mirror of
				https://github.com/docker/setup-buildx-action.git
				synced 2025-10-31 01:20:09 +08:00 
			
		
		
		
	 922550f064
			
		
	
	
		922550f064
		
			
		
	
	
	
	
		
			
			Background: before this change, if i tried to use GHA with an experimental driver, it would automatically append the flags `` --allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host ``` even if the underlying driver did not support them. Signed-off-by: Nick Santos <nick.santos@docker.com>
		
			
				
	
	
		
			249 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			249 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {beforeEach, describe, expect, jest, test} from '@jest/globals';
 | |
| import * as uuid from 'uuid';
 | |
| import {Buildx} from '@docker/actions-toolkit/lib/buildx/buildx';
 | |
| import {Docker} from '@docker/actions-toolkit/lib/docker/docker';
 | |
| import {Toolkit} from '@docker/actions-toolkit/lib/toolkit';
 | |
| import {Node} from '@docker/actions-toolkit/lib/types/builder';
 | |
| 
 | |
| import * as context from '../src/context';
 | |
| 
 | |
| jest.mock('uuid');
 | |
| jest.spyOn(uuid, 'v4').mockReturnValue('9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d');
 | |
| 
 | |
| jest.spyOn(Docker, 'context').mockImplementation((): Promise<string> => {
 | |
|   return Promise.resolve('default');
 | |
| });
 | |
| 
 | |
| 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,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['install', 'false'],
 | |
|         ['use', 'true'],
 | |
|         ['cleanup', '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,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['driver', 'docker'],
 | |
|         ['install', 'false'],
 | |
|         ['use', 'true'],
 | |
|         ['cleanup', 'true'],
 | |
|       ]),
 | |
|       [
 | |
|         'create',
 | |
|         '--name', 'default',
 | |
|         '--driver', 'docker',
 | |
|         '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host',
 | |
|         '--use'
 | |
|       ]
 | |
|     ],
 | |
|     [
 | |
|       2,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['install', 'false'],
 | |
|         ['use', 'false'],
 | |
|         ['driver-opts', 'image=moby/buildkit:master\nnetwork=host'],
 | |
|         ['cleanup', 'true'],
 | |
|       ]),
 | |
|       [
 | |
|         '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,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['driver', 'remote'],
 | |
|         ['endpoint', 'tls://foo:1234'],
 | |
|         ['install', 'false'],
 | |
|         ['use', 'true'],
 | |
|         ['cleanup', 'true'],
 | |
|       ]),
 | |
|       [
 | |
|         'create',
 | |
|         '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
 | |
|         '--driver', 'remote',
 | |
|         '--use',
 | |
|         'tls://foo:1234'
 | |
|       ]
 | |
|     ],
 | |
|     [
 | |
|       4,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['driver', 'remote'],
 | |
|         ['platforms', 'linux/arm64,linux/arm/v7'],
 | |
|         ['endpoint', 'tls://foo:1234'],
 | |
|         ['install', 'false'],
 | |
|         ['use', 'true'],
 | |
|         ['cleanup', 'true'],
 | |
|       ]),
 | |
|       [
 | |
|         'create',
 | |
|         '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
 | |
|         '--driver', 'remote',
 | |
|         '--platform', 'linux/arm64,linux/arm/v7',
 | |
|         '--use',
 | |
|         'tls://foo:1234'
 | |
|       ]
 | |
|     ],
 | |
|     [
 | |
|       5,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['install', 'false'],
 | |
|         ['use', 'false'],
 | |
|         ['driver-opts', `"env.no_proxy=localhost,127.0.0.1,.mydomain"`],
 | |
|         ['cleanup', 'true'],
 | |
|       ]),
 | |
|       [
 | |
|         '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,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['install', 'false'],
 | |
|         ['use', 'false'],
 | |
|         ['platforms', 'linux/amd64\n"linux/arm64,linux/arm/v7"'],
 | |
|         ['cleanup', 'true'],
 | |
|       ]),
 | |
|       [
 | |
|         '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'
 | |
|       ]
 | |
|     ],
 | |
|     [
 | |
|       7,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['install', 'false'],
 | |
|         ['use', 'false'],
 | |
|         ['driver', 'unknown'],
 | |
|         ['cleanup', 'true'],
 | |
|       ]),
 | |
|       [
 | |
|         'create',
 | |
|         '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d',
 | |
|         '--driver', 'unknown',
 | |
|       ]
 | |
|     ]
 | |
|   ])(
 | |
|     '[%d] given buildx %s and %p as inputs, returns %p',
 | |
|     async (num: number, buildxVersion: string, inputs: Map<string, string>, expected: Array<string>) => {
 | |
|       inputs.forEach((value: string, name: string) => {
 | |
|         setInput(name, value);
 | |
|       });
 | |
|       const toolkit = new Toolkit();
 | |
|       jest.spyOn(Buildx.prototype, 'version').mockImplementation(async (): Promise<string> => {
 | |
|         return buildxVersion;
 | |
|       });
 | |
|       const inp = await context.getInputs();
 | |
|       const res = await context.getCreateArgs(inp, toolkit);
 | |
|       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,
 | |
|       'v0.10.3',
 | |
|       new Map<string, string>([
 | |
|         ['install', 'false'],
 | |
|         ['use', 'true'],
 | |
|         ['cleanup', '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 buildx %s and %p as inputs, returns %p',
 | |
|     async (num: number, buildxVersion: string, inputs: Map<string, string>, node: Node, expected: Array<string>) => {
 | |
|       inputs.forEach((value: string, name: string) => {
 | |
|         setInput(name, value);
 | |
|       });
 | |
|       const toolkit = new Toolkit();
 | |
|       jest.spyOn(Buildx.prototype, 'version').mockImplementation(async (): Promise<string> => {
 | |
|         return buildxVersion;
 | |
|       });
 | |
|       const inp = await context.getInputs();
 | |
|       const res = await context.getAppendArgs(inp, node, toolkit);
 | |
|       expect(res).toEqual(expected);
 | |
|     }
 | |
|   );
 | |
| });
 | |
| 
 | |
| // 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;
 | |
| }
 |