mirror of
https://github.com/docker/build-push-action.git
synced 2025-04-04 22:20:07 +02:00
Test failures fixed, added 3 new test cases
Signed-off-by: Jyotsna <Josh-01@github.com>
This commit is contained in:
parent
dd55519eee
commit
e2bf0d0cc1
3 changed files with 83 additions and 17 deletions
|
@ -10,6 +10,7 @@ jest.spyOn(context, 'tmpDir').mockImplementation((): string => {
|
|||
const tmpDir = path.join('/tmp/.docker-build-push-jest').split(path.sep).join(path.posix.sep);
|
||||
if (!fs.existsSync(tmpDir)) {
|
||||
fs.mkdirSync(tmpDir, {recursive: true});
|
||||
2;
|
||||
}
|
||||
return tmpDir;
|
||||
});
|
||||
|
@ -146,6 +147,8 @@ describe('getArgs', () => {
|
|||
[
|
||||
'buildx',
|
||||
'build',
|
||||
'--label', 'org.opencontainers.image.source=https://github.com/docker/build-push-action.git',
|
||||
'--label', 'dockerfile-path=./test/Dockerfile',
|
||||
'--platform', 'linux/amd64,linux/arm64',
|
||||
'--iidfile', '/tmp/.docker-build-push-jest/iidfile',
|
||||
'--secret', 'id=GIT_AUTH_TOKEN,src=/tmp/.docker-build-push-jest/.tmpname-jest',
|
||||
|
@ -154,6 +157,59 @@ describe('getArgs', () => {
|
|||
'--push',
|
||||
'https://github.com/docker/build-push-action.git#heads/master'
|
||||
]
|
||||
],
|
||||
[
|
||||
'0.4.2',
|
||||
new Map<string, string>([
|
||||
['context', '.'],
|
||||
['labels', 'org.opencontainers.image.source=UserProvidedSourceLabel'],
|
||||
['outputs', 'type=image,dest=./release-out']
|
||||
]),
|
||||
[
|
||||
'buildx',
|
||||
'build',
|
||||
'--label', 'org.opencontainers.image.source=UserProvidedSourceLabel',
|
||||
'--label', 'dockerfile-path=Dockerfile',
|
||||
'--output', 'type=image,dest=./release-out',
|
||||
'--iidfile', '/tmp/.docker-build-push-jest/iidfile',
|
||||
'--file', 'Dockerfile',
|
||||
'.'
|
||||
]
|
||||
],
|
||||
[
|
||||
'0.4.2',
|
||||
new Map<string, string>([
|
||||
['context', '.'],
|
||||
['outputs', 'type=registry,dest=./release-out']
|
||||
]),
|
||||
[
|
||||
'buildx',
|
||||
'build',
|
||||
'--label', 'org.opencontainers.image.source=https://github.com/docker/build-push-action.git',
|
||||
'--label', 'dockerfile-path=Dockerfile',
|
||||
'--output', 'type=registry,dest=./release-out',
|
||||
'--iidfile', '/tmp/.docker-build-push-jest/iidfile',
|
||||
'--file', 'Dockerfile',
|
||||
'.'
|
||||
]
|
||||
],
|
||||
[
|
||||
'0.4.2',
|
||||
new Map<string, string>([
|
||||
['context', '.'],
|
||||
['labels', 'org.opencontainers.image.source=UserProvidedSourceLabel'],
|
||||
['load', 'true']
|
||||
]),
|
||||
[
|
||||
'buildx',
|
||||
'build',
|
||||
'--label', 'org.opencontainers.image.source=UserProvidedSourceLabel',
|
||||
'--label', 'dockerfile-path=Dockerfile',
|
||||
'--iidfile', '/tmp/.docker-build-push-jest/iidfile',
|
||||
'--file', 'Dockerfile',
|
||||
'--load',
|
||||
'.'
|
||||
]
|
||||
]
|
||||
])(
|
||||
'given %p with %p as inputs, returns %p',
|
||||
|
|
7
dist/index.js
generated
vendored
7
dist/index.js
generated
vendored
|
@ -12085,14 +12085,19 @@ function getInputs(defaultContext) {
|
|||
githubToken: core.getInput('github-token'),
|
||||
ssh: yield getInputList('ssh')
|
||||
};
|
||||
if (userInputs.load == true ||
|
||||
userInputs.push == true ||
|
||||
userInputs.outputs.find(val => val.indexOf('type=image') > -1 || val.indexOf('type=registry') > -1)) {
|
||||
//Add repo as source-label if not already supplied by user
|
||||
const sourceLabelKey = 'org.opencontainers.image.source';
|
||||
if (userInputs.labels.find(val => val.startsWith(sourceLabelKey) == true) == null) {
|
||||
userInputs.labels.push(`${sourceLabelKey}=https://github.com/${github.context.repo.owner}/${github.context.repo.repo}`);
|
||||
const githubOwnerRepoUrl = defaultContext.split('#')[0];
|
||||
userInputs.labels.push(`${sourceLabelKey}=${githubOwnerRepoUrl}`);
|
||||
}
|
||||
//Add dockerfile path as label
|
||||
let dockerfilePath = userInputs.file;
|
||||
userInputs.labels.push(`dockerfile-path=${dockerfilePath}`);
|
||||
}
|
||||
return userInputs;
|
||||
});
|
||||
}
|
||||
|
|
|
@ -76,17 +76,22 @@ export async function getInputs(defaultContext: string): Promise<Inputs> {
|
|||
ssh: await getInputList('ssh')
|
||||
};
|
||||
|
||||
if (
|
||||
userInputs.load == true ||
|
||||
userInputs.push == true ||
|
||||
userInputs.outputs.find(val => val.indexOf('type=image') > -1 || val.indexOf('type=registry') > -1)
|
||||
) {
|
||||
//Add repo as source-label if not already supplied by user
|
||||
const sourceLabelKey = 'org.opencontainers.image.source';
|
||||
if (userInputs.labels.find(val => val.startsWith(sourceLabelKey) == true) == null) {
|
||||
userInputs.labels.push(
|
||||
`${sourceLabelKey}=https://github.com/${github.context.repo.owner}/${github.context.repo.repo}`
|
||||
);
|
||||
const githubOwnerRepoUrl = defaultContext.split('#')[0];
|
||||
userInputs.labels.push(`${sourceLabelKey}=${githubOwnerRepoUrl}`);
|
||||
}
|
||||
|
||||
//Add dockerfile path as label
|
||||
let dockerfilePath = userInputs.file;
|
||||
userInputs.labels.push(`dockerfile-path=${dockerfilePath}`);
|
||||
}
|
||||
|
||||
return userInputs;
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue