gitlab-ci-local 4.28.2 → 4.29.0
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/package.json +15 -16
- package/src/argv.js +120 -0
- package/src/commander.js +12 -10
- package/src/git-data.js +42 -36
- package/src/handler.js +31 -64
- package/src/index.js +13 -14
- package/src/job-executor.js +4 -4
- package/src/job.js +109 -86
- package/src/parser-includes.js +7 -3
- package/src/parser.js +24 -30
- package/src/state.js +6 -2
- package/src/types/job-options.js +1 -1
- package/src/utils.js +36 -7
- package/src/variables-from-files.js +9 -5
- package/src/types/parser-options.js +0 -3
package/package.json
CHANGED
|
@@ -3,16 +3,15 @@
|
|
|
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.29.0",
|
|
7
7
|
"scripts": {
|
|
8
|
-
"prepublishOnly": "npm run check-all && chmod +x src/index.js",
|
|
9
8
|
"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
9
|
"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
10
|
"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",
|
|
12
11
|
"pkg-all": "npm run pkg-linux && npm run pkg-macos && npm run pkg-win",
|
|
13
12
|
"pkg": "pkg",
|
|
14
13
|
"build": "rm -f src/*.js src/*.d.ts && tsc",
|
|
15
|
-
"check-all": "npm run build && npm run lint && npm run coverage",
|
|
14
|
+
"check-all": "npm run build && npm run lint && npm run coverage && npm run audit",
|
|
16
15
|
"audit": "npm audit --parseable",
|
|
17
16
|
"lint": "npx eslint .",
|
|
18
17
|
"test": "jest --testTimeout 30000",
|
|
@@ -20,14 +19,14 @@
|
|
|
20
19
|
"start": "ts-node --log-error src/index.ts --cwd examples/docker-compose-nodejs"
|
|
21
20
|
},
|
|
22
21
|
"dependencies": {
|
|
23
|
-
"axios": "^0.
|
|
22
|
+
"axios": "^0.26.0",
|
|
24
23
|
"base64url": "^3.0.1",
|
|
25
24
|
"camelcase": "^6.3.0",
|
|
26
25
|
"chalk": "^4.1.2",
|
|
27
26
|
"checksum": "^1.0.0",
|
|
28
27
|
"deep-extend": "^0.6.0",
|
|
29
|
-
"dotenv": "^
|
|
30
|
-
"fs-extra": "^10.0.
|
|
28
|
+
"dotenv": "^16.0.0",
|
|
29
|
+
"fs-extra": "^10.0.1",
|
|
31
30
|
"js-yaml": "^4.1.0",
|
|
32
31
|
"pretty-hrtime": "^1.0.3",
|
|
33
32
|
"source-map-support": "^0.5.21",
|
|
@@ -37,23 +36,23 @@
|
|
|
37
36
|
"@types/checksum": "0.1.33",
|
|
38
37
|
"@types/deep-extend": "0.4.32",
|
|
39
38
|
"@types/fs-extra": "9.0.13",
|
|
40
|
-
"@types/jest": "27.4.
|
|
41
|
-
"@types/jest-when": "
|
|
39
|
+
"@types/jest": "27.4.1",
|
|
40
|
+
"@types/jest-when": "3.5.0",
|
|
42
41
|
"@types/js-yaml": "4.0.5",
|
|
43
42
|
"@types/pretty-hrtime": "1.0.1",
|
|
44
43
|
"@types/source-map-support": "0.5.4",
|
|
45
|
-
"@types/yargs": "17.0.
|
|
46
|
-
"@typescript-eslint/eslint-plugin": "5.
|
|
47
|
-
"@typescript-eslint/parser": "5.
|
|
44
|
+
"@types/yargs": "17.0.9",
|
|
45
|
+
"@typescript-eslint/eslint-plugin": "5.14.0",
|
|
46
|
+
"@typescript-eslint/parser": "5.14.0",
|
|
48
47
|
"axios-mock-adapter": "1.20.0",
|
|
49
48
|
"depcheck": "1.4.3",
|
|
50
|
-
"eslint": "8.
|
|
51
|
-
"jest": "27.
|
|
52
|
-
"jest-when": "3.5.
|
|
49
|
+
"eslint": "8.10.0",
|
|
50
|
+
"jest": "27.5.1",
|
|
51
|
+
"jest-when": "3.5.1",
|
|
53
52
|
"pkg": "5.5.2",
|
|
54
53
|
"ts-jest": "27.1.3",
|
|
55
|
-
"ts-node": "10.
|
|
56
|
-
"typescript": "4.
|
|
54
|
+
"ts-node": "10.7.0",
|
|
55
|
+
"typescript": "4.6.2"
|
|
57
56
|
},
|
|
58
57
|
"engines": {
|
|
59
58
|
"node": ">=16.10.0"
|
package/src/argv.js
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.Argv = void 0;
|
|
30
|
+
const asserts_1 = require("./asserts");
|
|
31
|
+
const fs = __importStar(require("fs-extra"));
|
|
32
|
+
const dotenv = __importStar(require("dotenv"));
|
|
33
|
+
const camelcase_1 = __importDefault(require("camelcase"));
|
|
34
|
+
class Argv {
|
|
35
|
+
constructor(argv) {
|
|
36
|
+
this.map = new Map();
|
|
37
|
+
for (const [key, value] of Object.entries(argv)) {
|
|
38
|
+
this.map.set(key, value);
|
|
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`));
|
|
43
|
+
for (const [key, value] of Object.entries(config)) {
|
|
44
|
+
const argKey = (0, camelcase_1.default)(key);
|
|
45
|
+
if (argv[argKey] == null) {
|
|
46
|
+
this.map.set(argKey, value);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
get cwd() {
|
|
52
|
+
let cwd = this.map.get("cwd") ?? process.cwd();
|
|
53
|
+
(0, asserts_1.assert)(typeof cwd != "object", "--cwd option cannot be an array");
|
|
54
|
+
cwd = cwd.replace(/\/$/, "");
|
|
55
|
+
(0, asserts_1.assert)(fs.pathExistsSync(cwd), `${cwd} is not a directory`);
|
|
56
|
+
return cwd;
|
|
57
|
+
}
|
|
58
|
+
get file() {
|
|
59
|
+
return this.map.get("file") ?? ".gitlab-ci.yml";
|
|
60
|
+
}
|
|
61
|
+
get home() {
|
|
62
|
+
return (this.map.get("home") ?? process.env.HOME ?? "").replace(/\/$/, "");
|
|
63
|
+
}
|
|
64
|
+
get volume() {
|
|
65
|
+
const val = this.map.get("volume") ?? [];
|
|
66
|
+
return typeof val == "string" ? val.split(" ") : val;
|
|
67
|
+
}
|
|
68
|
+
get extraHost() {
|
|
69
|
+
const val = this.map.get("extraHost") ?? [];
|
|
70
|
+
return typeof val == "string" ? val.split(" ") : val;
|
|
71
|
+
}
|
|
72
|
+
get variable() {
|
|
73
|
+
const val = this.map.get("variable");
|
|
74
|
+
const variables = {};
|
|
75
|
+
const pairs = typeof val == "string" ? val.split(" ") : val;
|
|
76
|
+
(pairs ?? []).forEach((variablePair) => {
|
|
77
|
+
const exec = /(?<key>\w*?)(=)(?<value>\w.*)/.exec(variablePair);
|
|
78
|
+
if (exec?.groups?.key) {
|
|
79
|
+
variables[exec.groups.key] = exec?.groups?.value;
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
return variables;
|
|
83
|
+
}
|
|
84
|
+
get manual() {
|
|
85
|
+
const val = this.map.get("manual") ?? [];
|
|
86
|
+
return typeof val == "string" ? val.split(" ") : val;
|
|
87
|
+
}
|
|
88
|
+
get job() {
|
|
89
|
+
return this.map.get("job") ?? [];
|
|
90
|
+
}
|
|
91
|
+
get privileged() {
|
|
92
|
+
return this.map.get("privileged") ?? false;
|
|
93
|
+
}
|
|
94
|
+
get needs() {
|
|
95
|
+
return this.map.get("needs") ?? false;
|
|
96
|
+
}
|
|
97
|
+
get completion() {
|
|
98
|
+
return this.map.get("completion") ?? false;
|
|
99
|
+
}
|
|
100
|
+
get list() {
|
|
101
|
+
return this.map.get("list") ?? false;
|
|
102
|
+
}
|
|
103
|
+
get listAll() {
|
|
104
|
+
return this.map.get("listAll") ?? false;
|
|
105
|
+
}
|
|
106
|
+
get preview() {
|
|
107
|
+
return this.map.get("preview") ?? false;
|
|
108
|
+
}
|
|
109
|
+
get shellIsolation() {
|
|
110
|
+
return this.map.get("shellIsolation") ?? false;
|
|
111
|
+
}
|
|
112
|
+
get fetchIncludes() {
|
|
113
|
+
return this.map.get("fetchIncludes") ?? false;
|
|
114
|
+
}
|
|
115
|
+
get mountCache() {
|
|
116
|
+
return this.map.get("mountCache") ?? false;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
exports.Argv = Argv;
|
|
120
|
+
//# 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 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 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/commander.js
CHANGED
|
@@ -10,16 +10,18 @@ const utils_1 = require("./utils");
|
|
|
10
10
|
const job_executor_1 = require("./job-executor");
|
|
11
11
|
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
12
12
|
class Commander {
|
|
13
|
-
static async runPipeline(parser, writeStreams
|
|
13
|
+
static async runPipeline(argv, parser, writeStreams) {
|
|
14
14
|
const jobs = parser.jobs;
|
|
15
15
|
const stages = parser.stages;
|
|
16
16
|
let potentialStarters = [...jobs.values()];
|
|
17
17
|
potentialStarters = potentialStarters.filter(j => j.when !== "never");
|
|
18
|
-
potentialStarters = potentialStarters.filter(j => j.when !== "manual" ||
|
|
19
|
-
await job_executor_1.JobExecutor.runLoop(jobs, stages, potentialStarters
|
|
20
|
-
await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad
|
|
18
|
+
potentialStarters = potentialStarters.filter(j => j.when !== "manual" || argv.manual.includes(j.name));
|
|
19
|
+
await job_executor_1.JobExecutor.runLoop(argv, jobs, stages, potentialStarters);
|
|
20
|
+
await Commander.printReport(argv.cwd, writeStreams, jobs, stages, parser.jobNamePad);
|
|
21
21
|
}
|
|
22
|
-
static async
|
|
22
|
+
static async runJobs(argv, parser, writeStreams) {
|
|
23
|
+
const needs = argv.needs;
|
|
24
|
+
const jobArgs = argv.job;
|
|
23
25
|
const jobs = parser.jobs;
|
|
24
26
|
const stages = parser.stages;
|
|
25
27
|
let potentialStarters = [];
|
|
@@ -28,12 +30,12 @@ class Commander {
|
|
|
28
30
|
const job = utils_1.Utils.getJobByName(jobs, jobName);
|
|
29
31
|
jobPoolMap.set(jobName, job);
|
|
30
32
|
if (needs) {
|
|
31
|
-
potentialStarters = potentialStarters.concat(job_executor_1.JobExecutor.getPastToWaitFor(jobs, stages, job,
|
|
33
|
+
potentialStarters = potentialStarters.concat(job_executor_1.JobExecutor.getPastToWaitFor(jobs, stages, job, argv.manual));
|
|
32
34
|
}
|
|
33
35
|
potentialStarters.push(job);
|
|
34
36
|
});
|
|
35
|
-
await job_executor_1.JobExecutor.runLoop(jobPoolMap, stages, potentialStarters
|
|
36
|
-
await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad
|
|
37
|
+
await job_executor_1.JobExecutor.runLoop(argv, jobPoolMap, stages, potentialStarters);
|
|
38
|
+
await Commander.printReport(argv.cwd, writeStreams, jobs, stages, parser.jobNamePad);
|
|
37
39
|
}
|
|
38
40
|
static runList(parser, writeStreams, listAll) {
|
|
39
41
|
const stages = parser.stages;
|
|
@@ -69,7 +71,7 @@ class Commander {
|
|
|
69
71
|
}
|
|
70
72
|
exports.Commander = Commander;
|
|
71
73
|
_a = Commander;
|
|
72
|
-
Commander.printReport = async (writeStreams, jobs, stages, jobNamePad
|
|
74
|
+
Commander.printReport = async (cwd, writeStreams, jobs, stages, jobNamePad) => {
|
|
73
75
|
writeStreams.stdout("\n");
|
|
74
76
|
const preScripts = {
|
|
75
77
|
successful: [],
|
|
@@ -154,4 +156,4 @@ Commander.printReport = async (writeStreams, jobs, stages, jobNamePad, cwd) => {
|
|
|
154
156
|
writeStreams.stdout(" }\n");
|
|
155
157
|
}
|
|
156
158
|
};
|
|
157
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commander.js","sourceRoot":"","sources":["commander.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from \"chalk\";\nimport {Job} from \"./job\";\nimport {Parser} from \"./parser\";\nimport {Utils} from \"./utils\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport {JobExecutor} from \"./job-executor\";\nimport fs from \"fs-extra\";\n\nexport class Commander {\n\n    static async runPipeline(parser: Parser, writeStreams: WriteStreams, manualOpts: string[], privileged: boolean, cwd: string) {\n        const jobs = parser.jobs;\n        const stages = parser.stages;\n\n        let potentialStarters = [...jobs.values()];\n        potentialStarters = potentialStarters.filter(j => j.when !== \"never\");\n        potentialStarters = potentialStarters.filter(j => j.when !== \"manual\" || manualOpts.includes(j.name));\n        await JobExecutor.runLoop(jobs, stages, potentialStarters, manualOpts, privileged);\n        await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad, cwd);\n    }\n\n    static async runSingleJob(parser: Parser, writeStreams: WriteStreams, jobArgs: string[], needs: boolean, manualOpts: string[], privileged: boolean, cwd: string) {\n        const jobs = parser.jobs;\n        const stages = parser.stages;\n\n        let potentialStarters: Job[] = [];\n        const jobPoolMap = needs ? new Map<string, Job>(jobs) : new Map<string, Job>();\n        jobArgs.forEach(jobName => {\n            const job = Utils.getJobByName(jobs, jobName);\n            jobPoolMap.set(jobName, job);\n            if (needs) {\n                potentialStarters = potentialStarters.concat(JobExecutor.getPastToWaitFor(jobs, stages, job, manualOpts));\n            }\n            potentialStarters.push(job);\n        });\n\n        await JobExecutor.runLoop(jobPoolMap, stages, potentialStarters, manualOpts, privileged);\n        await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad, cwd);\n    }\n\n    static printReport = async (writeStreams: WriteStreams, jobs: ReadonlyMap<string, Job>, stages: readonly string[], jobNamePad: number, cwd: string) => {\n        writeStreams.stdout(\"\\n\");\n\n        const preScripts: { successful: Job[]; failed: Job[]; warned: Job[] } = {\n            successful: [],\n            failed: [],\n            warned: [],\n        };\n        const afterScripts: { warned: Job[] } = {\n            warned: [],\n        };\n\n        for (const job of jobs.values()) {\n            if (job.started && job.afterScriptsExitCode !== 0) {\n                afterScripts.warned.push(job);\n            }\n        }\n\n        for (const job of jobs.values()) {\n            if (!job.started) {\n                continue;\n            }\n\n            if (job.preScriptsExitCode === 0) {\n                preScripts.successful.push(job);\n            } else if (job.allowFailure) {\n                preScripts.warned.push(job);\n            } else {\n                preScripts.failed.push(job);\n            }\n        }\n\n        if (preScripts.successful.length !== 0) {\n            preScripts.successful.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            preScripts.successful.forEach((job) => {\n                const namePad = job.name.padEnd(jobNamePad);\n                writeStreams.stdout(chalk`{black.bgGreenBright  PASS } {blueBright ${namePad}}`);\n                if (job.coveragePercent) {\n                    writeStreams.stdout(chalk` ${job.coveragePercent}% {grey coverage}`);\n                }\n                writeStreams.stdout(\"\\n\");\n            });\n        }\n\n        if (preScripts.warned.length !== 0) {\n            preScripts.warned.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            for (const {name} of preScripts.warned) {\n                const namePad = name.padEnd(jobNamePad);\n                const safeName = Utils.getSafeJobName(name);\n                writeStreams.stdout(chalk`{black.bgYellowBright  WARN } {blueBright ${namePad}}  pre_script\\n`);\n                const outputLog = await fs.readFile(`${cwd}/.gitlab-ci-local/output/${safeName}.log`, \"utf8\");\n                for (const line of outputLog.split(/\\r?\\n/).filter(j => !j.includes(\"[32m$ \")).filter(j => j !== \"\").slice(-3)) {\n                    writeStreams.stdout(chalk`  {yellow >} ${line}\\n`);\n                }\n            }\n        }\n\n        if (afterScripts.warned.length !== 0) {\n            afterScripts.warned.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            afterScripts.warned.forEach(({name}) => {\n                const namePad = name.padEnd(jobNamePad);\n                writeStreams.stdout(chalk`{black.bgYellowBright  WARN } {blueBright ${namePad}}  after_script\\n`);\n            });\n        }\n\n        if (preScripts.failed.length !== 0) {\n            preScripts.failed.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            for (const {name} of preScripts.failed) {\n                const namePad = name.padEnd(jobNamePad);\n                const safeName = Utils.getSafeJobName(name);\n                writeStreams.stdout(chalk`{black.bgRed  FAIL } {blueBright ${namePad}}\\n`);\n                const outputLog = await fs.readFile(`${cwd}/.gitlab-ci-local/output/${safeName}.log`, \"utf8\");\n                for (const line of outputLog.split(/\\r?\\n/).filter(j => !j.includes(\"[32m$ \")).filter(j => j !== \"\").slice(-3)) {\n                    writeStreams.stdout(chalk`  {red >} ${line}\\n`);\n                }\n            }\n        }\n\n        for (const job of preScripts.successful) {\n            const e = job.environment;\n            if (e == null) {\n                continue;\n            }\n            const name = Utils.expandText(e.name, job.expandedVariables);\n            const url = Utils.expandText(e.url, job.expandedVariables);\n            writeStreams.stdout(chalk`{blueBright ${job.name}} environment: \\{ name: {bold ${name}}`);\n            if (url != null) {\n                writeStreams.stdout(chalk`, url: {bold ${url}}`);\n            }\n            writeStreams.stdout(\" }\\n\");\n        }\n\n    };\n\n    static runList(parser: Parser, writeStreams: WriteStreams, listAll: boolean) {\n        const stages = parser.stages;\n        let jobs = [...parser.jobs.values()];\n        jobs.sort((a, b) => {\n            return stages.indexOf(a.stage) - stages.indexOf(b.stage);\n        });\n\n        let whenPadEnd = 4;\n        jobs.forEach(j => whenPadEnd = Math.max(j.when.length, whenPadEnd));\n\n        let stagePadEnd = 5;\n        stages.forEach(s => stagePadEnd = Math.max(s.length, stagePadEnd));\n\n        let descriptionPadEnd = 11;\n        jobs.forEach(j => descriptionPadEnd = Math.max(j.description.length, descriptionPadEnd));\n\n        const jobNamePad = parser.jobNamePad;\n\n        if (!listAll) {\n            jobs = jobs.filter(j => j.when !== \"never\");\n        }\n\n        writeStreams.stdout(chalk`{grey ${\"name\".padEnd(jobNamePad)}  ${\"description\".padEnd(descriptionPadEnd)}}  `);\n        writeStreams.stdout(chalk`{grey ${\"stage\".padEnd(stagePadEnd)}  ${\"when\".padEnd(whenPadEnd)}}  `);\n        writeStreams.stdout(chalk`{grey allow_failure  needs}\\n`);\n\n        const renderLine = (job: Job) => {\n            const needs = job.needs;\n            const allowFailure = job.allowFailure ? \"true \" : \"false\";\n            let jobLine = chalk`{blueBright ${job.name.padEnd(jobNamePad)}}  ${job.description.padEnd(descriptionPadEnd)}  `;\n            jobLine += chalk`{yellow ${job.stage.padEnd(stagePadEnd)}}  ${job.when.padEnd(whenPadEnd)}  ${allowFailure.padEnd(11)}`;\n            if (needs) {\n                jobLine += chalk`    [{blueBright ${needs.map(n => n.job).join(\",\")}}]`;\n            }\n            writeStreams.stdout(`${jobLine}\\n`);\n        };\n\n        jobs.forEach((job) => renderLine(job));\n    }\n\n}\n"]}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commander.js","sourceRoot":"","sources":["commander.ts"],"names":[],"mappings":";;;;;;;AAAA,kDAA0B;AAG1B,mCAA8B;AAE9B,iDAA2C;AAC3C,wDAA0B;AAG1B,MAAa,SAAS;IAElB,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,IAAU,EAAE,MAAc,EAAE,YAA0B;QAC3E,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACzB,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAE7B,IAAI,iBAAiB,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAC3C,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC;QACtE,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACvG,MAAM,0BAAW,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;QACjE,MAAM,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;IACzF,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,IAAU,EAAE,MAAc,EAAE,YAA0B;QACvE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC;QACzB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACzB,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAG7B,IAAI,iBAAiB,GAAU,EAAE,CAAC;QAClC,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,CAAc,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,EAAe,CAAC;QAC/E,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACtB,MAAM,GAAG,GAAG,aAAK,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YAC9C,UAAU,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YAC7B,IAAI,KAAK,EAAE;gBACP,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,0BAAW,CAAC,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;aAC9G;YACD,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,MAAM,0BAAW,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;QACvE,MAAM,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;IACzF,CAAC;IAiGD,MAAM,CAAC,OAAO,CAAC,MAAc,EAAE,YAA0B,EAAE,OAAgB;QACvE,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC7B,IAAI,IAAI,GAAG,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACf,OAAO,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEH,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC;QAEpE,IAAI,WAAW,GAAG,CAAC,CAAC;QACpB,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC;QAEnE,IAAI,iBAAiB,GAAG,EAAE,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC;QAEzF,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;QAErC,IAAI,CAAC,OAAO,EAAE;YACV,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC;SAC/C;QAED,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,SAAS,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,aAAa,CAAC,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAC9G,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,SAAS,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAClG,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,+BAA+B,CAAC,CAAC;QAE1D,MAAM,UAAU,GAAG,CAAC,GAAQ,EAAE,EAAE;YAC5B,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC;YACxB,MAAM,YAAY,GAAG,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;YAC1D,IAAI,OAAO,GAAG,IAAA,eAAK,EAAA,eAAe,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,WAAW,CAAC,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC;YACjH,OAAO,IAAI,IAAA,eAAK,EAAA,WAAW,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;YACxH,IAAI,KAAK,EAAE;gBACP,OAAO,IAAI,IAAA,eAAK,EAAA,oBAAoB,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC;aAC3E;YACD,YAAY,CAAC,MAAM,CAAC,GAAG,OAAO,IAAI,CAAC,CAAC;QACxC,CAAC,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;IAC3C,CAAC;;AAxKL,8BA0KC;;AAvIU,qBAAW,GAAG,KAAK,EAAE,GAAW,EAAE,YAA0B,EAAE,IAA8B,EAAE,MAAyB,EAAE,UAAkB,EAAE,EAAE;IAElJ,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAE1B,MAAM,UAAU,GAAwD;QACpE,UAAU,EAAE,EAAE;QACd,MAAM,EAAE,EAAE;QACV,MAAM,EAAE,EAAE;KACb,CAAC;IACF,MAAM,YAAY,GAAsB;QACpC,MAAM,EAAE,EAAE;KACb,CAAC;IAEF,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;QAC7B,IAAI,GAAG,CAAC,OAAO,IAAI,GAAG,CAAC,oBAAoB,KAAK,CAAC,EAAE;YAC/C,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACjC;KACJ;IAED,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;QAC7B,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE;YACd,SAAS;SACZ;QAED,IAAI,GAAG,CAAC,kBAAkB,KAAK,CAAC,EAAE;YAC9B,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACnC;aAAM,IAAI,GAAG,CAAC,YAAY,EAAE;YACzB,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC/B;aAAM;YACH,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC/B;KACJ;IAED,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;QACpC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACxF,UAAU,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAClC,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YAC5C,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,4CAA4C,OAAO,GAAG,CAAC,CAAC;YACjF,IAAI,GAAG,CAAC,eAAe,EAAE;gBACrB,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,IAAI,GAAG,CAAC,eAAe,mBAAmB,CAAC,CAAC;aACxE;YACD,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;KACN;IAED,IAAI,UAAU,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QAChC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACpF,KAAK,MAAM,EAAC,IAAI,EAAC,IAAI,UAAU,CAAC,MAAM,EAAE;YACpC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACxC,MAAM,QAAQ,GAAG,aAAK,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAC5C,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,6CAA6C,OAAO,iBAAiB,CAAC,CAAC;YAChG,MAAM,SAAS,GAAG,MAAM,kBAAE,CAAC,QAAQ,CAAC,GAAG,GAAG,4BAA4B,QAAQ,MAAM,EAAE,MAAM,CAAC,CAAC;YAC9F,KAAK,MAAM,IAAI,IAAI,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;gBAC5G,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,gBAAgB,IAAI,IAAI,CAAC,CAAC;aACtD;SACJ;KACJ;IAED,IAAI,YAAY,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QAClC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACtF,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,EAAC,IAAI,EAAC,EAAE,EAAE;YACnC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACxC,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,6CAA6C,OAAO,mBAAmB,CAAC,CAAC;QACtG,CAAC,CAAC,CAAC;KACN;IAED,IAAI,UAAU,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QAChC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACpF,KAAK,MAAM,EAAC,IAAI,EAAC,IAAI,UAAU,CAAC,MAAM,EAAE;YACpC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACxC,MAAM,QAAQ,GAAG,aAAK,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAC5C,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,oCAAoC,OAAO,KAAK,CAAC,CAAC;YAC3E,MAAM,SAAS,GAAG,MAAM,kBAAE,CAAC,QAAQ,CAAC,GAAG,GAAG,4BAA4B,QAAQ,MAAM,EAAE,MAAM,CAAC,CAAC;YAC9F,KAAK,MAAM,IAAI,IAAI,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;gBAC5G,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,aAAa,IAAI,IAAI,CAAC,CAAC;aACnD;SACJ;KACJ;IAED,KAAK,MAAM,GAAG,IAAI,UAAU,CAAC,UAAU,EAAE;QACrC,MAAM,CAAC,GAAG,GAAG,CAAC,WAAW,CAAC;QAC1B,IAAI,CAAC,IAAI,IAAI,EAAE;YACX,SAAS;SACZ;QACD,MAAM,IAAI,GAAG,aAAK,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC;QAC7D,MAAM,GAAG,GAAG,aAAK,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC;QAC3D,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,eAAe,GAAG,CAAC,IAAI,iCAAiC,IAAI,GAAG,CAAC,CAAC;QAC1F,IAAI,GAAG,IAAI,IAAI,EAAE;YACb,YAAY,CAAC,MAAM,CAAC,IAAA,eAAK,EAAA,gBAAgB,GAAG,GAAG,CAAC,CAAC;SACpD;QACD,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;KAC/B;AAEL,CAAE,CAAA","sourcesContent":["import chalk from \"chalk\";\nimport {Job} from \"./job\";\nimport {Parser} from \"./parser\";\nimport {Utils} from \"./utils\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport {JobExecutor} from \"./job-executor\";\nimport fs from \"fs-extra\";\nimport {Argv} from \"./argv\";\n\nexport class Commander {\n\n    static async runPipeline(argv: Argv, parser: Parser, writeStreams: WriteStreams) {\n        const jobs = parser.jobs;\n        const stages = parser.stages;\n\n        let potentialStarters = [...jobs.values()];\n        potentialStarters = potentialStarters.filter(j => j.when !== \"never\");\n        potentialStarters = potentialStarters.filter(j => j.when !== \"manual\" || argv.manual.includes(j.name));\n        await JobExecutor.runLoop(argv, jobs, stages, potentialStarters);\n        await Commander.printReport(argv.cwd, writeStreams, jobs, stages, parser.jobNamePad);\n    }\n\n    static async runJobs(argv: Argv, parser: Parser, writeStreams: WriteStreams) {\n        const needs = argv.needs;\n        const jobArgs = argv.job;\n        const jobs = parser.jobs;\n        const stages = parser.stages;\n\n\n        let potentialStarters: Job[] = [];\n        const jobPoolMap = needs ? new Map<string, Job>(jobs) : new Map<string, Job>();\n        jobArgs.forEach(jobName => {\n            const job = Utils.getJobByName(jobs, jobName);\n            jobPoolMap.set(jobName, job);\n            if (needs) {\n                potentialStarters = potentialStarters.concat(JobExecutor.getPastToWaitFor(jobs, stages, job, argv.manual));\n            }\n            potentialStarters.push(job);\n        });\n\n        await JobExecutor.runLoop(argv, jobPoolMap, stages, potentialStarters);\n        await Commander.printReport(argv.cwd, writeStreams, jobs, stages, parser.jobNamePad);\n    }\n\n    static printReport = async (cwd: string, writeStreams: WriteStreams, jobs: ReadonlyMap<string, Job>, stages: readonly string[], jobNamePad: number) => {\n\n        writeStreams.stdout(\"\\n\");\n\n        const preScripts: { successful: Job[]; failed: Job[]; warned: Job[] } = {\n            successful: [],\n            failed: [],\n            warned: [],\n        };\n        const afterScripts: { warned: Job[] } = {\n            warned: [],\n        };\n\n        for (const job of jobs.values()) {\n            if (job.started && job.afterScriptsExitCode !== 0) {\n                afterScripts.warned.push(job);\n            }\n        }\n\n        for (const job of jobs.values()) {\n            if (!job.started) {\n                continue;\n            }\n\n            if (job.preScriptsExitCode === 0) {\n                preScripts.successful.push(job);\n            } else if (job.allowFailure) {\n                preScripts.warned.push(job);\n            } else {\n                preScripts.failed.push(job);\n            }\n        }\n\n        if (preScripts.successful.length !== 0) {\n            preScripts.successful.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            preScripts.successful.forEach((job) => {\n                const namePad = job.name.padEnd(jobNamePad);\n                writeStreams.stdout(chalk`{black.bgGreenBright  PASS } {blueBright ${namePad}}`);\n                if (job.coveragePercent) {\n                    writeStreams.stdout(chalk` ${job.coveragePercent}% {grey coverage}`);\n                }\n                writeStreams.stdout(\"\\n\");\n            });\n        }\n\n        if (preScripts.warned.length !== 0) {\n            preScripts.warned.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            for (const {name} of preScripts.warned) {\n                const namePad = name.padEnd(jobNamePad);\n                const safeName = Utils.getSafeJobName(name);\n                writeStreams.stdout(chalk`{black.bgYellowBright  WARN } {blueBright ${namePad}}  pre_script\\n`);\n                const outputLog = await fs.readFile(`${cwd}/.gitlab-ci-local/output/${safeName}.log`, \"utf8\");\n                for (const line of outputLog.split(/\\r?\\n/).filter(j => !j.includes(\"[32m$ \")).filter(j => j !== \"\").slice(-3)) {\n                    writeStreams.stdout(chalk`  {yellow >} ${line}\\n`);\n                }\n            }\n        }\n\n        if (afterScripts.warned.length !== 0) {\n            afterScripts.warned.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            afterScripts.warned.forEach(({name}) => {\n                const namePad = name.padEnd(jobNamePad);\n                writeStreams.stdout(chalk`{black.bgYellowBright  WARN } {blueBright ${namePad}}  after_script\\n`);\n            });\n        }\n\n        if (preScripts.failed.length !== 0) {\n            preScripts.failed.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));\n            for (const {name} of preScripts.failed) {\n                const namePad = name.padEnd(jobNamePad);\n                const safeName = Utils.getSafeJobName(name);\n                writeStreams.stdout(chalk`{black.bgRed  FAIL } {blueBright ${namePad}}\\n`);\n                const outputLog = await fs.readFile(`${cwd}/.gitlab-ci-local/output/${safeName}.log`, \"utf8\");\n                for (const line of outputLog.split(/\\r?\\n/).filter(j => !j.includes(\"[32m$ \")).filter(j => j !== \"\").slice(-3)) {\n                    writeStreams.stdout(chalk`  {red >} ${line}\\n`);\n                }\n            }\n        }\n\n        for (const job of preScripts.successful) {\n            const e = job.environment;\n            if (e == null) {\n                continue;\n            }\n            const name = Utils.expandText(e.name, job.expandedVariables);\n            const url = Utils.expandText(e.url, job.expandedVariables);\n            writeStreams.stdout(chalk`{blueBright ${job.name}} environment: \\{ name: {bold ${name}}`);\n            if (url != null) {\n                writeStreams.stdout(chalk`, url: {bold ${url}}`);\n            }\n            writeStreams.stdout(\" }\\n\");\n        }\n\n    };\n\n    static runList(parser: Parser, writeStreams: WriteStreams, listAll: boolean) {\n        const stages = parser.stages;\n        let jobs = [...parser.jobs.values()];\n        jobs.sort((a, b) => {\n            return stages.indexOf(a.stage) - stages.indexOf(b.stage);\n        });\n\n        let whenPadEnd = 4;\n        jobs.forEach(j => whenPadEnd = Math.max(j.when.length, whenPadEnd));\n\n        let stagePadEnd = 5;\n        stages.forEach(s => stagePadEnd = Math.max(s.length, stagePadEnd));\n\n        let descriptionPadEnd = 11;\n        jobs.forEach(j => descriptionPadEnd = Math.max(j.description.length, descriptionPadEnd));\n\n        const jobNamePad = parser.jobNamePad;\n\n        if (!listAll) {\n            jobs = jobs.filter(j => j.when !== \"never\");\n        }\n\n        writeStreams.stdout(chalk`{grey ${\"name\".padEnd(jobNamePad)}  ${\"description\".padEnd(descriptionPadEnd)}}  `);\n        writeStreams.stdout(chalk`{grey ${\"stage\".padEnd(stagePadEnd)}  ${\"when\".padEnd(whenPadEnd)}}  `);\n        writeStreams.stdout(chalk`{grey allow_failure  needs}\\n`);\n\n        const renderLine = (job: Job) => {\n            const needs = job.needs;\n            const allowFailure = job.allowFailure ? \"true \" : \"false\";\n            let jobLine = chalk`{blueBright ${job.name.padEnd(jobNamePad)}}  ${job.description.padEnd(descriptionPadEnd)}  `;\n            jobLine += chalk`{yellow ${job.stage.padEnd(stagePadEnd)}}  ${job.when.padEnd(whenPadEnd)}  ${allowFailure.padEnd(11)}`;\n            if (needs) {\n                jobLine += chalk`    [{blueBright ${needs.map(n => n.job).join(\",\")}}]`;\n            }\n            writeStreams.stdout(`${jobLine}\\n`);\n        };\n\n        jobs.forEach((job) => renderLine(job));\n    }\n\n}\n"]}
|
package/src/git-data.js
CHANGED
|
@@ -42,39 +42,43 @@ class GitData {
|
|
|
42
42
|
}
|
|
43
43
|
static async init(cwd, writeStreams) {
|
|
44
44
|
const gitData = new GitData();
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
writeStreams.stderr((0, chalk_1.default) `{yellow Git not available using fallback}\n`);
|
|
51
|
-
return gitData;
|
|
52
|
-
}
|
|
53
|
-
await gitData.initCommitData(cwd, writeStreams);
|
|
54
|
-
await gitData.initRemoteData(cwd, writeStreams);
|
|
55
|
-
await gitData.initUserData(cwd, writeStreams);
|
|
45
|
+
const promises = [];
|
|
46
|
+
promises.push(gitData.initCommitData(cwd, writeStreams));
|
|
47
|
+
promises.push(gitData.initRemoteData(cwd, writeStreams));
|
|
48
|
+
promises.push(gitData.initUserData(cwd, writeStreams));
|
|
49
|
+
await Promise.all(promises);
|
|
56
50
|
return gitData;
|
|
57
51
|
}
|
|
58
52
|
async initCommitData(cwd, writeStreams) {
|
|
53
|
+
const promises = [];
|
|
54
|
+
const refNamePromise = utils_1.Utils.spawn(["git", "rev-parse", "--abbrev-ref", "HEAD"], cwd);
|
|
55
|
+
refNamePromise.then(({ stdout }) => {
|
|
56
|
+
this.commit.REF_NAME = stdout.trimEnd();
|
|
57
|
+
});
|
|
58
|
+
promises.push(refNamePromise);
|
|
59
|
+
const shaPromise = utils_1.Utils.spawn(["git", "rev-parse", "HEAD"], cwd);
|
|
60
|
+
shaPromise.then(({ stdout }) => {
|
|
61
|
+
this.commit.SHA = stdout.trimEnd();
|
|
62
|
+
});
|
|
63
|
+
promises.push(shaPromise);
|
|
64
|
+
const shortShaPromise = utils_1.Utils.spawn(["git", "rev-parse", "--short", "HEAD"], cwd);
|
|
65
|
+
shortShaPromise.then(({ stdout }) => {
|
|
66
|
+
this.commit.SHORT_SHA = stdout.trimEnd();
|
|
67
|
+
});
|
|
68
|
+
promises.push(shortShaPromise);
|
|
59
69
|
try {
|
|
60
|
-
|
|
61
|
-
const gitLogMatch = gitLogStdout.match(/(?<short_sha>\S*?) (?<sha>\S*) .*HEAD( -> |, tag: |, )(?<ref_name>.*?)(?:,|$)/);
|
|
62
|
-
(0, asserts_1.assert)(gitLogMatch?.groups != null, "git log -1 didn't provide valid matches");
|
|
63
|
-
this.commit.REF_NAME = gitLogMatch.groups.ref_name;
|
|
64
|
-
this.commit.SHA = gitLogMatch.groups.sha;
|
|
65
|
-
this.commit.SHORT_SHA = gitLogMatch.groups.short_sha;
|
|
70
|
+
await Promise.all(promises);
|
|
66
71
|
}
|
|
67
72
|
catch (e) {
|
|
68
73
|
if (e instanceof exit_error_1.ExitError) {
|
|
69
|
-
writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
70
|
-
return;
|
|
74
|
+
return writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
71
75
|
}
|
|
72
76
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git commit data}\n`);
|
|
73
77
|
}
|
|
74
78
|
}
|
|
75
79
|
async initRemoteData(cwd, writeStreams) {
|
|
76
80
|
try {
|
|
77
|
-
const { stdout: gitRemote } = await utils_1.Utils.spawn("git remote -v", cwd);
|
|
81
|
+
const { stdout: gitRemote } = await utils_1.Utils.spawn(["git", "remote", "-v"], cwd);
|
|
78
82
|
const gitRemoteMatch = gitRemote.match(/.*(?:\/\/|@)(?<host>[^:/]*)(:(?<port>\d+)\/|:|\/)(?<group>.*)\/(?<project>.*?)(?:\r?\n|\.git)/);
|
|
79
83
|
(0, asserts_1.assert)(gitRemoteMatch?.groups != null, "git remote -v didn't provide valid matches");
|
|
80
84
|
this.remote.port = gitRemoteMatch.groups.port ?? "22";
|
|
@@ -91,27 +95,29 @@ class GitData {
|
|
|
91
95
|
}
|
|
92
96
|
}
|
|
93
97
|
async initUserData(cwd, writeStreams) {
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
catch
|
|
98
|
+
const promises = [];
|
|
99
|
+
const gitUsernamePromise = utils_1.Utils.spawn(["git", "config", "user.name"], cwd).then(({ stdout }) => {
|
|
100
|
+
this.user.GITLAB_USER_NAME = stdout.trimEnd();
|
|
101
|
+
}).catch(() => {
|
|
98
102
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git user.name}\n`);
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
|
|
103
|
+
});
|
|
104
|
+
promises.push(gitUsernamePromise);
|
|
105
|
+
const gitEmailPromise = utils_1.Utils.spawn(["git", "config", "user.email"], cwd).then(({ stdout }) => {
|
|
106
|
+
const email = stdout.trimEnd();
|
|
102
107
|
this.user.GITLAB_USER_EMAIL = email;
|
|
103
108
|
this.user.GITLAB_USER_LOGIN = email.replace(/@.*/, "");
|
|
104
|
-
}
|
|
105
|
-
catch (e) {
|
|
109
|
+
}).catch(() => {
|
|
106
110
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git user.email}\n`);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
catch
|
|
111
|
+
});
|
|
112
|
+
promises.push(gitEmailPromise);
|
|
113
|
+
const osUidPromise = utils_1.Utils.spawn(["id", "-u"], cwd).then(({ stdout }) => {
|
|
114
|
+
this.user.GITLAB_USER_ID = stdout.trimEnd();
|
|
115
|
+
}).catch(() => {
|
|
112
116
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback linux user id}\n`);
|
|
113
|
-
}
|
|
117
|
+
});
|
|
118
|
+
promises.push(osUidPromise);
|
|
119
|
+
await Promise.all(promises);
|
|
114
120
|
}
|
|
115
121
|
}
|
|
116
122
|
exports.GitData = GitData;
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"git-data.js","sourceRoot":"","sources":["git-data.ts"],"names":[],"mappings":"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","sourcesContent":["import {Utils} from \"./utils\";\nimport {assert} from \"./asserts\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport chalk from \"chalk\";\nimport {ExitError} from \"./types/exit-error\";\n\nexport class GitData {\n\n    public readonly user = {\n        GITLAB_USER_LOGIN: \"local\",\n        GITLAB_USER_EMAIL: \"local@gitlab.com\",\n        GITLAB_USER_NAME: \"Bob Local\",\n        GITLAB_USER_ID: \"1000\",\n    };\n\n    public readonly remote = {\n        port: \"22\",\n        host: \"gitlab.com\",\n        group: \"fallback.group\",\n        project: \"fallback.project\",\n    };\n\n    public readonly commit = {\n        REF_NAME: \"main\",\n        SHA: \"0000000000000000000000000000000000000000\",\n        SHORT_SHA: \"00000000\",\n    };\n\n    get CI_PROJECT_PATH() {\n        return `${this.remote.group}/${this.remote.project}`;\n    }\n\n    get CI_REGISTRY() {\n        return `local-registry.${this.remote.host}`;\n    }\n\n    get CI_REGISTRY_IMAGE() {\n        return `${this.CI_REGISTRY}/${this.CI_PROJECT_PATH}`;\n    }\n\n    get CI_PROJECT_PATH_SLUG() {\n        return `${this.remote.group.replace(/\\//g, \"-\")}-${this.remote.project}`;\n    }\n\n    static async init(cwd: string, writeStreams: WriteStreams): Promise<GitData> {\n        const gitData = new GitData();\n        try {\n            const gitVersion = (await Utils.spawn(\"git --version\", cwd)).stdout.trimEnd();\n            assert(gitVersion != null, \"We do not think it is safe to use git without a proper version string!\");\n        } catch (e) {\n            writeStreams.stderr(chalk`{yellow Git not available using fallback}\\n`);\n            return gitData;\n        }\n        await gitData.initCommitData(cwd, writeStreams);\n        await gitData.initRemoteData(cwd, writeStreams);\n        await gitData.initUserData(cwd, writeStreams);\n        return gitData;\n    }\n\n    private async initCommitData(cwd: string, writeStreams: WriteStreams): Promise<void> {\n        try {\n            const gitLogStdout = (await Utils.spawn(\"git log -1 --pretty=format:'%h %H %D'\", cwd)).stdout.replace(/\\r?\\n/g, \"\");\n            const gitLogMatch = gitLogStdout.match(/(?<short_sha>\\S*?) (?<sha>\\S*) .*HEAD( -> |, tag: |, )(?<ref_name>.*?)(?:,|$)/);\n\n            assert(gitLogMatch?.groups != null, \"git log -1 didn't provide valid matches\");\n\n            this.commit.REF_NAME = gitLogMatch.groups.ref_name;\n            this.commit.SHA = gitLogMatch.groups.sha;\n            this.commit.SHORT_SHA = gitLogMatch.groups.short_sha;\n        } catch (e) {\n            if (e instanceof ExitError) {\n                writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n                return;\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git commit data}\\n`);\n        }\n    }\n\n    private async initRemoteData(cwd: string, writeStreams: WriteStreams): Promise<void> {\n        try {\n            const { stdout: gitRemote } = await Utils.spawn(\"git remote -v\", cwd);\n            const gitRemoteMatch = gitRemote.match(/.*(?:\\/\\/|@)(?<host>[^:/]*)(:(?<port>\\d+)\\/|:|\\/)(?<group>.*)\\/(?<project>.*?)(?:\\r?\\n|\\.git)/);\n\n            assert(gitRemoteMatch?.groups != null, \"git remote -v didn't provide valid matches\");\n\n            this.remote.port = gitRemoteMatch.groups.port ?? \"22\";\n            this.remote.host = gitRemoteMatch.groups.host;\n            this.remote.group = gitRemoteMatch.groups.group;\n            this.remote.project = gitRemoteMatch.groups.project;\n        } catch (e) {\n            if (e instanceof ExitError) {\n                writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n                return;\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git remote data}\\n`);\n        }\n    }\n\n    async initUserData(cwd: string, writeStreams: WriteStreams): Promise<void> {\n        try {\n            this.user.GITLAB_USER_NAME = (await Utils.spawn(\"git config user.name\", cwd)).stdout.trimEnd();\n        } catch(e) {\n            writeStreams.stderr(chalk`{yellow Using fallback git user.name}\\n`);\n        }\n\n        try {\n            const email = (await Utils.spawn(\"git config user.email\", cwd)).stdout.trimEnd();\n            this.user.GITLAB_USER_EMAIL = email;\n            this.user.GITLAB_USER_LOGIN = email.replace(/@.*/, \"\");\n        } catch (e) {\n            writeStreams.stderr(chalk`{yellow Using fallback git user.email}\\n`);\n        }\n\n        try {\n            this.user.GITLAB_USER_ID = (await Utils.spawn(\"id -u\", cwd)).stdout.trimEnd();\n        } catch(e) {\n            writeStreams.stderr(chalk`{yellow Using fallback linux user id}\\n`);\n        }\n    }\n}\n"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"git-data.js","sourceRoot":"","sources":["git-data.ts"],"names":[],"mappings":"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","sourcesContent":["import {Utils} from \"./utils\";\nimport {assert} from \"./asserts\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport chalk from \"chalk\";\nimport {ExitError} from \"./types/exit-error\";\n\nexport class GitData {\n\n    public readonly user = {\n        GITLAB_USER_LOGIN: \"local\",\n        GITLAB_USER_EMAIL: \"local@gitlab.com\",\n        GITLAB_USER_NAME: \"Bob Local\",\n        GITLAB_USER_ID: \"1000\",\n    };\n\n    public readonly remote = {\n        port: \"22\",\n        host: \"gitlab.com\",\n        group: \"fallback.group\",\n        project: \"fallback.project\",\n    };\n\n    public readonly commit = {\n        REF_NAME: \"main\",\n        SHA: \"0000000000000000000000000000000000000000\",\n        SHORT_SHA: \"00000000\",\n    };\n\n    get CI_PROJECT_PATH() {\n        return `${this.remote.group}/${this.remote.project}`;\n    }\n\n    get CI_REGISTRY() {\n        return `local-registry.${this.remote.host}`;\n    }\n\n    get CI_REGISTRY_IMAGE() {\n        return `${this.CI_REGISTRY}/${this.CI_PROJECT_PATH}`;\n    }\n\n    get CI_PROJECT_PATH_SLUG() {\n        return `${this.remote.group.replace(/\\//g, \"-\")}-${this.remote.project}`;\n    }\n\n    static async init(cwd: string, writeStreams: WriteStreams): Promise<GitData> {\n        const gitData = new GitData();\n        const promises = [];\n        promises.push(gitData.initCommitData(cwd, writeStreams));\n        promises.push(gitData.initRemoteData(cwd, writeStreams));\n        promises.push(gitData.initUserData(cwd, writeStreams));\n        await Promise.all(promises);\n        return gitData;\n    }\n\n    private async initCommitData(cwd: string, writeStreams: WriteStreams): Promise<void> {\n        const promises = [];\n\n        const refNamePromise = Utils.spawn([\"git\", \"rev-parse\", \"--abbrev-ref\", \"HEAD\"], cwd);\n        refNamePromise.then(({stdout}) => {\n            this.commit.REF_NAME = stdout.trimEnd();\n        });\n        promises.push(refNamePromise);\n\n        const shaPromise = Utils.spawn([\"git\", \"rev-parse\", \"HEAD\"], cwd);\n        shaPromise.then(({stdout}) => {\n            this.commit.SHA = stdout.trimEnd();\n        });\n        promises.push(shaPromise);\n\n        const shortShaPromise = Utils.spawn([\"git\", \"rev-parse\", \"--short\", \"HEAD\"], cwd);\n        shortShaPromise.then(({stdout}) => {\n            this.commit.SHORT_SHA = stdout.trimEnd();\n        });\n        promises.push(shortShaPromise);\n\n        try {\n            await Promise.all(promises);\n        } catch (e) {\n            if (e instanceof ExitError) {\n                return writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git commit data}\\n`);\n        }\n    }\n\n    private async initRemoteData(cwd: string, writeStreams: WriteStreams): Promise<void> {\n        try {\n            const { stdout: gitRemote } = await Utils.spawn([\"git\", \"remote\", \"-v\"], cwd);\n            const gitRemoteMatch = gitRemote.match(/.*(?:\\/\\/|@)(?<host>[^:/]*)(:(?<port>\\d+)\\/|:|\\/)(?<group>.*)\\/(?<project>.*?)(?:\\r?\\n|\\.git)/);\n\n            assert(gitRemoteMatch?.groups != null, \"git remote -v didn't provide valid matches\");\n\n            this.remote.port = gitRemoteMatch.groups.port ?? \"22\";\n            this.remote.host = gitRemoteMatch.groups.host;\n            this.remote.group = gitRemoteMatch.groups.group;\n            this.remote.project = gitRemoteMatch.groups.project;\n        } catch (e) {\n            if (e instanceof ExitError) {\n                writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n                return;\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git remote data}\\n`);\n        }\n    }\n\n    async initUserData(cwd: string, writeStreams: WriteStreams): Promise<void> {\n        const promises = [];\n\n        const gitUsernamePromise = Utils.spawn([\"git\", \"config\", \"user.name\"], cwd).then(({stdout}) => {\n            this.user.GITLAB_USER_NAME = stdout.trimEnd();\n        }).catch(() => {\n            writeStreams.stderr(chalk`{yellow Using fallback git user.name}\\n`);\n        });\n        promises.push(gitUsernamePromise);\n\n        const gitEmailPromise = Utils.spawn([\"git\", \"config\", \"user.email\"], cwd).then(({stdout}) => {\n            const email = stdout.trimEnd();\n            this.user.GITLAB_USER_EMAIL = email;\n            this.user.GITLAB_USER_LOGIN = email.replace(/@.*/, \"\");\n        }).catch(() => {\n            writeStreams.stderr(chalk`{yellow Using fallback git user.email}\\n`);\n        });\n        promises.push(gitEmailPromise);\n\n        const osUidPromise = Utils.spawn([\"id\", \"-u\"], cwd).then(({stdout}) => {\n            this.user.GITLAB_USER_ID = stdout.trimEnd();\n        }).catch(() => {\n            writeStreams.stderr(chalk`{yellow Using fallback linux user id}\\n`);\n        });\n        promises.push(osUidPromise);\n\n        await Promise.all(promises);\n    }\n}\n"]}
|