gitlab-ci-local 4.29.0 → 4.30.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 +19 -5
- package/package.json +12 -10
- package/src/argv.js +7 -1
- package/src/handler.js +23 -19
- package/src/index.js +8 -3
- package/src/job.js +88 -48
- package/src/parser.js +2 -2
- package/src/types/job-options.js +1 -1
- package/src/utils.js +12 -51
- package/src/variables-from-files.js +90 -48
package/README.md
CHANGED
|
@@ -30,7 +30,7 @@ Get rid of all those dev specific shell scripts and make files.
|
|
|
30
30
|
* [Bash alias](#bash-alias)
|
|
31
31
|
* [Tab completion](#tab-completion)
|
|
32
32
|
* [Quirks](#quirks)
|
|
33
|
-
* [Tracked Files](#tracked-files)
|
|
33
|
+
* [Tracked Files](#tracked-files)
|
|
34
34
|
* [Home Variables](#home-variables)
|
|
35
35
|
* [Project Variables](#project-variables)
|
|
36
36
|
* [Decorators](#decorators)
|
|
@@ -57,7 +57,6 @@ sudo apt-get update
|
|
|
57
57
|
sudo apt-get install gitlab-ci-local
|
|
58
58
|
```
|
|
59
59
|
|
|
60
|
-
|
|
61
60
|
### Macos
|
|
62
61
|
|
|
63
62
|
```bash
|
|
@@ -110,8 +109,6 @@ Untracked and ignored files will not be synced inside isolated jobs, only tracke
|
|
|
110
109
|
|
|
111
110
|
Remember `git add`
|
|
112
111
|
|
|
113
|
-
|
|
114
|
-
|
|
115
112
|
### Home variables
|
|
116
113
|
|
|
117
114
|
Put a file like this in `$HOME/.gitlab-ci-local/variables.yml`
|
|
@@ -133,10 +130,26 @@ group:
|
|
|
133
130
|
global:
|
|
134
131
|
# Will be type File, because value is a file path
|
|
135
132
|
KNOWN_HOSTS: '~/.ssh/known_hosts'
|
|
133
|
+
DEPLOY_ENV_SPECIFIC:
|
|
134
|
+
type: variable # Optional and defaults to variable
|
|
135
|
+
values:
|
|
136
|
+
'*production*': 'Im production only value'
|
|
137
|
+
'staging': 'Im staging only value'
|
|
138
|
+
FILE_CONTENT_IN_VALLUES:
|
|
139
|
+
type: file
|
|
140
|
+
values:
|
|
141
|
+
'*': |
|
|
142
|
+
Im staging only value
|
|
143
|
+
I'm great for certs n' stuff
|
|
136
144
|
```
|
|
137
145
|
|
|
138
146
|
Variables will now appear in your jobs, if project or group matches git remote, global's are always present
|
|
139
147
|
|
|
148
|
+
### Remote file variables
|
|
149
|
+
```shell
|
|
150
|
+
gitlab-ci-local --remote-variables git@gitlab.com:firecow/example.git=gitlab-variables.yml=master
|
|
151
|
+
```
|
|
152
|
+
|
|
140
153
|
### Project variables
|
|
141
154
|
|
|
142
155
|
Put a file like this in `$CWD/.gitlab-ci-local-variables.yml`
|
|
@@ -203,10 +216,11 @@ Prevent artifacts from being copied to source folder
|
|
|
203
216
|
produce:
|
|
204
217
|
stage: build
|
|
205
218
|
script: mkdir -p path/ && touch path/file1
|
|
206
|
-
artifacts: {paths: [path/] }
|
|
219
|
+
artifacts: { paths: [path/] }
|
|
207
220
|
```
|
|
208
221
|
|
|
209
222
|
### Includes
|
|
223
|
+
|
|
210
224
|
Includes from external sources are only fetched once. Use `--fetch-includes` to invoke an external fetching rutine.
|
|
211
225
|
|
|
212
226
|
### Artifacts
|
package/package.json
CHANGED
|
@@ -3,15 +3,16 @@
|
|
|
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.
|
|
6
|
+
"version": "4.30.1",
|
|
7
7
|
"scripts": {
|
|
8
|
+
"prepublishOnly": "npm run check-all && chmod +x src/index.js",
|
|
8
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",
|
|
9
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",
|
|
10
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",
|
|
11
12
|
"pkg-all": "npm run pkg-linux && npm run pkg-macos && npm run pkg-win",
|
|
12
13
|
"pkg": "pkg",
|
|
13
14
|
"build": "rm -f src/*.js src/*.d.ts && tsc",
|
|
14
|
-
"check-all": "npm run build && npm run lint && npm run coverage
|
|
15
|
+
"check-all": "npm run build && npm run lint && npm run coverage",
|
|
15
16
|
"audit": "npm audit --parseable",
|
|
16
17
|
"lint": "npx eslint .",
|
|
17
18
|
"test": "jest --testTimeout 30000",
|
|
@@ -19,18 +20,19 @@
|
|
|
19
20
|
"start": "ts-node --log-error src/index.ts --cwd examples/docker-compose-nodejs"
|
|
20
21
|
},
|
|
21
22
|
"dependencies": {
|
|
22
|
-
"axios": "^0.26.
|
|
23
|
+
"axios": "^0.26.1",
|
|
23
24
|
"base64url": "^3.0.1",
|
|
24
25
|
"camelcase": "^6.3.0",
|
|
25
26
|
"chalk": "^4.1.2",
|
|
26
27
|
"checksum": "^1.0.0",
|
|
27
28
|
"deep-extend": "^0.6.0",
|
|
28
29
|
"dotenv": "^16.0.0",
|
|
30
|
+
"execa": "^5.1.1",
|
|
29
31
|
"fs-extra": "^10.0.1",
|
|
30
32
|
"js-yaml": "^4.1.0",
|
|
31
33
|
"pretty-hrtime": "^1.0.3",
|
|
32
34
|
"source-map-support": "^0.5.21",
|
|
33
|
-
"yargs": "^17.
|
|
35
|
+
"yargs": "^17.4.0"
|
|
34
36
|
},
|
|
35
37
|
"devDependencies": {
|
|
36
38
|
"@types/checksum": "0.1.33",
|
|
@@ -41,18 +43,18 @@
|
|
|
41
43
|
"@types/js-yaml": "4.0.5",
|
|
42
44
|
"@types/pretty-hrtime": "1.0.1",
|
|
43
45
|
"@types/source-map-support": "0.5.4",
|
|
44
|
-
"@types/yargs": "17.0.
|
|
45
|
-
"@typescript-eslint/eslint-plugin": "5.
|
|
46
|
-
"@typescript-eslint/parser": "5.
|
|
46
|
+
"@types/yargs": "17.0.10",
|
|
47
|
+
"@typescript-eslint/eslint-plugin": "5.17.0",
|
|
48
|
+
"@typescript-eslint/parser": "5.17.0",
|
|
47
49
|
"axios-mock-adapter": "1.20.0",
|
|
48
50
|
"depcheck": "1.4.3",
|
|
49
|
-
"eslint": "8.
|
|
51
|
+
"eslint": "8.12.0",
|
|
50
52
|
"jest": "27.5.1",
|
|
51
53
|
"jest-when": "3.5.1",
|
|
52
54
|
"pkg": "5.5.2",
|
|
53
|
-
"ts-jest": "27.1.
|
|
55
|
+
"ts-jest": "27.1.4",
|
|
54
56
|
"ts-node": "10.7.0",
|
|
55
|
-
"typescript": "4.6.
|
|
57
|
+
"typescript": "4.6.3"
|
|
56
58
|
},
|
|
57
59
|
"engines": {
|
|
58
60
|
"node": ">=16.10.0"
|
package/src/argv.js
CHANGED
|
@@ -69,6 +69,9 @@ class Argv {
|
|
|
69
69
|
const val = this.map.get("extraHost") ?? [];
|
|
70
70
|
return typeof val == "string" ? val.split(" ") : val;
|
|
71
71
|
}
|
|
72
|
+
get remoteVariables() {
|
|
73
|
+
return this.map.get("remoteVariables");
|
|
74
|
+
}
|
|
72
75
|
get variable() {
|
|
73
76
|
const val = this.map.get("variable");
|
|
74
77
|
const variables = {};
|
|
@@ -88,6 +91,9 @@ class Argv {
|
|
|
88
91
|
get job() {
|
|
89
92
|
return this.map.get("job") ?? [];
|
|
90
93
|
}
|
|
94
|
+
get autoCompleting() {
|
|
95
|
+
return this.map.get("autoCompleting") ?? false;
|
|
96
|
+
}
|
|
91
97
|
get privileged() {
|
|
92
98
|
return this.map.get("privileged") ?? false;
|
|
93
99
|
}
|
|
@@ -117,4 +123,4 @@ class Argv {
|
|
|
117
123
|
}
|
|
118
124
|
}
|
|
119
125
|
exports.Argv = Argv;
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
126
|
+
//# 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 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 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"]}
|
package/src/handler.js
CHANGED
|
@@ -40,8 +40,7 @@ const utils_1 = require("./utils");
|
|
|
40
40
|
const exit_error_1 = require("./types/exit-error");
|
|
41
41
|
const argv_1 = require("./argv");
|
|
42
42
|
const asserts_1 = require("./asserts");
|
|
43
|
-
const generateGitIgnore = (cwd
|
|
44
|
-
(0, asserts_1.assert)(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);
|
|
43
|
+
const generateGitIgnore = (cwd) => {
|
|
45
44
|
const gitIgnoreFilePath = `${cwd}/.gitlab-ci-local/.gitignore`;
|
|
46
45
|
const gitIgnoreContent = "*\n!.gitignore\n";
|
|
47
46
|
if (!fs.existsSync(gitIgnoreFilePath)) {
|
|
@@ -50,7 +49,7 @@ const generateGitIgnore = (cwd, file) => {
|
|
|
50
49
|
};
|
|
51
50
|
const cleanupResources = async (parser) => {
|
|
52
51
|
if (!parser) {
|
|
53
|
-
|
|
52
|
+
return;
|
|
54
53
|
}
|
|
55
54
|
const promises = [];
|
|
56
55
|
for (const job of parser.jobs.values()) {
|
|
@@ -62,32 +61,39 @@ async function handler(args, writeStreams) {
|
|
|
62
61
|
const argv = new argv_1.Argv(args);
|
|
63
62
|
const cwd = argv.cwd;
|
|
64
63
|
const file = argv.file;
|
|
64
|
+
let parser = null;
|
|
65
|
+
process.on("exit", () => {
|
|
66
|
+
if (parser)
|
|
67
|
+
cleanupResources(parser).then().catch();
|
|
68
|
+
});
|
|
65
69
|
process.on("unhandledRejection", async (e) => {
|
|
66
70
|
if (e instanceof exit_error_1.ExitError) {
|
|
67
|
-
process.stderr.write((0, chalk_1.default) `{red ${e.message}}\n`);
|
|
71
|
+
process.stderr.write((0, chalk_1.default) `{red ${e.message.trim()}}\n`);
|
|
68
72
|
}
|
|
69
73
|
else if (e instanceof Error) {
|
|
70
|
-
process.stderr.write((0, chalk_1.default) `{red ${e.stack ?? e.message}}\n`);
|
|
74
|
+
process.stderr.write((0, chalk_1.default) `{red ${e.stack?.trim() ?? e.message.trim()}}\n`);
|
|
71
75
|
}
|
|
72
76
|
else if (e) {
|
|
73
|
-
process.stderr.write((0, chalk_1.default) `{red ${e.toString()}}\n`);
|
|
77
|
+
process.stderr.write((0, chalk_1.default) `{red ${e.toString().trim()}}\n`);
|
|
74
78
|
}
|
|
75
|
-
|
|
79
|
+
if (parser)
|
|
80
|
+
await cleanupResources(parser);
|
|
76
81
|
process.exit(1);
|
|
77
82
|
});
|
|
78
83
|
process.on("SIGINT", async (_, code) => {
|
|
79
84
|
await cleanupResources(parser);
|
|
80
85
|
process.exit(code);
|
|
81
86
|
});
|
|
82
|
-
|
|
87
|
+
if (argv.completion) {
|
|
88
|
+
yargs.showCompletionScript();
|
|
89
|
+
return new Map();
|
|
90
|
+
}
|
|
91
|
+
(0, asserts_1.assert)(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);
|
|
83
92
|
if (argv.fetchIncludes) {
|
|
84
93
|
parser = await parser_1.Parser.create(argv, writeStreams, 0);
|
|
85
94
|
return new Map();
|
|
86
95
|
}
|
|
87
|
-
if (argv.
|
|
88
|
-
yargs.showCompletionScript();
|
|
89
|
-
}
|
|
90
|
-
else if (argv.preview) {
|
|
96
|
+
if (argv.preview) {
|
|
91
97
|
const pipelineIid = await state.getPipelineIid(cwd);
|
|
92
98
|
parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
|
|
93
99
|
const gitlabData = parser.gitlabData;
|
|
@@ -107,8 +113,8 @@ async function handler(args, writeStreams) {
|
|
|
107
113
|
commander_1.Commander.runList(parser, writeStreams, argv.listAll);
|
|
108
114
|
}
|
|
109
115
|
else if (argv.job.length > 0) {
|
|
116
|
+
generateGitIgnore(cwd);
|
|
110
117
|
const time = process.hrtime();
|
|
111
|
-
generateGitIgnore(cwd, file);
|
|
112
118
|
if (argv.needs) {
|
|
113
119
|
await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);
|
|
114
120
|
await state.incrementPipelineIid(cwd);
|
|
@@ -122,8 +128,8 @@ async function handler(args, writeStreams) {
|
|
|
122
128
|
}
|
|
123
129
|
}
|
|
124
130
|
else {
|
|
131
|
+
generateGitIgnore(cwd);
|
|
125
132
|
const time = process.hrtime();
|
|
126
|
-
generateGitIgnore(cwd, file);
|
|
127
133
|
await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);
|
|
128
134
|
await state.incrementPipelineIid(cwd);
|
|
129
135
|
const pipelineIid = await state.getPipelineIid(cwd);
|
|
@@ -133,10 +139,8 @@ async function handler(args, writeStreams) {
|
|
|
133
139
|
writeStreams.stdout((0, chalk_1.default) `{grey pipeline finished} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
|
|
134
140
|
}
|
|
135
141
|
writeStreams.flush();
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
}
|
|
139
|
-
return new Map();
|
|
142
|
+
await cleanupResources(parser);
|
|
143
|
+
return parser.jobs;
|
|
140
144
|
}
|
|
141
145
|
exports.handler = handler;
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["handler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as yaml from \"js-yaml\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as yargs from \"yargs\";\nimport {Commander} from \"./commander\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport {Job} from \"./job\";\nimport {Utils} from \"./utils\";\nimport {ExitError} from \"./types/exit-error\";\nimport {Argv} from \"./argv\";\nimport {assert} from \"./asserts\";\n\nconst generateGitIgnore = (cwd: string, file: string) => {\n    assert(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);\n    const gitIgnoreFilePath = `${cwd}/.gitlab-ci-local/.gitignore`;\n    const gitIgnoreContent = \"*\\n!.gitignore\\n\";\n    if (!fs.existsSync(gitIgnoreFilePath)) {\n        fs.outputFileSync(gitIgnoreFilePath, gitIgnoreContent);\n    }\n};\n\nconst cleanupResources = async(parser: Parser|null) => {\n    if (!parser) {\n        process.exit(1);\n    }\n    const promises = [];\n    for (const job of parser.jobs.values()) {\n        promises.push(job.cleanupResources());\n    }\n    await Promise.all(promises);\n};\n\nexport async function handler(args: any, writeStreams: WriteStreams): Promise<ReadonlyMap<string, Job>> {\n    const argv = new Argv(args);\n    const cwd = argv.cwd;\n    const file = argv.file;\n\n    process.on(\"unhandledRejection\", async (e) => {\n        if (e instanceof ExitError) {\n            process.stderr.write(chalk`{red ${e.message}}\\n`);\n        } else if (e instanceof Error) {\n            process.stderr.write(chalk`{red ${e.stack ?? e.message}}\\n`);\n        } else if (e) {\n            process.stderr.write(chalk`{red ${e.toString()}}\\n`);\n        }\n        await cleanupResources(parser);\n        process.exit(1);\n    });\n\n    process.on(\"SIGINT\", async (_: string, code: number) => {\n        await cleanupResources(parser);\n        process.exit(code);\n    });\n\n    let parser: Parser | null = null;\n\n    if (argv.fetchIncludes) {\n        parser = await Parser.create(argv, writeStreams, 0);\n        return new Map<string, Job>();\n    }\n\n    if (argv.completion) {\n        yargs.showCompletionScript();\n    } else if (argv.preview) {\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        const gitlabData = parser.gitlabData;\n        for (const jobName of Object.keys(gitlabData)) {\n            if (jobName === \"stages\") {\n                continue;\n            }\n            if (Job.illegalJobNames.includes(jobName) || jobName.startsWith(\".\")) {\n                delete gitlabData[jobName];\n            }\n        }\n        writeStreams.stdout(`---\\n${yaml.dump(gitlabData, {lineWidth: 160})}`);\n    } else if (argv.list || argv.listAll) {\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        Commander.runList(parser, writeStreams, argv.listAll);\n    } else if (argv.job.length > 0) {\n        const time = process.hrtime();\n        generateGitIgnore(cwd, file);\n        if (argv.needs) {\n            await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n            await state.incrementPipelineIid(cwd);\n        }\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runJobs(argv, parser, writeStreams);\n        if (argv.needs) {\n            writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n    } else {\n        const time = process.hrtime();\n        generateGitIgnore(cwd, file);\n        await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n        await state.incrementPipelineIid(cwd);\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runPipeline(argv, parser, writeStreams);\n        writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    }\n    writeStreams.flush();\n\n    if (parser) {\n        return parser.jobs;\n    }\n\n    return new Map<string, Job>();\n}\n\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["handler.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,8CAAgC;AAChC,kDAA0B;AAC1B,6CAA+B;AAC/B,6CAA+B;AAC/B,2CAAsC;AACtC,qCAAgC;AAChC,+CAAiC;AACjC,kEAAyC;AAEzC,+BAA0B;AAC1B,mCAA8B;AAC9B,mDAA6C;AAC7C,iCAA4B;AAC5B,uCAAiC;AAEjC,MAAM,iBAAiB,GAAG,CAAC,GAAW,EAAE,EAAE;IACtC,MAAM,iBAAiB,GAAG,GAAG,GAAG,8BAA8B,CAAC;IAC/D,MAAM,gBAAgB,GAAG,kBAAkB,CAAC;IAC5C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,iBAAiB,CAAC,EAAE;QACnC,EAAE,CAAC,cAAc,CAAC,iBAAiB,EAAE,gBAAgB,CAAC,CAAC;KAC1D;AACL,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG,KAAK,EAAC,MAAmB,EAAE,EAAE;IAClD,IAAI,CAAC,MAAM,EAAE;QACT,OAAO;KACV;IACD,MAAM,QAAQ,GAAG,EAAE,CAAC;IACpB,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE;QACpC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC,CAAC;KACzC;IACD,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;AAChC,CAAC,CAAC;AAEK,KAAK,UAAU,OAAO,CAAC,IAAS,EAAE,YAA0B;IAC/D,MAAM,IAAI,GAAG,IAAI,WAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;IACrB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;IACvB,IAAI,MAAM,GAAkB,IAAI,CAAC;IAEjC,OAAO,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;QACpB,IAAI,MAAM;YAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,EAAE,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,EAAE,CAAC,oBAAoB,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;QACzC,IAAI,CAAC,YAAY,sBAAS,EAAE;YACxB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAA,eAAK,EAAA,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;SAC5D;aAAM,IAAI,CAAC,YAAY,KAAK,EAAE;YAC3B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAA,eAAK,EAAA,QAAQ,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;SAC/E;aAAM,IAAI,CAAC,EAAE;YACV,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAA,eAAK,EAAA,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;SAC/D;QACD,IAAI,MAAM;YAAE,MAAM,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAS,EAAE,IAAY,EAAE,EAAE;QACnD,MAAM,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC/B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,IAAI,IAAI,CAAC,UAAU,EAAE;QACjB,KAAK,CAAC,oBAAoB,EAAE,CAAC;QAC7B,OAAO,IAAI,GAAG,EAAe,CAAC;KACjC;IAED,IAAA,gBAAM,EAAC,EAAE,CAAC,UAAU,CAAC,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,EAAE,GAAG,GAAG,IAAI,IAAI,qBAAqB,CAAC,CAAC;IAE7E,IAAI,IAAI,CAAC,aAAa,EAAE;QACpB,MAAM,GAAG,MAAM,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;QACpD,OAAO,IAAI,GAAG,EAAe,CAAC;KACjC;IAED,IAAI,IAAI,CAAC,OAAO,EAAE;QACd,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QACpD,MAAM,GAAG,MAAM,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC;QAC9D,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;QACrC,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YAC3C,IAAI,OAAO,KAAK,QAAQ,EAAE;gBACtB,SAAS;aACZ;YACD,IAAI,SAAG,CAAC,eAAe,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;gBAClE,OAAO,UAAU,CAAC,OAAO,CAAC,CAAC;aAC9B;SACJ;QACD,YAAY,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,EAAC,SAAS,EAAE,GAAG,EAAC,CAAC,EAAE,CAAC,CAAC;KAC1E;SAAM,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,EAAE;QAClC,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QACpD,MAAM,GAAG,MAAM,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC;QAC9D,qBAAS,CAAC,OAAO,CAAC,MAAM,EAAE,YAAY,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;KACzD;SAAM,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;QAC5B,iBAAiB,CAAC,GAAG,CAAC,CAAC;QACvB,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,MAAM,EAAE,CAAC,MAAM,CAAC,GAAG,GAAG,6BAA6B,CAAC,CAAC;YACrD,MAAM,KAAK,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC;SACzC;QACD,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QACpD,MAAM,GAAG,MAAM,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC;QAC9D,MAAM,aAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAC9C,MAAM,qBAAS,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QACpD,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,qCAAqC,IAAA,uBAAY,EAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC;SAC1G;KACJ;SAAM;QACH,iBAAiB,CAAC,GAAG,CAAC,CAAC;QACvB,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QAC9B,MAAM,EAAE,CAAC,MAAM,CAAC,GAAG,GAAG,6BAA6B,CAAC,CAAC;QACrD,MAAM,KAAK,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC;QACtC,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QACpD,MAAM,GAAG,MAAM,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC;QAC9D,MAAM,aAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAC9C,MAAM,qBAAS,CAAC,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QACxD,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,qCAAqC,IAAA,uBAAY,EAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC;KAC1G;IACD,YAAY,CAAC,KAAK,EAAE,CAAC;IAErB,MAAM,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAC/B,OAAO,MAAM,CAAC,IAAI,CAAC;AACvB,CAAC;AArFD,0BAqFC","sourcesContent":["import * as yaml from \"js-yaml\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as yargs from \"yargs\";\nimport {Commander} from \"./commander\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport {Job} from \"./job\";\nimport {Utils} from \"./utils\";\nimport {ExitError} from \"./types/exit-error\";\nimport {Argv} from \"./argv\";\nimport {assert} from \"./asserts\";\n\nconst generateGitIgnore = (cwd: string) => {\n    const gitIgnoreFilePath = `${cwd}/.gitlab-ci-local/.gitignore`;\n    const gitIgnoreContent = \"*\\n!.gitignore\\n\";\n    if (!fs.existsSync(gitIgnoreFilePath)) {\n        fs.outputFileSync(gitIgnoreFilePath, gitIgnoreContent);\n    }\n};\n\nconst cleanupResources = async(parser: Parser|null) => {\n    if (!parser) {\n        return;\n    }\n    const promises = [];\n    for (const job of parser.jobs.values()) {\n        promises.push(job.cleanupResources());\n    }\n    await Promise.all(promises);\n};\n\nexport async function handler(args: any, writeStreams: WriteStreams): Promise<ReadonlyMap<string, Job>> {\n    const argv = new Argv(args);\n    const cwd = argv.cwd;\n    const file = argv.file;\n    let parser: Parser | null = null;\n\n    process.on(\"exit\", () => {\n        if (parser) cleanupResources(parser).then().catch();\n    });\n\n    process.on(\"unhandledRejection\", async (e) => {\n        if (e instanceof ExitError) {\n            process.stderr.write(chalk`{red ${e.message.trim()}}\\n`);\n        } else if (e instanceof Error) {\n            process.stderr.write(chalk`{red ${e.stack?.trim() ?? e.message.trim()}}\\n`);\n        } else if (e) {\n            process.stderr.write(chalk`{red ${e.toString().trim()}}\\n`);\n        }\n        if (parser) await cleanupResources(parser);\n        process.exit(1);\n    });\n\n    process.on(\"SIGINT\", async (_: string, code: number) => {\n        await cleanupResources(parser);\n        process.exit(code);\n    });\n\n    if (argv.completion) {\n        yargs.showCompletionScript();\n        return new Map<string, Job>();\n    }\n\n    assert(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);\n\n    if (argv.fetchIncludes) {\n        parser = await Parser.create(argv, writeStreams, 0);\n        return new Map<string, Job>();\n    }\n\n    if (argv.preview) {\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        const gitlabData = parser.gitlabData;\n        for (const jobName of Object.keys(gitlabData)) {\n            if (jobName === \"stages\") {\n                continue;\n            }\n            if (Job.illegalJobNames.includes(jobName) || jobName.startsWith(\".\")) {\n                delete gitlabData[jobName];\n            }\n        }\n        writeStreams.stdout(`---\\n${yaml.dump(gitlabData, {lineWidth: 160})}`);\n    } else if (argv.list || argv.listAll) {\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        Commander.runList(parser, writeStreams, argv.listAll);\n    } else if (argv.job.length > 0) {\n        generateGitIgnore(cwd);\n        const time = process.hrtime();\n        if (argv.needs) {\n            await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n            await state.incrementPipelineIid(cwd);\n        }\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runJobs(argv, parser, writeStreams);\n        if (argv.needs) {\n            writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n    } else {\n        generateGitIgnore(cwd);\n        const time = process.hrtime();\n        await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n        await state.incrementPipelineIid(cwd);\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runPipeline(argv, parser, writeStreams);\n        writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    }\n    writeStreams.flush();\n\n    await cleanupResources(parser);\n    return parser.jobs;\n}\n\n"]}
|
package/src/index.js
CHANGED
|
@@ -43,8 +43,8 @@ const argv_1 = require("./argv");
|
|
|
43
43
|
(() => {
|
|
44
44
|
const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, "../package.json"), "utf8"));
|
|
45
45
|
(0, yargs_1.default)(process.argv.slice(2))
|
|
46
|
-
.version(packageJson["version"])
|
|
47
46
|
.showHelpOnFail(false)
|
|
47
|
+
.version(packageJson["version"])
|
|
48
48
|
.wrap(yargs_1.default.terminalWidth())
|
|
49
49
|
.command({
|
|
50
50
|
handler: async (argv) => {
|
|
@@ -112,6 +112,11 @@ const argv_1 = require("./argv");
|
|
|
112
112
|
type: "array",
|
|
113
113
|
description: "Add variable to all executed jobs (--variable HELLO=world)",
|
|
114
114
|
requiresArg: false,
|
|
115
|
+
})
|
|
116
|
+
.option("remote-variables", {
|
|
117
|
+
type: "string",
|
|
118
|
+
description: "Fetch variables file from remote location",
|
|
119
|
+
requiresArg: false,
|
|
115
120
|
})
|
|
116
121
|
.option("file", {
|
|
117
122
|
type: "string",
|
|
@@ -155,7 +160,7 @@ const argv_1 = require("./argv");
|
|
|
155
160
|
})
|
|
156
161
|
.completion("completion", false, async (_, yargsArgv) => {
|
|
157
162
|
try {
|
|
158
|
-
const argv = new argv_1.Argv(yargsArgv);
|
|
163
|
+
const argv = new argv_1.Argv({ ...yargsArgv, autoCompleting: true });
|
|
159
164
|
const pipelineIid = await state.getPipelineIid(argv.cwd);
|
|
160
165
|
const parser = await parser_1.Parser.create(argv, new mock_write_streams_1.MockWriteStreams(), pipelineIid);
|
|
161
166
|
return [...parser.jobs.values()].filter((j) => j.when != "never").map((j) => j.name);
|
|
@@ -166,4 +171,4 @@ const argv_1 = require("./argv");
|
|
|
166
171
|
})
|
|
167
172
|
.parse();
|
|
168
173
|
})();
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport \"source-map-support/register\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as path from \"path\";\nimport yargs from \"yargs\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport {ExitError} from \"./types/exit-error\";\nimport {ProcessWriteStreams} from \"./process-write-streams\";\nimport {handler} from \"./handler\";\nimport {JobExecutor} from \"./job-executor\";\nimport {MockWriteStreams} from \"./mock-write-streams\";\nimport {Argv} from \"./argv\";\n\n(() => {\n    const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, \"../package.json\"), \"utf8\"));\n    yargs(process.argv.slice(2))\n        .version(packageJson[\"version\"])\n        .showHelpOnFail(false)\n        .wrap(yargs.terminalWidth())\n        .command({\n            handler: async (argv) => {\n                try {\n                    const jobs = await handler(argv, new ProcessWriteStreams());\n                    const failedJobs = JobExecutor.getFailed(jobs);\n                    process.exit(failedJobs.length > 0 ? 1 : 0);\n                } catch (e) {\n                    if (e instanceof ExitError) {\n                        process.stderr.write(chalk`{red ${e.message}}\\n`);\n                        process.exit(1);\n                    }\n                    throw e;\n                }\n            },\n            builder: (y: any) => {\n                return y.positional(\"job\", {\n                    describe: \"Jobname's to execute\",\n                    type: \"array\",\n                });\n            },\n            command: \"$0 [job..]\",\n            describe: \"Runs the entire pipeline or job's\",\n        })\n        .usage(\"Find more information at https://github.com/firecow/gitlab-ci-local\")\n        .strictOptions()\n        .env(\"GCL\")\n        .option(\"manual\", {\n            type: \"array\",\n            description: \"One or more manual jobs to run during a pipeline\",\n            requiresArg: true,\n        })\n        .option(\"list\", {\n            type: \"boolean\",\n            description: \"List jobs and job information, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-all\", {\n            type: \"boolean\",\n            description: \"List jobs and job information, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"preview\", {\n            type: \"boolean\",\n            description: \"Print YML with defaults, includes, extends and reference's expanded\",\n            requiresArg: false,\n        })\n        .option(\"cwd\", {\n            type: \"string\",\n            description: \"Path to a current working directory\",\n            requiresArg: true,\n        })\n        .option(\"completion\", {\n            type: \"string\",\n            description: \"Generate tab completion script\",\n            requiresArg: false,\n        })\n        .option(\"needs\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, when executing a single job\",\n            requiresArg: false,\n        })\n        .option(\"variable\", {\n            type: \"array\",\n            description: \"Add variable to all executed jobs (--variable HELLO=world)\",\n            requiresArg: false,\n        })\n        .option(\"file\", {\n            type: \"string\",\n            description: \"Specify custom location of the .gitlab-ci.yml. Relative to cwd, eg. (gitlab/.gitlab-ci.yml)\",\n            requiresArg: false,\n        })\n        .option(\"home\", {\n            type: \"string\",\n            description: \"Specify custom HOME location ($HOME/.gitlab-ci-local/variables.yml)\",\n            requiresArg: false,\n        })\n        .option(\"shell-isolation\", {\n            type: \"boolean\",\n            description: \"Enable artifact isolation for shell-executor jobs\",\n            requiresArg: false,\n        })\n        .option(\"mount-cache\", {\n            type: \"boolean\",\n            description: \"Enable docker mount based caching\",\n            requiresArg: false,\n        })\n        .option(\"privileged\", {\n            type: \"boolean\",\n            description: \"Set docker executor to privileged mode\",\n            requiresArg: false,\n        })\n        .option(\"volume\", {\n            type: \"array\",\n            description: \"Add volumes to docker executor\",\n            requiresArg: false,\n        })\n        .option(\"extra-host\", {\n            type: \"array\",\n            description: \"Add extra docker host entries\",\n            requiresArg: false,\n        })\n        .option(\"fetch-includes\", {\n            type: \"boolean\",\n            description: \"Fetch all external includes one more time\",\n            requiresArg: false,\n        })\n        .completion(\"completion\", false, async (_, yargsArgv) => {\n            try {\n                const argv = new Argv(yargsArgv);\n                const pipelineIid = await state.getPipelineIid(argv.cwd);\n                const parser = await Parser.create(argv, new MockWriteStreams(), pipelineIid);\n                return [...parser.jobs.values()].filter((j) => j.when != \"never\").map((j) => j.name);\n            } catch (e) {\n                return [\"Parser-Failed!\"];\n            }\n\n        })\n        .parse();\n})();\n\n"]}
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport \"source-map-support/register\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as path from \"path\";\nimport yargs from \"yargs\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport {ExitError} from \"./types/exit-error\";\nimport {ProcessWriteStreams} from \"./process-write-streams\";\nimport {handler} from \"./handler\";\nimport {JobExecutor} from \"./job-executor\";\nimport {MockWriteStreams} from \"./mock-write-streams\";\nimport {Argv} from \"./argv\";\n\n(() => {\n    const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, \"../package.json\"), \"utf8\"));\n    yargs(process.argv.slice(2))\n        .showHelpOnFail(false)\n        .version(packageJson[\"version\"])\n        .wrap(yargs.terminalWidth())\n        .command({\n            handler: async (argv) => {\n                try {\n                    const jobs = await handler(argv, new ProcessWriteStreams());\n                    const failedJobs = JobExecutor.getFailed(jobs);\n                    process.exit(failedJobs.length > 0 ? 1 : 0);\n                } catch (e) {\n                    if (e instanceof ExitError) {\n                        process.stderr.write(chalk`{red ${e.message}}\\n`);\n                        process.exit(1);\n                    }\n                    throw e;\n                }\n            },\n            builder: (y: any) => {\n                return y.positional(\"job\", {\n                    describe: \"Jobname's to execute\",\n                    type: \"array\",\n                });\n            },\n            command: \"$0 [job..]\",\n            describe: \"Runs the entire pipeline or job's\",\n        })\n        .usage(\"Find more information at https://github.com/firecow/gitlab-ci-local\")\n        .strictOptions()\n        .env(\"GCL\")\n        .option(\"manual\", {\n            type: \"array\",\n            description: \"One or more manual jobs to run during a pipeline\",\n            requiresArg: true,\n        })\n        .option(\"list\", {\n            type: \"boolean\",\n            description: \"List jobs and job information, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-all\", {\n            type: \"boolean\",\n            description: \"List jobs and job information, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"preview\", {\n            type: \"boolean\",\n            description: \"Print YML with defaults, includes, extends and reference's expanded\",\n            requiresArg: false,\n        })\n        .option(\"cwd\", {\n            type: \"string\",\n            description: \"Path to a current working directory\",\n            requiresArg: true,\n        })\n        .option(\"completion\", {\n            type: \"string\",\n            description: \"Generate tab completion script\",\n            requiresArg: false,\n        })\n        .option(\"needs\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, when executing a single job\",\n            requiresArg: false,\n        })\n        .option(\"variable\", {\n            type: \"array\",\n            description: \"Add variable to all executed jobs (--variable HELLO=world)\",\n            requiresArg: false,\n        })\n        .option(\"remote-variables\", {\n            type: \"string\",\n            description: \"Fetch variables file from remote location\",\n            requiresArg: false,\n        })\n        .option(\"file\", {\n            type: \"string\",\n            description: \"Specify custom location of the .gitlab-ci.yml. Relative to cwd, eg. (gitlab/.gitlab-ci.yml)\",\n            requiresArg: false,\n        })\n        .option(\"home\", {\n            type: \"string\",\n            description: \"Specify custom HOME location ($HOME/.gitlab-ci-local/variables.yml)\",\n            requiresArg: false,\n        })\n        .option(\"shell-isolation\", {\n            type: \"boolean\",\n            description: \"Enable artifact isolation for shell-executor jobs\",\n            requiresArg: false,\n        })\n        .option(\"mount-cache\", {\n            type: \"boolean\",\n            description: \"Enable docker mount based caching\",\n            requiresArg: false,\n        })\n        .option(\"privileged\", {\n            type: \"boolean\",\n            description: \"Set docker executor to privileged mode\",\n            requiresArg: false,\n        })\n        .option(\"volume\", {\n            type: \"array\",\n            description: \"Add volumes to docker executor\",\n            requiresArg: false,\n        })\n        .option(\"extra-host\", {\n            type: \"array\",\n            description: \"Add extra docker host entries\",\n            requiresArg: false,\n        })\n        .option(\"fetch-includes\", {\n            type: \"boolean\",\n            description: \"Fetch all external includes one more time\",\n            requiresArg: false,\n        })\n        .completion(\"completion\", false, async (_, yargsArgv) => {\n            try {\n                const argv = new Argv({...yargsArgv, autoCompleting: true});\n                const pipelineIid = await state.getPipelineIid(argv.cwd);\n                const parser = await Parser.create(argv, new MockWriteStreams(), pipelineIid);\n                return [...parser.jobs.values()].filter((j) => j.when != \"never\").map((j) => j.name);\n            } catch (e) {\n                return [\"Parser-Failed!\"];\n            }\n\n        })\n        .parse();\n})();\n\n"]}
|