mirror of
				https://github.com/docker/setup-buildx-action.git
				synced 2025-11-04 06:34:19 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			283 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			283 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import {beforeEach, describe, expect, it, jest, test} from '@jest/globals';
 | 
						|
import * as fs from 'fs';
 | 
						|
import * as os from 'os';
 | 
						|
import * as path from 'path';
 | 
						|
import * as uuid from 'uuid';
 | 
						|
import * as context from '../src/context';
 | 
						|
import * as nodes from '../src/nodes';
 | 
						|
 | 
						|
const tmpdir = fs.mkdtempSync(path.join(os.tmpdir(), 'docker-setup-buildx-')).split(path.sep).join(path.posix.sep);
 | 
						|
jest.spyOn(context, 'tmpDir').mockImplementation((): string => {
 | 
						|
  return tmpdir;
 | 
						|
});
 | 
						|
 | 
						|
jest.spyOn(context, 'tmpNameSync').mockImplementation((): string => {
 | 
						|
  return path.join(tmpdir, '.tmpname').split(path.sep).join(path.posix.sep);
 | 
						|
});
 | 
						|
 | 
						|
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'
 | 
						|
      ]
 | 
						|
    ],
 | 
						|
    [
 | 
						|
      4,
 | 
						|
      new Map<string, string>([
 | 
						|
        ['driver', 'remote'],
 | 
						|
        ['platforms', 'linux/arm64,linux/arm/v7'],
 | 
						|
        ['endpoint', 'tls://foo:1234'],
 | 
						|
        ['install', 'false'],
 | 
						|
        ['use', 'true'],
 | 
						|
      ]),
 | 
						|
      [
 | 
						|
        'create',
 | 
						|
        '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
 | 
						|
        '--driver', 'remote',
 | 
						|
        '--platform', 'linux/arm64,linux/arm/v7',
 | 
						|
        '--use',
 | 
						|
        'tls://foo:1234'
 | 
						|
      ]
 | 
						|
    ],
 | 
						|
    [
 | 
						|
      5,
 | 
						|
      new Map<string, string>([
 | 
						|
        ['install', 'false'],
 | 
						|
        ['use', 'false'],
 | 
						|
        ['driver-opts', `"env.no_proxy=localhost,127.0.0.1,.mydomain"`],
 | 
						|
      ]),
 | 
						|
      [
 | 
						|
        'create',
 | 
						|
        '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
 | 
						|
        '--driver', 'docker-container',
 | 
						|
        '--driver-opt', '"env.no_proxy=localhost,127.0.0.1,.mydomain"',
 | 
						|
        '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host'
 | 
						|
      ]
 | 
						|
    ],
 | 
						|
    [
 | 
						|
      6,
 | 
						|
      new Map<string, string>([
 | 
						|
        ['install', 'false'],
 | 
						|
        ['use', 'false'],
 | 
						|
        ['platforms', 'linux/amd64\n"linux/arm64,linux/arm/v7"'],
 | 
						|
      ]),
 | 
						|
      [
 | 
						|
        'create',
 | 
						|
        '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
 | 
						|
        '--driver', 'docker-container',
 | 
						|
        '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host',
 | 
						|
        '--platform', 'linux/amd64,linux/arm64,linux/arm/v7'
 | 
						|
      ]
 | 
						|
    ],
 | 
						|
  ])(
 | 
						|
    '[%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);
 | 
						|
    }
 | 
						|
  );
 | 
						|
});
 | 
						|
 | 
						|
describe('getAppendArgs', () => {
 | 
						|
  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'],
 | 
						|
      ]),
 | 
						|
      {
 | 
						|
        "name": "aws_graviton2",
 | 
						|
        "endpoint": "ssh://me@graviton2",
 | 
						|
        "driver-opts": [
 | 
						|
          "image=moby/buildkit:latest"
 | 
						|
        ],
 | 
						|
        "buildkitd-flags": "--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host",
 | 
						|
        "platforms": "linux/arm64"
 | 
						|
      },
 | 
						|
      [
 | 
						|
        'create',
 | 
						|
        '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
 | 
						|
        '--append',
 | 
						|
        '--node', 'aws_graviton2',
 | 
						|
        '--driver-opt', 'image=moby/buildkit:latest',
 | 
						|
        '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host',
 | 
						|
        '--platform', 'linux/arm64',
 | 
						|
        'ssh://me@graviton2'
 | 
						|
      ]
 | 
						|
    ]
 | 
						|
  ])(
 | 
						|
    '[%d] given %p as inputs, returns %p',
 | 
						|
    async (num: number, inputs: Map<string, string>, node: nodes.Node, expected: Array<string>) => {
 | 
						|
      inputs.forEach((value: string, name: string) => {
 | 
						|
        setInput(name, value);
 | 
						|
      });
 | 
						|
      const inp = await context.getInputs();
 | 
						|
      const res = await context.getAppendArgs(inp, node, '0.9.0');
 | 
						|
      expect(res).toEqual(expected);
 | 
						|
    }
 | 
						|
  );
 | 
						|
});
 | 
						|
 | 
						|
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']);
 | 
						|
  });
 | 
						|
 | 
						|
  it('remove empty lines correctly', async () => {
 | 
						|
    setInput('foo', 'bar\n\nbaz');
 | 
						|
    const res = await context.getInputList('foo');
 | 
						|
    expect(res).toEqual(['bar', 'baz']);
 | 
						|
  });
 | 
						|
 | 
						|
  it('handles comma correctly', async () => {
 | 
						|
    setInput('foo', 'bar,baz');
 | 
						|
    const res = await context.getInputList('foo');
 | 
						|
    expect(res).toEqual(['bar', 'baz']);
 | 
						|
  });
 | 
						|
 | 
						|
  it('remove empty result correctly', async () => {
 | 
						|
    setInput('foo', 'bar,baz,');
 | 
						|
    const res = await context.getInputList('foo');
 | 
						|
    expect(res).toEqual(['bar', 'baz']);
 | 
						|
  });
 | 
						|
 | 
						|
  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);
 | 
						|
  });
 | 
						|
});
 | 
						|
 | 
						|
// 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;
 | 
						|
}
 |