mirror of
https://github.com/docker/build-push-action
synced 2024-11-23 02:31:41 +00:00
Add name output to identify builder instance name
Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com>
This commit is contained in:
parent
b72149bbe7
commit
0cc5e42c7a
7 changed files with 72 additions and 20 deletions
27
.github/workflows/setup-buildx-ci.yml
vendored
27
.github/workflows/setup-buildx-ci.yml
vendored
|
@ -40,6 +40,9 @@ jobs:
|
||||||
uses: ./setup-buildx/
|
uses: ./setup-buildx/
|
||||||
with:
|
with:
|
||||||
buildx-version: ${{ matrix.buildx-version }}
|
buildx-version: ${{ matrix.buildx-version }}
|
||||||
|
-
|
||||||
|
name: Builder instance name
|
||||||
|
run: echo ${{ steps.buildx.outputs.name }}
|
||||||
-
|
-
|
||||||
name: Available platforms
|
name: Available platforms
|
||||||
run: echo ${{ steps.buildx.outputs.platforms }}
|
run: echo ${{ steps.buildx.outputs.platforms }}
|
||||||
|
@ -47,6 +50,27 @@ jobs:
|
||||||
name: Dump context
|
name: Dump context
|
||||||
uses: crazy-max/ghaction-dump-context@v1
|
uses: crazy-max/ghaction-dump-context@v1
|
||||||
|
|
||||||
|
multi:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2.3.1
|
||||||
|
-
|
||||||
|
name: Set up Docker Buildx 1
|
||||||
|
id: buildx1
|
||||||
|
uses: ./setup-buildx/
|
||||||
|
-
|
||||||
|
name: Builder 1 instance name
|
||||||
|
run: echo ${{ steps.buildx1.outputs.name }}
|
||||||
|
-
|
||||||
|
name: Set up Docker Buildx 2
|
||||||
|
id: buildx2
|
||||||
|
uses: ./setup-buildx/
|
||||||
|
-
|
||||||
|
name: Builder 2 instance name
|
||||||
|
run: echo ${{ steps.buildx2.outputs.name }}
|
||||||
|
|
||||||
install:
|
install:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
|
@ -135,3 +159,6 @@ jobs:
|
||||||
-
|
-
|
||||||
name: Available platforms
|
name: Available platforms
|
||||||
run: echo ${{ steps.buildx.outputs.platforms }}
|
run: echo ${{ steps.buildx.outputs.platforms }}
|
||||||
|
-
|
||||||
|
name: Builder instance name
|
||||||
|
run: echo ${{ steps.buildx.outputs.name }}
|
||||||
|
|
|
@ -77,6 +77,9 @@ jobs:
|
||||||
uses: docker/actions/setup-buildx@v1
|
uses: docker/actions/setup-buildx@v1
|
||||||
with:
|
with:
|
||||||
buildx-version: latest
|
buildx-version: latest
|
||||||
|
-
|
||||||
|
name: Builder instance name
|
||||||
|
run: echo ${{ steps.buildx.outputs.name }}
|
||||||
-
|
-
|
||||||
name: Available platforms
|
name: Available platforms
|
||||||
run: echo ${{ steps.buildx.outputs.platforms }}
|
run: echo ${{ steps.buildx.outputs.platforms }}
|
||||||
|
@ -102,6 +105,7 @@ Following outputs are available
|
||||||
|
|
||||||
| Name | Type | Description |
|
| Name | Type | Description |
|
||||||
|---------------|---------|---------------------------------------|
|
|---------------|---------|---------------------------------------|
|
||||||
|
| `name` | String | Builder instance name |
|
||||||
| `platforms` | String | Available platforms (comma separated) |
|
| `platforms` | String | Available platforms (comma separated) |
|
||||||
|
|
||||||
### environment variables
|
### environment variables
|
||||||
|
|
|
@ -8,7 +8,13 @@ const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), 'setup-buildx-'));
|
||||||
describe('buildx', () => {
|
describe('buildx', () => {
|
||||||
it('is available', async () => {
|
it('is available', async () => {
|
||||||
expect(await buildx.isAvailable()).toBe(true);
|
expect(await buildx.isAvailable()).toBe(true);
|
||||||
}, 100000);
|
});
|
||||||
|
|
||||||
|
it('count builders', async () => {
|
||||||
|
const countBuilders = await buildx.countBuilders();
|
||||||
|
console.log(`countBuilders: ${countBuilders}`);
|
||||||
|
expect(countBuilders).toBeGreaterThan(0);
|
||||||
|
});
|
||||||
|
|
||||||
it('acquires v0.2.2 version of buildx', async () => {
|
it('acquires v0.2.2 version of buildx', async () => {
|
||||||
const buildxBin = await buildx.install('v0.2.2', tmpDir);
|
const buildxBin = await buildx.install('v0.2.2', tmpDir);
|
||||||
|
|
|
@ -27,6 +27,8 @@ inputs:
|
||||||
required: false
|
required: false
|
||||||
|
|
||||||
outputs:
|
outputs:
|
||||||
|
name:
|
||||||
|
description: 'Builder instance name'
|
||||||
platforms:
|
platforms:
|
||||||
description: 'Available platforms (comma separated)'
|
description: 'Available platforms (comma separated)'
|
||||||
|
|
||||||
|
|
27
setup-buildx/dist/index.js
generated
vendored
27
setup-buildx/dist/index.js
generated
vendored
|
@ -2501,15 +2501,11 @@ function run() {
|
||||||
}
|
}
|
||||||
core.info('📣 Buildx info');
|
core.info('📣 Buildx info');
|
||||||
yield exec.exec('docker', ['buildx', 'version'], false);
|
yield exec.exec('docker', ['buildx', 'version'], false);
|
||||||
|
const builderName = `builder-${(yield buildx.countBuilders()) + 1}-${process.env.GITHUB_JOB}`;
|
||||||
|
core.saveState('builderName', builderName);
|
||||||
|
core.setOutput('name', builderName);
|
||||||
core.info('🔨 Creating a new builder instance...');
|
core.info('🔨 Creating a new builder instance...');
|
||||||
let createArgs = [
|
let createArgs = ['buildx', 'create', '--name', builderName, '--driver', driver];
|
||||||
'buildx',
|
|
||||||
'create',
|
|
||||||
'--name',
|
|
||||||
`builder-${process.env.GITHUB_SHA}`,
|
|
||||||
'--driver',
|
|
||||||
driver
|
|
||||||
];
|
|
||||||
if (driverOpt) {
|
if (driverOpt) {
|
||||||
createArgs.push('--driver-opt', driverOpt);
|
createArgs.push('--driver-opt', driverOpt);
|
||||||
}
|
}
|
||||||
|
@ -2547,7 +2543,7 @@ function cleanup() {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
try {
|
try {
|
||||||
core.info('🚿 Removing builder instance...');
|
core.info('🚿 Removing builder instance...');
|
||||||
yield exec.exec('docker', ['buildx', 'rm', `builder-${process.env.GITHUB_SHA}`], false);
|
yield exec.exec('docker', ['buildx', 'rm', `${process.env.STATE_builderName}`], false);
|
||||||
}
|
}
|
||||||
catch (error) {
|
catch (error) {
|
||||||
core.warning(error.message);
|
core.warning(error.message);
|
||||||
|
@ -7243,7 +7239,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.install = exports.isAvailable = void 0;
|
exports.install = exports.countBuilders = exports.isAvailable = void 0;
|
||||||
const fs = __importStar(__webpack_require__(747));
|
const fs = __importStar(__webpack_require__(747));
|
||||||
const os = __importStar(__webpack_require__(87));
|
const os = __importStar(__webpack_require__(87));
|
||||||
const path = __importStar(__webpack_require__(622));
|
const path = __importStar(__webpack_require__(622));
|
||||||
|
@ -7265,6 +7261,17 @@ function isAvailable() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
exports.isAvailable = isAvailable;
|
exports.isAvailable = isAvailable;
|
||||||
|
function countBuilders() {
|
||||||
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
|
return yield exec.exec(`docker`, ['buildx', 'ls'], true).then(res => {
|
||||||
|
if (res.stderr != '' && !res.success) {
|
||||||
|
throw new Error(`Cannot list builders: ${res.stderr}`);
|
||||||
|
}
|
||||||
|
return (res.stdout.trim().split(`\n`).length - 1) / 2;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
exports.countBuilders = countBuilders;
|
||||||
function install(inputVersion, dockerConfigHome) {
|
function install(inputVersion, dockerConfigHome) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
const release = yield github.getRelease(inputVersion);
|
const release = yield github.getRelease(inputVersion);
|
||||||
|
|
|
@ -19,6 +19,15 @@ export async function isAvailable(): Promise<Boolean> {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export async function countBuilders(): Promise<number> {
|
||||||
|
return await exec.exec(`docker`, ['buildx', 'ls'], true).then(res => {
|
||||||
|
if (res.stderr != '' && !res.success) {
|
||||||
|
throw new Error(`Cannot list builders: ${res.stderr}`);
|
||||||
|
}
|
||||||
|
return (res.stdout.trim().split(`\n`).length - 1) / 2;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
export async function install(inputVersion: string, dockerConfigHome: string): Promise<string> {
|
export async function install(inputVersion: string, dockerConfigHome: string): Promise<string> {
|
||||||
const release: github.GitHubRelease | null = await github.getRelease(inputVersion);
|
const release: github.GitHubRelease | null = await github.getRelease(inputVersion);
|
||||||
if (!release) {
|
if (!release) {
|
||||||
|
|
|
@ -27,15 +27,12 @@ async function run(): Promise<void> {
|
||||||
core.info('📣 Buildx info');
|
core.info('📣 Buildx info');
|
||||||
await exec.exec('docker', ['buildx', 'version'], false);
|
await exec.exec('docker', ['buildx', 'version'], false);
|
||||||
|
|
||||||
|
const builderName: string = `builder-${(await buildx.countBuilders()) + 1}-${process.env.GITHUB_JOB}`;
|
||||||
|
core.saveState('builderName', builderName);
|
||||||
|
core.setOutput('name', builderName);
|
||||||
|
|
||||||
core.info('🔨 Creating a new builder instance...');
|
core.info('🔨 Creating a new builder instance...');
|
||||||
let createArgs: Array<string> = [
|
let createArgs: Array<string> = ['buildx', 'create', '--name', builderName, '--driver', driver];
|
||||||
'buildx',
|
|
||||||
'create',
|
|
||||||
'--name',
|
|
||||||
`builder-${process.env.GITHUB_SHA}`,
|
|
||||||
'--driver',
|
|
||||||
driver
|
|
||||||
];
|
|
||||||
if (driverOpt) {
|
if (driverOpt) {
|
||||||
createArgs.push('--driver-opt', driverOpt);
|
createArgs.push('--driver-opt', driverOpt);
|
||||||
}
|
}
|
||||||
|
@ -76,7 +73,7 @@ async function run(): Promise<void> {
|
||||||
async function cleanup(): Promise<void> {
|
async function cleanup(): Promise<void> {
|
||||||
try {
|
try {
|
||||||
core.info('🚿 Removing builder instance...');
|
core.info('🚿 Removing builder instance...');
|
||||||
await exec.exec('docker', ['buildx', 'rm', `builder-${process.env.GITHUB_SHA}`], false);
|
await exec.exec('docker', ['buildx', 'rm', `${process.env.STATE_builderName}`], false);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.warning(error.message);
|
core.warning(error.message);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue