Skip to content

Commit

Permalink
fix: variable expansion in environment
Browse files Browse the repository at this point in the history
  • Loading branch information
ANGkeith committed Nov 30, 2024
1 parent 8fa0245 commit 83b28e4
Show file tree
Hide file tree
Showing 5 changed files with 57 additions and 10 deletions.
23 changes: 14 additions & 9 deletions src/job.ts
Original file line number Diff line number Diff line change
Expand Up @@ -198,6 +198,9 @@ export class Job {
predefinedVariables["CI_REGISTRY"] = `local-registry.${this.gitData.remote.host}`;
predefinedVariables["CI_REGISTRY_IMAGE"] = `$CI_REGISTRY/${this._variables["CI_PROJECT_PATH"].toLowerCase()}`;

// NOTE: Update `this._variables` with the patched predefinedVariables
this._variables = {...this.globalVariables, ...jobVariables, ...matrixVariables, ...predefinedVariables, ...fileVariables, ...argvVariables};

// Expand variables in rules:changes
if (this.rules && expandVariables) {
const expanded = Utils.expandVariables(this._variables);
Expand All @@ -214,6 +217,16 @@ export class Job {
});
}

let ruleVariables: {[name: string]: string} | undefined;
// Set {when, allowFailure} based on rules result
if (this.rules) {
const ruleResult = Utils.getRulesResult({argv, cwd, rules: this.rules, variables: this._variables}, this.gitData, this.when, this.allowFailure);
this.when = ruleResult.when;
this.allowFailure = ruleResult.allowFailure;
ruleVariables = ruleResult.variables;
this._variables = {...this._variables, ...ruleVariables, ...argvVariables};
}

// Find environment matched variables
if (this.environment && expandVariables) {
const expanded = Utils.expandVariables(this._variables);
Expand All @@ -223,15 +236,7 @@ export class Job {
const envMatchedVariables = Utils.findEnvMatchedVariables(variablesFromFiles, this.fileVariablesDir, this.environment);

// Merge and expand after finding env matched variables
this._variables = {...this.globalVariables, ...jobVariables, ...matrixVariables, ...predefinedVariables, ...envMatchedVariables, ...argvVariables};

// Set {when, allowFailure} based on rules result
if (this.rules) {
const ruleResult = Utils.getRulesResult({argv, cwd, rules: this.rules, variables: this._variables}, this.gitData, this.when, this.allowFailure);
this.when = ruleResult.when;
this.allowFailure = ruleResult.allowFailure;
this._variables = {...this.globalVariables, ...jobVariables, ...ruleResult.variables, ...matrixVariables, ...predefinedVariables, ...envMatchedVariables, ...argvVariables};
}
this._variables = {...this.globalVariables, ...jobVariables, ...matrixVariables, ...predefinedVariables, ...ruleVariables, ...envMatchedVariables, ...argvVariables};
// Delete variables the user intentionally wants unset
for (const unsetVariable of argv.unsetVariables) {
delete this._variables[unsetVariable];
Expand Down
2 changes: 1 addition & 1 deletion src/parser.ts
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,7 @@ export class Parser {
baseName: jobName,
globalVariables: gitlabData.variables,
pipelineIid: pipelineIid,
predefinedVariables,
predefinedVariables: {...predefinedVariables}, // NOTE: pass by value because predefinedVariables is mutated in the constructor
gitData,
variablesFromFiles,
matrixVariables: parallelMatrixVariables,
Expand Down
6 changes: 6 additions & 0 deletions tests/test-cases/variable-expansion/.gitlab-ci-1.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
job:
environment:
name: review/$CI_JOB_STAGE/deploy
script:
- echo 'deploy staging'
10 changes: 10 additions & 0 deletions tests/test-cases/variable-expansion/.gitlab-ci-2.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
---
job:
rules:
- variables:
PIPELINE_ENVIRONMENT: test
image: alpine
environment:
name: $PIPELINE_ENVIRONMENT # expects this to be expanded to `test`
script:
- echo $PIPELINE_ENVIRONMENT
Original file line number Diff line number Diff line change
Expand Up @@ -63,3 +63,29 @@ test(`variable-expansion <${test_job_4}>`, async () => {

expect(writeStreams.stdoutLines.join("\n")).toContain(expected);
});

test("should expand predefined variables in environment", async () => {
const writeStreams = new WriteStreamsMock();
await handler({
cwd: "tests/test-cases/variable-expansion",
file: ".gitlab-ci-1.yml",
noColor: true,
}, writeStreams);

const expected = "job environment: { name: review/test/deploy }";
const filteredStdout = writeStreams.stdoutLines.filter(f => f.startsWith("job environment")).join("\n");
expect(filteredStdout).toEqual(expected);
});

test("should expand rule variables in environment", async () => {
const writeStreams = new WriteStreamsMock();
await handler({
cwd: "tests/test-cases/variable-expansion",
file: ".gitlab-ci-2.yml",
noColor: true,
}, writeStreams);

const expected = "job environment: { name: test }";
const filteredStdout = writeStreams.stdoutLines.filter(f => f.startsWith("job environment")).join("\n");
expect(filteredStdout).toEqual(expected);
});

0 comments on commit 83b28e4

Please sign in to comment.