gitlab-ci-local 4.31.0 → 4.33.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -26,12 +26,13 @@ Get rid of all those dev specific shell scripts and make files.
26
26
  * [docker-swarm-php](./examples/docker-swarm-php/README.md)
27
27
  * [Installation](#installation)
28
28
  * [Convenience](#convenience)
29
- * [CLI options via shell](#cli-options-via-shell)
29
+ * [CLI options via shell](#cli-options-via-shell)
30
30
  * [DotEnv file](#dotenv-file)
31
31
  * [Bash alias](#bash-alias)
32
32
  * [Tab completion](#tab-completion)
33
33
  * [Quirks](#quirks)
34
34
  * [Tracked Files](#tracked-files)
35
+ * [Local Only](#local-only)
35
36
  * [Home File Variables](#home-file-variables)
36
37
  * [Remote File Variables](#remote-file-variables)
37
38
  * [Project File Variables](#project-file-variables)
@@ -90,7 +91,7 @@ export GLC_VARIABLES="IMAGE=someimage SOMEOTHERIMAGE=someotherimage"
90
91
 
91
92
  ### DotEnv file
92
93
 
93
- Add a `.gitlab-ci-local-env` file to the current working directory
94
+ Add a `.gitlab-ci-local-env` file to the current working directory or a `.env` file in `$HOME/.gitlab-ci-local`
94
95
 
95
96
  ```
96
97
  # Overrides .gitlab-ci.yml as the default git ci/cd file
@@ -122,6 +123,21 @@ Untracked and ignored files will not be synced inside isolated jobs, only tracke
122
123
 
123
124
  Remember `git add`
124
125
 
126
+ ### Local Only
127
+
128
+ ```yml
129
+ local-only-job:
130
+ rules:
131
+ - { if: $GITLAB_CI == 'false' }
132
+ ```
133
+
134
+ ```yml
135
+ local-only-subsection:
136
+ script:
137
+ - if [ $GITLAB_CI == 'false' ]; then eslint . --fix; fi
138
+ - eslint .
139
+ ```
140
+
125
141
  ### Home file variables
126
142
 
127
143
  Put a file like this in `$HOME/.gitlab-ci-local/variables.yml`
@@ -233,6 +249,11 @@ produce:
233
249
  artifacts: { paths: [path/] }
234
250
  ```
235
251
 
252
+ A global configuration is possible when setting the following flag
253
+ ```shell
254
+ gitlab-ci-local --no-artifacts-to-source
255
+ ```
256
+
236
257
  ### Includes
237
258
 
238
259
  Includes from external sources are only fetched once. Use `--fetch-includes` to invoke an external fetching rutine.
@@ -246,7 +267,7 @@ Docker executor copies artifacts to and from .gitlab-ci-local/artifacts
246
267
 
247
268
  ## Development
248
269
 
249
- You need nodejs 16+
270
+ You need nodejs 18+
250
271
 
251
272
  ### Scripts
252
273
 
package/package.json CHANGED
@@ -3,61 +3,63 @@
3
3
  "description": "Tired of pushing to test your .gitlab-ci.yml?",
4
4
  "main": "src/index.js",
5
5
  "bin": "src/index.js",
6
- "version": "4.31.0",
6
+ "version": "4.33.1",
7
7
  "scripts": {
8
8
  "prepublishOnly": "npm run check-all && chmod +x src/index.js",
9
- "pkg-linux": "pkg src/index.js --public -t node16-linux-x64 -o bin/linux/gitlab-ci-local && chmod +x bin/linux/gitlab-ci-local && gzip -c bin/linux/gitlab-ci-local > bin/linux.gz",
10
- "pkg-macos": "pkg src/index.js --public -t node16-macos-x64 -o bin/macos/gitlab-ci-local && gzip -c bin/macos/gitlab-ci-local > bin/macos.gz",
11
- "pkg-win": "pkg src/index.js --public -t node16-win-x64 -o bin/win/gitlab-ci-local && gzip -c bin/win/gitlab-ci-local.exe > bin/win.gz",
9
+ "pkg-linux": "pkg src/index.js --public -t node18-linux-x64 -o bin/linux/gitlab-ci-local && chmod +x bin/linux/gitlab-ci-local && gzip -c bin/linux/gitlab-ci-local > bin/linux.gz",
10
+ "pkg-macos": "pkg src/index.js --public -t node18-macos-x64 -o bin/macos/gitlab-ci-local && gzip -c bin/macos/gitlab-ci-local > bin/macos.gz",
11
+ "pkg-win": "pkg src/index.js --public -t node18-win-x64 -o bin/win/gitlab-ci-local && gzip -c bin/win/gitlab-ci-local.exe > bin/win.gz",
12
12
  "pkg-all": "npm run pkg-linux && npm run pkg-macos && npm run pkg-win",
13
13
  "pkg": "pkg",
14
- "build": "rm -f src/*.js src/*.d.ts && tsc",
15
- "check-all": "npm run build && npm run lint && npm run coverage",
14
+ "cleanup": "rm -rf src/*.js src/**/*.d.ts tests/*.js tests/test-cases/*/*.js tests/test-cases/*/.gitlab-ci-local",
15
+ "build": " npm run cleanup && tsc",
16
+ "check-all": "npm run build && npm run lint && npm run coverage && npm run audit",
16
17
  "audit": "npm audit --parseable",
17
18
  "lint": "npx eslint .",
18
- "test": "jest --testTimeout 30000",
19
+ "test": "npm run build && jest --testTimeout 30000",
19
20
  "coverage": "jest --coverage --testTimeout 30000",
20
21
  "start": "ts-node --log-error src/index.ts --cwd examples/docker-compose-nodejs"
21
22
  },
22
23
  "dependencies": {
23
- "axios": "^0.27.2",
24
- "base64url": "^3.0.1",
25
- "camelcase": "^6.3.0",
26
- "chalk": "^4.1.2",
27
- "checksum": "^1.0.0",
28
- "deep-extend": "^0.6.0",
29
- "dotenv": "^16.0.0",
30
- "execa": "^5.1.1",
31
- "fs-extra": "^10.1.0",
32
- "js-yaml": "^4.1.0",
33
- "object-traversal": "^1.0.1",
34
- "pretty-hrtime": "^1.0.3",
35
- "source-map-support": "^0.5.21",
36
- "yargs": "^17.4.1"
24
+ "axios": "0.27.2",
25
+ "base64url": "3.0.1",
26
+ "camelcase": "6.3.0",
27
+ "chalk": "4.1.2",
28
+ "checksum": "1.0.0",
29
+ "deep-extend": "0.6.0",
30
+ "dotenv": "16.0.1",
31
+ "execa": "5.1.1",
32
+ "fs-extra": "10.1.0",
33
+ "globby": "^11.0.4",
34
+ "js-yaml": "4.1.0",
35
+ "object-traversal": "1.0.1",
36
+ "pretty-hrtime": "1.0.3",
37
+ "source-map-support": "0.5.21",
38
+ "yargs": "17.5.1"
37
39
  },
38
40
  "devDependencies": {
39
- "@types/base64url": "^2.0.3",
40
- "@types/camelcase": "^5.2.0",
41
+ "@types/base64url": "2.0.3",
42
+ "@types/camelcase": "5.2.0",
41
43
  "@types/checksum": "0.1.33",
42
44
  "@types/deep-extend": "0.4.32",
43
45
  "@types/fs-extra": "9.0.13",
44
- "@types/jest": "27.5.0",
45
- "@types/jest-when": "3.5.0",
46
+ "@types/jest": "28.1.6",
47
+ "@types/jest-when": "3.5.2",
46
48
  "@types/js-yaml": "4.0.5",
47
49
  "@types/pretty-hrtime": "1.0.1",
48
50
  "@types/source-map-support": "0.5.4",
49
- "@types/yargs": "17.0.10",
50
- "@typescript-eslint/eslint-plugin": "5.22.0",
51
- "@typescript-eslint/parser": "5.22.0",
52
- "axios-mock-adapter": "1.20.0",
51
+ "@types/yargs": "17.0.11",
52
+ "@typescript-eslint/eslint-plugin": "5.33.0",
53
+ "@typescript-eslint/parser": "5.33.0",
54
+ "axios-mock-adapter": "1.21.2",
53
55
  "depcheck": "1.4.3",
54
- "eslint": "8.14.0",
55
- "jest": "28.1.0",
56
+ "eslint": "8.22.0",
57
+ "jest": "28.1.3",
56
58
  "jest-when": "3.5.1",
57
- "pkg": "5.6.0",
58
- "ts-jest": "^28.0.1",
59
- "ts-node": "10.7.0",
60
- "typescript": "4.6.4"
59
+ "pkg": "5.8.0",
60
+ "ts-jest": "28.0.7",
61
+ "ts-node": "10.9.1",
62
+ "typescript": "4.7.4"
61
63
  },
62
64
  "engines": {
63
65
  "node": ">=16.10.0"
@@ -83,25 +85,24 @@
83
85
  "plugin:@typescript-eslint/recommended"
84
86
  ],
85
87
  "rules": {
86
- "@typescript-eslint/no-explicit-any": [
87
- "off"
88
- ],
89
- "@typescript-eslint/explicit-module-boundary-types": [
90
- "off"
91
- ],
92
- "@typescript-eslint/semi": [
93
- "error"
94
- ],
95
- "@typescript-eslint/quotes": [
96
- "error"
97
- ],
88
+ "@typescript-eslint/no-explicit-any": "off",
89
+ "@typescript-eslint/explicit-module-boundary-types": "off",
90
+ "@typescript-eslint/semi": "error",
91
+ "@typescript-eslint/quotes": "error",
98
92
  "@typescript-eslint/comma-dangle": [
99
93
  "error",
100
94
  "always-multiline"
101
95
  ],
102
- "@typescript-eslint/member-delimiter-style": [
103
- "error"
104
- ]
96
+ "@typescript-eslint/object-curly-spacing": "error",
97
+ "@typescript-eslint/space-before-function-paren": "error",
98
+ "@typescript-eslint/space-before-blocks": "error",
99
+ "@typescript-eslint/space-infix-ops": "error",
100
+ "@typescript-eslint/member-delimiter-style": "error",
101
+ "@typescript-eslint/indent": [
102
+ "error",
103
+ 4
104
+ ],
105
+ "space-in-parens": "error"
105
106
  }
106
107
  },
107
108
  "jest": {
package/src/argv.js CHANGED
@@ -37,9 +37,12 @@ class Argv {
37
37
  for (const [key, value] of Object.entries(argv)) {
38
38
  this.map.set(key, value);
39
39
  }
40
- const cwd = this.cwd;
41
- if (fs.existsSync(`${cwd}/.gitlab-ci-local-env`)) {
42
- const config = dotenv.parse(fs.readFileSync(`${cwd}/.gitlab-ci-local-env`));
40
+ this.injectDotenv(`${this.home}/.gitlab-ci-local/.env`, argv);
41
+ this.injectDotenv(`${this.cwd}/.gitlab-ci-local-env`, argv);
42
+ }
43
+ injectDotenv(potentialDotenvFilepath, argv) {
44
+ if (fs.existsSync(potentialDotenvFilepath)) {
45
+ const config = dotenv.parse(fs.readFileSync(potentialDotenvFilepath));
43
46
  for (const [key, value] of Object.entries(config)) {
44
47
  const argKey = (0, camelcase_1.default)(key);
45
48
  if (argv[argKey] == null) {
@@ -58,6 +61,9 @@ class Argv {
58
61
  get file() {
59
62
  return this.map.get("file") ?? ".gitlab-ci.yml";
60
63
  }
64
+ get stateDir() {
65
+ return (this.map.get("stateDir") ?? ".gitlab-ci-local").replace(/\/$/, "");
66
+ }
61
67
  get home() {
62
68
  return (this.map.get("home") ?? process.env.HOME ?? "").replace(/\/$/, "");
63
69
  }
@@ -127,6 +133,9 @@ class Argv {
127
133
  get mountCache() {
128
134
  return this.map.get("mountCache") ?? false;
129
135
  }
136
+ get artifactsToSource() {
137
+ return this.map.get("artifactsToSource") ?? true;
138
+ }
130
139
  }
131
140
  exports.Argv = Argv;
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"argv.js","sourceRoot":"","sources":["argv.ts"],"names":[],"mappings":"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","sourcesContent":["import {assert} from \"./asserts\";\nimport * as fs from \"fs-extra\";\nimport * as dotenv from \"dotenv\";\nimport camelCase from \"camelcase\";\n\nexport class Argv {\n\n    private map: Map<string, any> = new Map<string, any>();\n\n    constructor(argv: any) {\n        for (const [key, value] of Object.entries(argv)) {\n            this.map.set(key, value);\n        }\n\n        const cwd = this.cwd;\n        if (fs.existsSync(`${cwd}/.gitlab-ci-local-env`)) {\n            const config = dotenv.parse(fs.readFileSync(`${cwd}/.gitlab-ci-local-env`));\n            for (const [key, value] of Object.entries(config)) {\n                const argKey = camelCase(key);\n                if (argv[argKey] == null) {\n                    this.map.set(argKey, value);\n                }\n            }\n        }\n    }\n\n    get cwd(): string {\n        let cwd = this.map.get(\"cwd\") ?? process.cwd();\n        assert(typeof cwd != \"object\", \"--cwd option cannot be an array\");\n        cwd = cwd.replace(/\\/$/, \"\");\n        assert(fs.pathExistsSync(cwd), `${cwd} is not a directory`);\n        return cwd;\n    }\n\n    get file(): string {\n        return this.map.get(\"file\") ?? \".gitlab-ci.yml\";\n    }\n\n    get home(): string {\n        return (this.map.get(\"home\") ?? process.env.HOME ?? \"\").replace(/\\/$/, \"\");\n    }\n\n    get volume(): string[] {\n        const val = this.map.get(\"volume\") ?? [];\n        return typeof val == \"string\" ? val.split(\" \") : val;\n    }\n\n    get extraHost(): string[] {\n        const val = this.map.get(\"extraHost\") ?? [];\n        return typeof val == \"string\" ? val.split(\" \") : val;\n    }\n\n    get remoteVariables(): string {\n        return this.map.get(\"remoteVariables\");\n    }\n\n    get variable(): { [key: string]: string } {\n        const val = this.map.get(\"variable\");\n        const variables: { [key: string]: string } = {};\n        const pairs = typeof val == \"string\" ? val.split(\" \") : val;\n        (pairs ?? []).forEach((variablePair: string) => {\n            const exec = /(?<key>\\w*?)(=)(?<value>\\w.*)/.exec(variablePair);\n            if (exec?.groups?.key) {\n                variables[exec.groups.key] = exec?.groups?.value;\n            }\n        });\n        return variables;\n    }\n\n    get manual(): string[] {\n        const val = this.map.get(\"manual\") ?? [];\n        return typeof val == \"string\" ? val.split(\" \") : val;\n    }\n\n    get job(): string[] {\n        return this.map.get(\"job\") ?? [];\n    }\n\n    get autoCompleting(): boolean {\n        return this.map.get(\"autoCompleting\") ?? false;\n    }\n\n    get privileged(): boolean {\n        return this.map.get(\"privileged\") ?? false;\n    }\n\n    get needs(): boolean {\n        return this.map.get(\"needs\") ?? false;\n    }\n\n    get onlyNeeds(): boolean {\n        return this.map.get(\"onlyNeeds\") ?? false;\n    }\n\n    get completion(): boolean {\n        return this.map.get(\"completion\") ?? false;\n    }\n\n    get list(): boolean {\n        return this.map.get(\"list\") ?? false;\n    }\n\n    get listAll(): boolean {\n        return this.map.get(\"listAll\") ?? false;\n    }\n\n    get listJson(): boolean {\n        return this.map.get(\"listJson\") ?? false;\n    }\n\n    get preview(): boolean {\n        return this.map.get(\"preview\") ?? false;\n    }\n\n    get shellIsolation(): boolean {\n        return this.map.get(\"shellIsolation\") ?? false;\n    }\n\n    get fetchIncludes(): boolean {\n        return this.map.get(\"fetchIncludes\") ?? false;\n    }\n\n    get mountCache(): boolean {\n        return this.map.get(\"mountCache\") ?? false;\n    }\n}\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"argv.js","sourceRoot":"","sources":["argv.ts"],"names":[],"mappings":"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","sourcesContent":["import {assert} from \"./asserts\";\nimport * as fs from \"fs-extra\";\nimport * as dotenv from \"dotenv\";\nimport camelCase from \"camelcase\";\n\nexport class Argv {\n\n    private map: Map<string, any> = new Map<string, any>();\n\n    constructor (argv: any) {\n        for (const [key, value] of Object.entries(argv)) {\n            this.map.set(key, value);\n        }\n\n        this.injectDotenv(`${this.home}/.gitlab-ci-local/.env`, argv);\n        this.injectDotenv(`${this.cwd}/.gitlab-ci-local-env`, argv);\n    }\n\n    private injectDotenv (potentialDotenvFilepath: string, argv: any) {\n        if (fs.existsSync(potentialDotenvFilepath)) {\n            const config = dotenv.parse(fs.readFileSync(potentialDotenvFilepath));\n            for (const [key, value] of Object.entries(config)) {\n                const argKey = camelCase(key);\n                if (argv[argKey] == null) {\n                    this.map.set(argKey, value);\n                }\n            }\n        }\n    }\n\n    get cwd (): string {\n        let cwd = this.map.get(\"cwd\") ?? process.cwd();\n        assert(typeof cwd != \"object\", \"--cwd option cannot be an array\");\n        cwd = cwd.replace(/\\/$/, \"\");\n        assert(fs.pathExistsSync(cwd), `${cwd} is not a directory`);\n        return cwd;\n    }\n\n    get file (): string {\n        return this.map.get(\"file\") ?? \".gitlab-ci.yml\";\n    }\n\n    get stateDir (): string {\n        return (this.map.get(\"stateDir\") ?? \".gitlab-ci-local\").replace(/\\/$/, \"\");\n    }\n\n    get home (): string {\n        return (this.map.get(\"home\") ?? process.env.HOME ?? \"\").replace(/\\/$/, \"\");\n    }\n\n    get volume (): string[] {\n        const val = this.map.get(\"volume\") ?? [];\n        return typeof val == \"string\" ? val.split(\" \") : val;\n    }\n\n    get extraHost (): string[] {\n        const val = this.map.get(\"extraHost\") ?? [];\n        return typeof val == \"string\" ? val.split(\" \") : val;\n    }\n\n    get remoteVariables (): string {\n        return this.map.get(\"remoteVariables\");\n    }\n\n    get variable (): {[key: string]: string} {\n        const val = this.map.get(\"variable\");\n        const variables: {[key: string]: string} = {};\n        const pairs = typeof val == \"string\" ? val.split(\" \") : val;\n        (pairs ?? []).forEach((variablePair: string) => {\n            const exec = /(?<key>\\w*?)(=)(?<value>\\w.*)/.exec(variablePair);\n            if (exec?.groups?.key) {\n                variables[exec.groups.key] = exec?.groups?.value;\n            }\n        });\n        return variables;\n    }\n\n    get manual (): string[] {\n        const val = this.map.get(\"manual\") ?? [];\n        return typeof val == \"string\" ? val.split(\" \") : val;\n    }\n\n    get job (): string[] {\n        return this.map.get(\"job\") ?? [];\n    }\n\n    get autoCompleting (): boolean {\n        return this.map.get(\"autoCompleting\") ?? false;\n    }\n\n    get privileged (): boolean {\n        return this.map.get(\"privileged\") ?? false;\n    }\n\n    get needs (): boolean {\n        return this.map.get(\"needs\") ?? false;\n    }\n\n    get onlyNeeds (): boolean {\n        return this.map.get(\"onlyNeeds\") ?? false;\n    }\n\n    get completion (): boolean {\n        return this.map.get(\"completion\") ?? false;\n    }\n\n    get list (): boolean {\n        return this.map.get(\"list\") ?? false;\n    }\n\n    get listAll (): boolean {\n        return this.map.get(\"listAll\") ?? false;\n    }\n\n    get listJson (): boolean {\n        return this.map.get(\"listJson\") ?? false;\n    }\n\n    get preview (): boolean {\n        return this.map.get(\"preview\") ?? false;\n    }\n\n    get shellIsolation (): boolean {\n        return this.map.get(\"shellIsolation\") ?? false;\n    }\n\n    get fetchIncludes (): boolean {\n        return this.map.get(\"fetchIncludes\") ?? false;\n    }\n\n    get mountCache (): boolean {\n        return this.map.get(\"mountCache\") ?? false;\n    }\n\n    get artifactsToSource (): boolean {\n        return this.map.get(\"artifactsToSource\") ?? true;\n    }\n}\n"]}
package/src/asserts.js CHANGED
@@ -1,11 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.assert = void 0;
4
- const exit_error_1 = require("./types/exit-error");
4
+ const exit_error_1 = require("./exit-error");
5
5
  function assert(expression, exitMsg) {
6
6
  if (!expression) {
7
7
  throw new exit_error_1.ExitError(exitMsg);
8
8
  }
9
9
  }
10
10
  exports.assert = assert;
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXJ0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFzc2VydHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbURBQTZDO0FBRTdDLFNBQWdCLE1BQU0sQ0FBQyxVQUFtQixFQUFFLE9BQWU7SUFDdkQsSUFBSSxDQUFDLFVBQVUsRUFBRTtRQUNiLE1BQU0sSUFBSSxzQkFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQ2hDO0FBQ0wsQ0FBQztBQUpELHdCQUlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtFeGl0RXJyb3J9IGZyb20gXCIuL3R5cGVzL2V4aXQtZXJyb3JcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydChleHByZXNzaW9uOiBib29sZWFuLCBleGl0TXNnOiBzdHJpbmcpOiBhc3NlcnRzIGV4cHJlc3Npb24ge1xuICAgIGlmICghZXhwcmVzc2lvbikge1xuICAgICAgICB0aHJvdyBuZXcgRXhpdEVycm9yKGV4aXRNc2cpO1xuICAgIH1cbn1cbiJdfQ==
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXJ0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFzc2VydHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkNBQXVDO0FBRXZDLFNBQWdCLE1BQU0sQ0FBRSxVQUFtQixFQUFFLE9BQWU7SUFDeEQsSUFBSSxDQUFDLFVBQVUsRUFBRTtRQUNiLE1BQU0sSUFBSSxzQkFBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQ2hDO0FBQ0wsQ0FBQztBQUpELHdCQUlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtFeGl0RXJyb3J9IGZyb20gXCIuL2V4aXQtZXJyb3JcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydCAoZXhwcmVzc2lvbjogYm9vbGVhbiwgZXhpdE1zZzogc3RyaW5nKTogYXNzZXJ0cyBleHByZXNzaW9uIHtcbiAgICBpZiAoIWV4cHJlc3Npb24pIHtcbiAgICAgICAgdGhyb3cgbmV3IEV4aXRFcnJvcihleGl0TXNnKTtcbiAgICB9XG59XG4iXX0=
@@ -10,7 +10,7 @@ class CacheEntry {
10
10
  }
11
11
  async getUniqueCacheName(cwd, env) {
12
12
  if (typeof this.key === "string" || this.key == null) {
13
- return utils_1.Utils.expandText(this.key ?? "default");
13
+ return utils_1.Utils.expandText(this.key ?? "default", env);
14
14
  }
15
15
  return "md-" + await utils_1.Utils.checksumFiles(this.key.files.map(f => {
16
16
  return `${cwd}/${utils_1.Utils.expandText(f, env)}`;
@@ -18,4 +18,4 @@ class CacheEntry {
18
18
  }
19
19
  }
20
20
  exports.CacheEntry = CacheEntry;
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGUtZW50cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJjYWNoZS1lbnRyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBOEI7QUFFOUIsTUFBYSxVQUFVO0lBS25CLFlBQVksR0FBaUMsRUFBRSxLQUFlLEVBQUUsTUFBcUM7UUFDakcsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFDZixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUN2QixDQUFDO0lBRUQsS0FBSyxDQUFDLGtCQUFrQixDQUFDLEdBQVcsRUFBRSxHQUE4QjtRQUNoRSxJQUFJLE9BQU8sSUFBSSxDQUFDLEdBQUcsS0FBSyxRQUFRLElBQUksSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLEVBQUU7WUFDbEQsT0FBTyxhQUFLLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksU0FBUyxDQUFDLENBQUM7U0FDbEQ7UUFDRCxPQUFPLEtBQUssR0FBRyxNQUFNLGFBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQzVELE9BQU8sR0FBRyxHQUFHLElBQUksYUFBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNoRCxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztDQUVKO0FBcEJELGdDQW9CQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7VXRpbHN9IGZyb20gXCIuL3V0aWxzXCI7XG5cbmV4cG9ydCBjbGFzcyBDYWNoZUVudHJ5IHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgcG9saWN5OiBcInB1bGxcIiB8IFwicHVsbC1wdXNoXCIgfCBcInB1c2hcIjtcbiAgICBwdWJsaWMgcmVhZG9ubHkga2V5OiBzdHJpbmcgfCB7IGZpbGVzOiBzdHJpbmdbXSB9O1xuICAgIHB1YmxpYyByZWFkb25seSBwYXRoczogc3RyaW5nW107XG5cbiAgICBjb25zdHJ1Y3RvcihrZXk6IHN0cmluZyB8IHsgZmlsZXM6IHN0cmluZ1tdIH0sIHBhdGhzOiBzdHJpbmdbXSwgcG9saWN5OiBcInB1bGxcIiB8IFwicHVsbC1wdXNoXCIgfCBcInB1c2hcIikge1xuICAgICAgICB0aGlzLmtleSA9IGtleTtcbiAgICAgICAgdGhpcy5wb2xpY3kgPSBwb2xpY3k7XG4gICAgICAgIHRoaXMucGF0aHMgPSBwYXRocztcbiAgICB9XG5cbiAgICBhc3luYyBnZXRVbmlxdWVDYWNoZU5hbWUoY3dkOiBzdHJpbmcsIGVudjogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSkge1xuICAgICAgICBpZiAodHlwZW9mIHRoaXMua2V5ID09PSBcInN0cmluZ1wiIHx8IHRoaXMua2V5ID09IG51bGwpIHtcbiAgICAgICAgICAgIHJldHVybiBVdGlscy5leHBhbmRUZXh0KHRoaXMua2V5ID8/IFwiZGVmYXVsdFwiKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gXCJtZC1cIiArIGF3YWl0IFV0aWxzLmNoZWNrc3VtRmlsZXModGhpcy5rZXkuZmlsZXMubWFwKGYgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIGAke2N3ZH0vJHtVdGlscy5leHBhbmRUZXh0KGYsIGVudil9YDtcbiAgICAgICAgfSkpO1xuICAgIH1cblxufVxuIl19
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGUtZW50cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJjYWNoZS1lbnRyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBOEI7QUFFOUIsTUFBYSxVQUFVO0lBS25CLFlBQWEsR0FBK0IsRUFBRSxLQUFlLEVBQUUsTUFBcUM7UUFDaEcsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFDZixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUN2QixDQUFDO0lBRUQsS0FBSyxDQUFDLGtCQUFrQixDQUFFLEdBQVcsRUFBRSxHQUE0QjtRQUMvRCxJQUFJLE9BQU8sSUFBSSxDQUFDLEdBQUcsS0FBSyxRQUFRLElBQUksSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLEVBQUU7WUFDbEQsT0FBTyxhQUFLLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksU0FBUyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1NBQ3ZEO1FBQ0QsT0FBTyxLQUFLLEdBQUcsTUFBTSxhQUFLLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUM1RCxPQUFPLEdBQUcsR0FBRyxJQUFJLGFBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDaEQsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNSLENBQUM7Q0FFSjtBQXBCRCxnQ0FvQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1V0aWxzfSBmcm9tIFwiLi91dGlsc1wiO1xuXG5leHBvcnQgY2xhc3MgQ2FjaGVFbnRyeSB7XG4gICAgcHVibGljIHJlYWRvbmx5IHBvbGljeTogXCJwdWxsXCIgfCBcInB1bGwtcHVzaFwiIHwgXCJwdXNoXCI7XG4gICAgcHVibGljIHJlYWRvbmx5IGtleTogc3RyaW5nIHwge2ZpbGVzOiBzdHJpbmdbXX07XG4gICAgcHVibGljIHJlYWRvbmx5IHBhdGhzOiBzdHJpbmdbXTtcblxuICAgIGNvbnN0cnVjdG9yIChrZXk6IHN0cmluZyB8IHtmaWxlczogc3RyaW5nW119LCBwYXRoczogc3RyaW5nW10sIHBvbGljeTogXCJwdWxsXCIgfCBcInB1bGwtcHVzaFwiIHwgXCJwdXNoXCIpIHtcbiAgICAgICAgdGhpcy5rZXkgPSBrZXk7XG4gICAgICAgIHRoaXMucG9saWN5ID0gcG9saWN5O1xuICAgICAgICB0aGlzLnBhdGhzID0gcGF0aHM7XG4gICAgfVxuXG4gICAgYXN5bmMgZ2V0VW5pcXVlQ2FjaGVOYW1lIChjd2Q6IHN0cmluZywgZW52OiB7W2tleTogc3RyaW5nXTogc3RyaW5nfSkge1xuICAgICAgICBpZiAodHlwZW9mIHRoaXMua2V5ID09PSBcInN0cmluZ1wiIHx8IHRoaXMua2V5ID09IG51bGwpIHtcbiAgICAgICAgICAgIHJldHVybiBVdGlscy5leHBhbmRUZXh0KHRoaXMua2V5ID8/IFwiZGVmYXVsdFwiLCBlbnYpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBcIm1kLVwiICsgYXdhaXQgVXRpbHMuY2hlY2tzdW1GaWxlcyh0aGlzLmtleS5maWxlcy5tYXAoZiA9PiB7XG4gICAgICAgICAgICByZXR1cm4gYCR7Y3dkfS8ke1V0aWxzLmV4cGFuZFRleHQoZiwgZW52KX1gO1xuICAgICAgICB9KSk7XG4gICAgfVxuXG59XG4iXX0=