2022-09-19 11:36:58 +02:00
|
|
|
import {beforeEach, describe, expect, it, jest, test} from '@jest/globals';
|
2021-07-02 07:02:22 +02:00
|
|
|
import * as fs from 'fs';
|
2021-04-23 18:14:38 +02:00
|
|
|
import * as os from 'os';
|
2021-07-02 07:02:22 +02:00
|
|
|
import * as path from 'path';
|
2022-09-19 11:36:58 +02:00
|
|
|
import * as uuid from 'uuid';
|
2020-09-03 16:23:15 +02:00
|
|
|
import * as context from '../src/context';
|
|
|
|
|
2022-09-22 02:48:11 +02:00
|
|
|
const tmpdir = fs.mkdtempSync(path.join(os.tmpdir(), 'docker-setup-buildx-')).split(path.sep).join(path.posix.sep);
|
2021-07-02 07:02:22 +02:00
|
|
|
jest.spyOn(context, 'tmpDir').mockImplementation((): string => {
|
2022-09-22 02:48:11 +02:00
|
|
|
return tmpdir;
|
2021-07-02 07:02:22 +02:00
|
|
|
});
|
|
|
|
|
2021-09-03 22:21:20 +02:00
|
|
|
jest.spyOn(context, 'tmpNameSync').mockImplementation((): string => {
|
2022-09-22 02:48:11 +02:00
|
|
|
return path.join(tmpdir, '.tmpname').split(path.sep).join(path.posix.sep);
|
2021-09-03 22:21:20 +02:00
|
|
|
});
|
|
|
|
|
2022-09-19 11:36:58 +02:00
|
|
|
jest.mock('uuid');
|
|
|
|
jest.spyOn(uuid, 'v4').mockReturnValue('9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d');
|
|
|
|
|
|
|
|
describe('getCreateArgs', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
process.env = Object.keys(process.env).reduce((object, key) => {
|
|
|
|
if (!key.startsWith('INPUT_')) {
|
|
|
|
object[key] = process.env[key];
|
|
|
|
}
|
|
|
|
return object;
|
|
|
|
}, {});
|
|
|
|
});
|
|
|
|
|
|
|
|
// prettier-ignore
|
|
|
|
test.each([
|
|
|
|
[
|
|
|
|
0,
|
|
|
|
new Map<string, string>([
|
|
|
|
['install', 'false'],
|
|
|
|
['use', 'true'],
|
|
|
|
]),
|
|
|
|
[
|
|
|
|
'create',
|
|
|
|
'--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
|
|
|
|
'--driver', 'docker-container',
|
|
|
|
'--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host',
|
|
|
|
'--use'
|
|
|
|
]
|
|
|
|
],
|
|
|
|
[
|
|
|
|
1,
|
|
|
|
new Map<string, string>([
|
|
|
|
['driver', 'docker'],
|
|
|
|
['install', 'false'],
|
|
|
|
['use', 'true'],
|
|
|
|
]),
|
|
|
|
[
|
|
|
|
'create',
|
|
|
|
'--name', 'default',
|
|
|
|
'--driver', 'docker',
|
|
|
|
'--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host',
|
|
|
|
'--use'
|
|
|
|
]
|
|
|
|
],
|
|
|
|
[
|
|
|
|
2,
|
|
|
|
new Map<string, string>([
|
|
|
|
['install', 'false'],
|
|
|
|
['use', 'false'],
|
|
|
|
['driver-opts', 'image=moby/buildkit:master\nnetwork=host'],
|
|
|
|
]),
|
|
|
|
[
|
|
|
|
'create',
|
|
|
|
'--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
|
|
|
|
'--driver', 'docker-container',
|
|
|
|
'--driver-opt', 'image=moby/buildkit:master',
|
|
|
|
'--driver-opt', 'network=host',
|
|
|
|
'--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host'
|
|
|
|
]
|
|
|
|
],
|
|
|
|
[
|
|
|
|
3,
|
|
|
|
new Map<string, string>([
|
|
|
|
['driver', 'remote'],
|
|
|
|
['endpoint', 'tls://foo:1234'],
|
|
|
|
['install', 'false'],
|
|
|
|
['use', 'true'],
|
|
|
|
]),
|
|
|
|
[
|
|
|
|
'create',
|
|
|
|
'--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
|
|
|
|
'--driver', 'remote',
|
|
|
|
'--use',
|
|
|
|
'tls://foo:1234'
|
|
|
|
]
|
|
|
|
],
|
|
|
|
])(
|
|
|
|
'[%d] given %p as inputs, returns %p',
|
|
|
|
async (num: number, inputs: Map<string, string>, expected: Array<string>) => {
|
|
|
|
inputs.forEach((value: string, name: string) => {
|
|
|
|
setInput(name, value);
|
|
|
|
});
|
|
|
|
const inp = await context.getInputs();
|
|
|
|
const res = await context.getCreateArgs(inp, '0.9.0');
|
|
|
|
expect(res).toEqual(expected);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2020-09-03 16:23:15 +02:00
|
|
|
describe('getInputList', () => {
|
|
|
|
it('handles single line correctly', async () => {
|
|
|
|
await setInput('foo', 'bar');
|
|
|
|
const res = await context.getInputList('foo');
|
|
|
|
expect(res).toEqual(['bar']);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('handles multiple lines correctly', async () => {
|
|
|
|
setInput('foo', 'bar\nbaz');
|
|
|
|
const res = await context.getInputList('foo');
|
|
|
|
expect(res).toEqual(['bar', 'baz']);
|
|
|
|
});
|
|
|
|
|
2020-09-12 23:34:53 +02:00
|
|
|
it('remove empty lines correctly', async () => {
|
|
|
|
setInput('foo', 'bar\n\nbaz');
|
|
|
|
const res = await context.getInputList('foo');
|
|
|
|
expect(res).toEqual(['bar', 'baz']);
|
|
|
|
});
|
|
|
|
|
2020-09-03 16:23:15 +02:00
|
|
|
it('handles comma correctly', async () => {
|
|
|
|
setInput('foo', 'bar,baz');
|
|
|
|
const res = await context.getInputList('foo');
|
|
|
|
expect(res).toEqual(['bar', 'baz']);
|
|
|
|
});
|
|
|
|
|
2020-09-12 23:34:53 +02:00
|
|
|
it('remove empty result correctly', async () => {
|
|
|
|
setInput('foo', 'bar,baz,');
|
|
|
|
const res = await context.getInputList('foo');
|
|
|
|
expect(res).toEqual(['bar', 'baz']);
|
|
|
|
});
|
|
|
|
|
2020-09-03 16:23:15 +02:00
|
|
|
it('handles different new lines correctly', async () => {
|
|
|
|
setInput('foo', 'bar\r\nbaz');
|
|
|
|
const res = await context.getInputList('foo');
|
|
|
|
expect(res).toEqual(['bar', 'baz']);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('handles different new lines and comma correctly', async () => {
|
|
|
|
setInput('foo', 'bar\r\nbaz,bat');
|
|
|
|
const res = await context.getInputList('foo');
|
|
|
|
expect(res).toEqual(['bar', 'baz', 'bat']);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('handles multiple lines and ignoring comma correctly', async () => {
|
|
|
|
setInput('driver-opts', 'image=moby/buildkit:master\nnetwork=host');
|
|
|
|
const res = await context.getInputList('driver-opts', true);
|
|
|
|
expect(res).toEqual(['image=moby/buildkit:master', 'network=host']);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('handles different new lines and ignoring comma correctly', async () => {
|
|
|
|
setInput('driver-opts', 'image=moby/buildkit:master\r\nnetwork=host');
|
|
|
|
const res = await context.getInputList('driver-opts', true);
|
|
|
|
expect(res).toEqual(['image=moby/buildkit:master', 'network=host']);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('asyncForEach', () => {
|
|
|
|
it('executes async tasks sequentially', async () => {
|
|
|
|
const testValues = [1, 2, 3, 4, 5];
|
|
|
|
const results: number[] = [];
|
|
|
|
|
|
|
|
await context.asyncForEach(testValues, async value => {
|
|
|
|
results.push(value);
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(results).toEqual(testValues);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-04-23 18:14:38 +02:00
|
|
|
describe('setOutput', () => {
|
|
|
|
beforeEach(() => {
|
2022-03-21 13:43:41 +01:00
|
|
|
process.stdout.write = jest.fn() as typeof process.stdout.write;
|
2021-04-23 18:14:38 +02:00
|
|
|
});
|
|
|
|
|
2022-03-21 13:43:41 +01:00
|
|
|
// eslint-disable-next-line jest/expect-expect
|
2021-04-23 18:14:38 +02:00
|
|
|
it('setOutput produces the correct command', () => {
|
|
|
|
context.setOutput('some output', 'some value');
|
|
|
|
assertWriteCalls([`::set-output name=some output::some value${os.EOL}`]);
|
|
|
|
});
|
|
|
|
|
2022-03-21 13:43:41 +01:00
|
|
|
// eslint-disable-next-line jest/expect-expect
|
2021-04-23 18:14:38 +02:00
|
|
|
it('setOutput handles bools', () => {
|
|
|
|
context.setOutput('some output', false);
|
|
|
|
assertWriteCalls([`::set-output name=some output::false${os.EOL}`]);
|
|
|
|
});
|
|
|
|
|
2022-03-21 13:43:41 +01:00
|
|
|
// eslint-disable-next-line jest/expect-expect
|
2021-04-23 18:14:38 +02:00
|
|
|
it('setOutput handles numbers', () => {
|
|
|
|
context.setOutput('some output', 1.01);
|
|
|
|
assertWriteCalls([`::set-output name=some output::1.01${os.EOL}`]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2020-09-03 16:23:15 +02:00
|
|
|
// See: https://github.com/actions/toolkit/blob/master/packages/core/src/core.ts#L67
|
|
|
|
function getInputName(name: string): string {
|
|
|
|
return `INPUT_${name.replace(/ /g, '_').toUpperCase()}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
function setInput(name: string, value: string): void {
|
|
|
|
process.env[getInputName(name)] = value;
|
|
|
|
}
|
2021-04-23 18:14:38 +02:00
|
|
|
|
|
|
|
// Assert that process.stdout.write calls called only with the given arguments.
|
|
|
|
function assertWriteCalls(calls: string[]): void {
|
|
|
|
expect(process.stdout.write).toHaveBeenCalledTimes(calls.length);
|
|
|
|
for (let i = 0; i < calls.length; i++) {
|
|
|
|
expect(process.stdout.write).toHaveBeenNthCalledWith(i + 1, calls[i]);
|
|
|
|
}
|
|
|
|
}
|