gitlab-ci-local 4.26.3 → 4.28.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/README.md +19 -0
- package/package.json +17 -18
- package/src/cache-entry.js +21 -0
- package/src/commander.js +21 -10
- package/src/git-data.js +52 -56
- package/src/handler.js +13 -7
- package/src/index.js +13 -4
- package/src/job-expanders.js +3 -19
- package/src/job.js +211 -114
- package/src/mutex.js +24 -0
- package/src/parser-includes.js +39 -31
- package/src/parser.js +13 -14
- package/src/service.js +5 -4
- package/src/types/job-options.js +1 -1
- package/src/types/parser-options.js +1 -1
- package/src/utils.js +3 -3
- package/src/variables-from-files.js +103 -0
- package/src/home-variables.js +0 -100
package/README.md
CHANGED
|
@@ -32,7 +32,9 @@ Get rid of all those dev specific shell scripts and make files.
|
|
|
32
32
|
* [Quirks](#quirks)
|
|
33
33
|
* [Tracked Files](#tracked-files)
|
|
34
34
|
* [Home Variables](#home-variables)
|
|
35
|
+
* [Project Variables](#project-variables)
|
|
35
36
|
* [Decorators](#decorators)
|
|
37
|
+
* [Includes](#includes)
|
|
36
38
|
* [Artifacts](#artifacts)
|
|
37
39
|
* [Development](#development)
|
|
38
40
|
* [Scripts](#scripts)
|
|
@@ -135,6 +137,20 @@ global:
|
|
|
135
137
|
|
|
136
138
|
Variables will now appear in your jobs, if project or group matches git remote, global's are always present
|
|
137
139
|
|
|
140
|
+
### Project variables
|
|
141
|
+
|
|
142
|
+
Put a file like this in `$CWD/.gitlab-ci-local-variables.yml`
|
|
143
|
+
|
|
144
|
+
```yaml
|
|
145
|
+
---
|
|
146
|
+
AUTHORIZATION_PASSWORD: djwqiod910321
|
|
147
|
+
DOCKER_LOGIN_PASSWORD: dij3213n123n12in3
|
|
148
|
+
# Will be type File, because value is a file path
|
|
149
|
+
KNOWN_HOSTS: '~/.ssh/known_hosts'
|
|
150
|
+
```
|
|
151
|
+
|
|
152
|
+
Variables will now appear in your jobs.
|
|
153
|
+
|
|
138
154
|
### Decorators
|
|
139
155
|
|
|
140
156
|
#### The `@Description` decorator
|
|
@@ -190,6 +206,9 @@ produce:
|
|
|
190
206
|
artifacts: {paths: [path/] }
|
|
191
207
|
```
|
|
192
208
|
|
|
209
|
+
### Includes
|
|
210
|
+
Includes from external sources are only fetched once. Use `--fetch-includes` to invoke an external fetching rutine.
|
|
211
|
+
|
|
193
212
|
### Artifacts
|
|
194
213
|
|
|
195
214
|
Shell executor jobs copies artifacts to host/cwd directory. Use --shell-isolation option to mimic correct artifact handling for shell jobs.
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
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.28.0",
|
|
7
7
|
"scripts": {
|
|
8
8
|
"prepublishOnly": "npm run check-all && chmod +x src/index.js",
|
|
9
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",
|
|
@@ -20,41 +20,40 @@
|
|
|
20
20
|
"start": "ts-node --log-error src/index.ts --cwd examples/docker-compose-nodejs"
|
|
21
21
|
},
|
|
22
22
|
"dependencies": {
|
|
23
|
+
"axios": "^0.24.0",
|
|
23
24
|
"base64url": "^3.0.1",
|
|
24
|
-
"camelcase": "^6.2.
|
|
25
|
+
"camelcase": "^6.2.1",
|
|
25
26
|
"chalk": "^4.1.2",
|
|
26
27
|
"checksum": "^1.0.0",
|
|
27
28
|
"deep-extend": "^0.6.0",
|
|
28
29
|
"dotenv": "^10.0.0",
|
|
29
30
|
"fs-extra": "^10.0.0",
|
|
30
31
|
"js-yaml": "^4.1.0",
|
|
31
|
-
"node-fetch": "^2.6.5",
|
|
32
32
|
"pretty-hrtime": "^1.0.3",
|
|
33
|
-
"source-map-support": "^0.5.
|
|
34
|
-
"yargs": "^17.
|
|
33
|
+
"source-map-support": "^0.5.21",
|
|
34
|
+
"yargs": "^17.3.0"
|
|
35
35
|
},
|
|
36
36
|
"devDependencies": {
|
|
37
|
-
"@types/chalk": "2.2.0",
|
|
38
37
|
"@types/checksum": "0.1.33",
|
|
39
38
|
"@types/deep-extend": "0.4.32",
|
|
40
39
|
"@types/fs-extra": "9.0.13",
|
|
41
|
-
"@types/jest": "27.0.
|
|
40
|
+
"@types/jest": "27.0.3",
|
|
42
41
|
"@types/jest-when": "2.7.3",
|
|
43
|
-
"@types/js-yaml": "4.0.
|
|
44
|
-
"@types/node-fetch": "2.5.12",
|
|
42
|
+
"@types/js-yaml": "4.0.5",
|
|
45
43
|
"@types/pretty-hrtime": "1.0.1",
|
|
46
44
|
"@types/source-map-support": "0.5.4",
|
|
47
|
-
"@types/yargs": "17.0.
|
|
48
|
-
"@typescript-eslint/eslint-plugin": "5.
|
|
49
|
-
"@typescript-eslint/parser": "5.
|
|
45
|
+
"@types/yargs": "17.0.7",
|
|
46
|
+
"@typescript-eslint/eslint-plugin": "5.8.0",
|
|
47
|
+
"@typescript-eslint/parser": "5.8.0",
|
|
48
|
+
"axios-mock-adapter": "1.20.0",
|
|
50
49
|
"depcheck": "1.4.2",
|
|
51
|
-
"eslint": "8.
|
|
52
|
-
"jest": "27.
|
|
53
|
-
"jest-when": "3.
|
|
54
|
-
"pkg": "5.
|
|
55
|
-
"ts-jest": "27.
|
|
50
|
+
"eslint": "8.5.0",
|
|
51
|
+
"jest": "27.4.5",
|
|
52
|
+
"jest-when": "3.5.0",
|
|
53
|
+
"pkg": "5.5.1",
|
|
54
|
+
"ts-jest": "27.1.2",
|
|
56
55
|
"ts-node": "10.4.0",
|
|
57
|
-
"typescript": "4.
|
|
56
|
+
"typescript": "4.5.4"
|
|
58
57
|
},
|
|
59
58
|
"engines": {
|
|
60
59
|
"node": ">=16.10.0"
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CacheEntry = void 0;
|
|
4
|
+
const utils_1 = require("./utils");
|
|
5
|
+
class CacheEntry {
|
|
6
|
+
constructor(key, paths, policy) {
|
|
7
|
+
this.key = key;
|
|
8
|
+
this.policy = policy;
|
|
9
|
+
this.paths = paths;
|
|
10
|
+
}
|
|
11
|
+
async getUniqueCacheName(cwd, env) {
|
|
12
|
+
if (typeof this.key === "string" || this.key == null) {
|
|
13
|
+
return utils_1.Utils.expandText(this.key ?? "default");
|
|
14
|
+
}
|
|
15
|
+
return "md-" + await utils_1.Utils.checksumFiles(this.key.files.map(f => {
|
|
16
|
+
return `${cwd}/${utils_1.Utils.expandText(f, env)}`;
|
|
17
|
+
}));
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.CacheEntry = CacheEntry;
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGUtZW50cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJjYWNoZS1lbnRyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBOEI7QUFFOUIsTUFBYSxVQUFVO0lBS25CLFlBQVksR0FBaUMsRUFBRSxLQUFlLEVBQUUsTUFBcUM7UUFDakcsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFDZixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUN2QixDQUFDO0lBRUQsS0FBSyxDQUFDLGtCQUFrQixDQUFDLEdBQVcsRUFBRSxHQUE4QjtRQUNoRSxJQUFJLE9BQU8sSUFBSSxDQUFDLEdBQUcsS0FBSyxRQUFRLElBQUksSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLEVBQUU7WUFDbEQsT0FBTyxhQUFLLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksU0FBUyxDQUFDLENBQUM7U0FDbEQ7UUFDRCxPQUFPLEtBQUssR0FBRyxNQUFNLGFBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQzVELE9BQU8sR0FBRyxHQUFHLElBQUksYUFBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNoRCxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztDQUVKO0FBcEJELGdDQW9CQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7VXRpbHN9IGZyb20gXCIuL3V0aWxzXCI7XG5cbmV4cG9ydCBjbGFzcyBDYWNoZUVudHJ5IHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgcG9saWN5OiBcInB1bGxcIiB8IFwicHVsbC1wdXNoXCIgfCBcInB1c2hcIjtcbiAgICBwdWJsaWMgcmVhZG9ubHkga2V5OiBzdHJpbmcgfCB7IGZpbGVzOiBzdHJpbmdbXSB9O1xuICAgIHB1YmxpYyByZWFkb25seSBwYXRoczogc3RyaW5nW107XG5cbiAgICBjb25zdHJ1Y3RvcihrZXk6IHN0cmluZyB8IHsgZmlsZXM6IHN0cmluZ1tdIH0sIHBhdGhzOiBzdHJpbmdbXSwgcG9saWN5OiBcInB1bGxcIiB8IFwicHVsbC1wdXNoXCIgfCBcInB1c2hcIikge1xuICAgICAgICB0aGlzLmtleSA9IGtleTtcbiAgICAgICAgdGhpcy5wb2xpY3kgPSBwb2xpY3k7XG4gICAgICAgIHRoaXMucGF0aHMgPSBwYXRocztcbiAgICB9XG5cbiAgICBhc3luYyBnZXRVbmlxdWVDYWNoZU5hbWUoY3dkOiBzdHJpbmcsIGVudjogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSkge1xuICAgICAgICBpZiAodHlwZW9mIHRoaXMua2V5ID09PSBcInN0cmluZ1wiIHx8IHRoaXMua2V5ID09IG51bGwpIHtcbiAgICAgICAgICAgIHJldHVybiBVdGlscy5leHBhbmRUZXh0KHRoaXMua2V5ID8/IFwiZGVmYXVsdFwiKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gXCJtZC1cIiArIGF3YWl0IFV0aWxzLmNoZWNrc3VtRmlsZXModGhpcy5rZXkuZmlsZXMubWFwKGYgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIGAke2N3ZH0vJHtVdGlscy5leHBhbmRUZXh0KGYsIGVudil9YDtcbiAgICAgICAgfSkpO1xuICAgIH1cblxufVxuIl19
|
package/src/commander.js
CHANGED
|
@@ -8,17 +8,18 @@ exports.Commander = void 0;
|
|
|
8
8
|
const chalk_1 = __importDefault(require("chalk"));
|
|
9
9
|
const utils_1 = require("./utils");
|
|
10
10
|
const job_executor_1 = require("./job-executor");
|
|
11
|
+
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
11
12
|
class Commander {
|
|
12
|
-
static async runPipeline(parser, writeStreams, manualOpts, privileged) {
|
|
13
|
+
static async runPipeline(parser, writeStreams, manualOpts, privileged, cwd) {
|
|
13
14
|
const jobs = parser.jobs;
|
|
14
15
|
const stages = parser.stages;
|
|
15
16
|
let potentialStarters = [...jobs.values()];
|
|
16
17
|
potentialStarters = potentialStarters.filter(j => j.when !== "never");
|
|
17
18
|
potentialStarters = potentialStarters.filter(j => j.when !== "manual" || manualOpts.includes(j.name));
|
|
18
19
|
await job_executor_1.JobExecutor.runLoop(jobs, stages, potentialStarters, manualOpts, privileged);
|
|
19
|
-
await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad);
|
|
20
|
+
await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad, cwd);
|
|
20
21
|
}
|
|
21
|
-
static async runSingleJob(parser, writeStreams, jobArgs, needs, manualOpts, privileged) {
|
|
22
|
+
static async runSingleJob(parser, writeStreams, jobArgs, needs, manualOpts, privileged, cwd) {
|
|
22
23
|
const jobs = parser.jobs;
|
|
23
24
|
const stages = parser.stages;
|
|
24
25
|
let potentialStarters = [];
|
|
@@ -32,7 +33,7 @@ class Commander {
|
|
|
32
33
|
potentialStarters.push(job);
|
|
33
34
|
});
|
|
34
35
|
await job_executor_1.JobExecutor.runLoop(jobPoolMap, stages, potentialStarters, manualOpts, privileged);
|
|
35
|
-
await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad);
|
|
36
|
+
await Commander.printReport(writeStreams, jobs, stages, parser.jobNamePad, cwd);
|
|
36
37
|
}
|
|
37
38
|
static runList(parser, writeStreams, listAll) {
|
|
38
39
|
const stages = parser.stages;
|
|
@@ -68,7 +69,7 @@ class Commander {
|
|
|
68
69
|
}
|
|
69
70
|
exports.Commander = Commander;
|
|
70
71
|
_a = Commander;
|
|
71
|
-
Commander.printReport = async (writeStreams, jobs, stages, jobNamePad) => {
|
|
72
|
+
Commander.printReport = async (writeStreams, jobs, stages, jobNamePad, cwd) => {
|
|
72
73
|
writeStreams.stdout("\n");
|
|
73
74
|
const preScripts = {
|
|
74
75
|
successful: [],
|
|
@@ -110,10 +111,15 @@ Commander.printReport = async (writeStreams, jobs, stages, jobNamePad) => {
|
|
|
110
111
|
}
|
|
111
112
|
if (preScripts.warned.length !== 0) {
|
|
112
113
|
preScripts.warned.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));
|
|
113
|
-
|
|
114
|
+
for (const { name } of preScripts.warned) {
|
|
114
115
|
const namePad = name.padEnd(jobNamePad);
|
|
116
|
+
const safeName = utils_1.Utils.getSafeJobName(name);
|
|
115
117
|
writeStreams.stdout((0, chalk_1.default) `{black.bgYellowBright WARN } {blueBright ${namePad}} pre_script\n`);
|
|
116
|
-
|
|
118
|
+
const outputLog = await fs_extra_1.default.readFile(`${cwd}/.gitlab-ci-local/output/${safeName}.log`, "utf8");
|
|
119
|
+
for (const line of outputLog.split(/\r?\n/).filter(j => !j.includes("[32m$ ")).filter(j => j !== "").slice(-3)) {
|
|
120
|
+
writeStreams.stdout((0, chalk_1.default) ` {yellow >} ${line}\n`);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
117
123
|
}
|
|
118
124
|
if (afterScripts.warned.length !== 0) {
|
|
119
125
|
afterScripts.warned.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));
|
|
@@ -124,10 +130,15 @@ Commander.printReport = async (writeStreams, jobs, stages, jobNamePad) => {
|
|
|
124
130
|
}
|
|
125
131
|
if (preScripts.failed.length !== 0) {
|
|
126
132
|
preScripts.failed.sort((a, b) => stages.indexOf(a.stage) - stages.indexOf(b.stage));
|
|
127
|
-
|
|
133
|
+
for (const { name } of preScripts.failed) {
|
|
128
134
|
const namePad = name.padEnd(jobNamePad);
|
|
135
|
+
const safeName = utils_1.Utils.getSafeJobName(name);
|
|
129
136
|
writeStreams.stdout((0, chalk_1.default) `{black.bgRed FAIL } {blueBright ${namePad}}\n`);
|
|
130
|
-
|
|
137
|
+
const outputLog = await fs_extra_1.default.readFile(`${cwd}/.gitlab-ci-local/output/${safeName}.log`, "utf8");
|
|
138
|
+
for (const line of outputLog.split(/\r?\n/).filter(j => !j.includes("[32m$ ")).filter(j => j !== "").slice(-3)) {
|
|
139
|
+
writeStreams.stdout((0, chalk_1.default) ` {red >} ${line}\n`);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
131
142
|
}
|
|
132
143
|
for (const job of preScripts.successful) {
|
|
133
144
|
const e = job.environment;
|
|
@@ -143,4 +154,4 @@ Commander.printReport = async (writeStreams, jobs, stages, jobNamePad) => {
|
|
|
143
154
|
writeStreams.stdout(" }\n");
|
|
144
155
|
}
|
|
145
156
|
};
|
|
146
|
-
//# 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\";\n\nexport class Commander {\n\n    static async runPipeline(parser: Parser, writeStreams: WriteStreams, manualOpts: string[], privileged: boolean) {\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);\n    }\n\n    static async runSingleJob(parser: Parser, writeStreams: WriteStreams, jobArgs: string[], needs: boolean, manualOpts: string[], privileged: boolean) {\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);\n    }\n\n    static printReport = async (writeStreams: WriteStreams, jobs: ReadonlyMap<string, Job>, stages: readonly string[], jobNamePad: number) => {\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            preScripts.warned.forEach(({name}) => {\n                const namePad = name.padEnd(jobNamePad);\n                writeStreams.stdout(chalk`{black.bgYellowBright  WARN } {blueBright ${namePad}}  pre_script\\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            preScripts.failed.forEach(({name}) => {\n                const namePad = name.padEnd(jobNamePad);\n                writeStreams.stdout(chalk`{black.bgRed  FAIL } {blueBright ${namePad}}\\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"]}
|
|
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"]}
|
package/src/git-data.js
CHANGED
|
@@ -9,10 +9,24 @@ const asserts_1 = require("./asserts");
|
|
|
9
9
|
const chalk_1 = __importDefault(require("chalk"));
|
|
10
10
|
const exit_error_1 = require("./types/exit-error");
|
|
11
11
|
class GitData {
|
|
12
|
-
constructor(
|
|
13
|
-
this.
|
|
14
|
-
|
|
15
|
-
|
|
12
|
+
constructor() {
|
|
13
|
+
this.user = {
|
|
14
|
+
GITLAB_USER_LOGIN: "local",
|
|
15
|
+
GITLAB_USER_EMAIL: "local@gitlab.com",
|
|
16
|
+
GITLAB_USER_NAME: "Bob Local",
|
|
17
|
+
GITLAB_USER_ID: "1000",
|
|
18
|
+
};
|
|
19
|
+
this.remote = {
|
|
20
|
+
port: "22",
|
|
21
|
+
host: "gitlab.com",
|
|
22
|
+
group: "fallback.group",
|
|
23
|
+
project: "fallback.project",
|
|
24
|
+
};
|
|
25
|
+
this.commit = {
|
|
26
|
+
REF_NAME: "main",
|
|
27
|
+
SHA: "0000000000000000000000000000000000000000",
|
|
28
|
+
SHORT_SHA: "00000000",
|
|
29
|
+
};
|
|
16
30
|
}
|
|
17
31
|
get CI_PROJECT_PATH() {
|
|
18
32
|
return `${this.remote.group}/${this.remote.project}`;
|
|
@@ -27,95 +41,77 @@ class GitData {
|
|
|
27
41
|
return `${this.remote.group.replace(/\//g, "-")}-${this.remote.project}`;
|
|
28
42
|
}
|
|
29
43
|
static async init(cwd, writeStreams) {
|
|
44
|
+
const gitData = new GitData();
|
|
30
45
|
try {
|
|
31
46
|
const gitVersion = (await utils_1.Utils.spawn("git --version", cwd)).stdout.trimEnd();
|
|
32
47
|
(0, asserts_1.assert)(gitVersion != null, "We do not think it is safe to use git without a proper version string!");
|
|
33
48
|
}
|
|
34
49
|
catch (e) {
|
|
35
50
|
writeStreams.stderr((0, chalk_1.default) `{yellow Git not available using fallback}\n`);
|
|
36
|
-
return
|
|
51
|
+
return gitData;
|
|
37
52
|
}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
});
|
|
53
|
+
await gitData.initCommitData(cwd, writeStreams);
|
|
54
|
+
await gitData.initRemoteData(cwd, writeStreams);
|
|
55
|
+
await gitData.initUserData(cwd, writeStreams);
|
|
56
|
+
return gitData;
|
|
43
57
|
}
|
|
44
|
-
|
|
58
|
+
async initCommitData(cwd, writeStreams) {
|
|
45
59
|
try {
|
|
46
60
|
const gitLogStdout = (await utils_1.Utils.spawn("git log -1 --pretty=format:'%h %H %D'", cwd)).stdout.replace(/\r?\n/g, "");
|
|
47
61
|
const gitLogMatch = gitLogStdout.match(/(?<short_sha>\S*?) (?<sha>\S*) .*HEAD( -> |, tag: |, )(?<ref_name>.*?)(?:,|$)/);
|
|
48
62
|
(0, asserts_1.assert)(gitLogMatch?.groups != null, "git log -1 didn't provide valid matches");
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
SHORT_SHA: gitLogMatch.groups.short_sha,
|
|
53
|
-
};
|
|
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;
|
|
54
66
|
}
|
|
55
67
|
catch (e) {
|
|
56
68
|
if (e instanceof exit_error_1.ExitError) {
|
|
57
69
|
writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
58
|
-
return
|
|
70
|
+
return;
|
|
59
71
|
}
|
|
60
72
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git commit data}\n`);
|
|
61
|
-
return this.defaultData.commit;
|
|
62
73
|
}
|
|
63
74
|
}
|
|
64
|
-
|
|
75
|
+
async initRemoteData(cwd, writeStreams) {
|
|
65
76
|
try {
|
|
66
77
|
const { stdout: gitRemote } = await utils_1.Utils.spawn("git remote -v", cwd);
|
|
67
78
|
const gitRemoteMatch = gitRemote.match(/.*(?:\/\/|@)(?<host>[^:/]*)(:(?<port>\d+)\/|:|\/)(?<group>.*)\/(?<project>.*?)(?:\r?\n|\.git)/);
|
|
68
79
|
(0, asserts_1.assert)(gitRemoteMatch?.groups != null, "git remote -v didn't provide valid matches");
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
project: gitRemoteMatch.groups.project,
|
|
74
|
-
};
|
|
80
|
+
this.remote.port = gitRemoteMatch.groups.port ?? "22";
|
|
81
|
+
this.remote.host = gitRemoteMatch.groups.host;
|
|
82
|
+
this.remote.group = gitRemoteMatch.groups.group;
|
|
83
|
+
this.remote.project = gitRemoteMatch.groups.project;
|
|
75
84
|
}
|
|
76
85
|
catch (e) {
|
|
77
86
|
if (e instanceof exit_error_1.ExitError) {
|
|
78
87
|
writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
79
|
-
return
|
|
88
|
+
return;
|
|
80
89
|
}
|
|
81
90
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git remote data}\n`);
|
|
82
|
-
return this.defaultData.remote;
|
|
83
91
|
}
|
|
84
92
|
}
|
|
85
|
-
|
|
93
|
+
async initUserData(cwd, writeStreams) {
|
|
94
|
+
try {
|
|
95
|
+
this.user.GITLAB_USER_NAME = (await utils_1.Utils.spawn("git config user.name", cwd)).stdout.trimEnd();
|
|
96
|
+
}
|
|
97
|
+
catch (e) {
|
|
98
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git user.name}\n`);
|
|
99
|
+
}
|
|
86
100
|
try {
|
|
87
101
|
const email = (await utils_1.Utils.spawn("git config user.email", cwd)).stdout.trimEnd();
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
102
|
+
this.user.GITLAB_USER_EMAIL = email;
|
|
103
|
+
this.user.GITLAB_USER_LOGIN = email.replace(/@.*/, "");
|
|
104
|
+
}
|
|
105
|
+
catch (e) {
|
|
106
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git user.email}\n`);
|
|
107
|
+
}
|
|
108
|
+
try {
|
|
109
|
+
this.user.GITLAB_USER_ID = (await utils_1.Utils.spawn("id -u", cwd)).stdout.trimEnd();
|
|
94
110
|
}
|
|
95
111
|
catch (e) {
|
|
96
|
-
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback
|
|
97
|
-
return this.defaultData.user;
|
|
112
|
+
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback linux user id}\n`);
|
|
98
113
|
}
|
|
99
114
|
}
|
|
100
115
|
}
|
|
101
116
|
exports.GitData = GitData;
|
|
102
|
-
GitData.defaultData = new GitData({
|
|
103
|
-
user: {
|
|
104
|
-
GITLAB_USER_LOGIN: "local",
|
|
105
|
-
GITLAB_USER_EMAIL: "local@gitlab.com",
|
|
106
|
-
GITLAB_USER_NAME: "Bob Local",
|
|
107
|
-
GITLAB_USER_ID: "1000",
|
|
108
|
-
},
|
|
109
|
-
remote: {
|
|
110
|
-
port: "22",
|
|
111
|
-
host: "gitlab.com",
|
|
112
|
-
group: "fallback.group",
|
|
113
|
-
project: "fallback.project",
|
|
114
|
-
},
|
|
115
|
-
commit: {
|
|
116
|
-
REF_NAME: "main",
|
|
117
|
-
SHA: "0000000000000000000000000000000000000000",
|
|
118
|
-
SHORT_SHA: "00000000",
|
|
119
|
-
},
|
|
120
|
-
});
|
|
121
|
-
//# 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\ninterface GitRemote {\n    port: string;\n    host: string;\n    group: string;\n    project: string;\n}\n\ninterface GitCommit {\n    SHA: string;\n    SHORT_SHA: string;\n    REF_NAME: string;\n}\n\ninterface GitUser {\n    GITLAB_USER_EMAIL: string;\n    GITLAB_USER_LOGIN: string;\n    GITLAB_USER_NAME: string;\n    GITLAB_USER_ID: string;\n}\n\nexport class GitData {\n\n    static readonly defaultData: GitData =\n        new GitData({\n            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            remote: {\n                port: \"22\",\n                host: \"gitlab.com\",\n                group: \"fallback.group\",\n                project: \"fallback.project\",\n            },\n            commit: {\n                REF_NAME: \"main\",\n                SHA: \"0000000000000000000000000000000000000000\",\n                SHORT_SHA: \"00000000\",\n            },\n        });\n\n    readonly remote: GitRemote;\n    readonly commit: GitCommit;\n    readonly user: GitUser;\n\n    constructor(data: { remote: GitRemote; commit: GitCommit; user: GitUser }) {\n        this.remote = data.remote;\n        this.commit = data.commit;\n        this.user = data.user;\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        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 this.defaultData;\n        }\n\n        return new GitData({\n            user: await GitData.getUserData(cwd, writeStreams),\n            remote: await GitData.getRemoteData(cwd, writeStreams),\n            commit: await GitData.getCommitData(cwd, writeStreams),\n        });\n    }\n\n    static async getCommitData(cwd: string, writeStreams: WriteStreams): Promise<GitCommit> {\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            return {\n                REF_NAME: gitLogMatch.groups.ref_name,\n                SHA: gitLogMatch.groups.sha,\n                SHORT_SHA: gitLogMatch.groups.short_sha,\n            };\n        } catch (e) {\n            if (e instanceof ExitError) {\n                writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n                return this.defaultData.commit;\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git commit data}\\n`);\n            return this.defaultData.commit;\n        }\n    }\n\n    static async getRemoteData(cwd: string, writeStreams: WriteStreams): Promise<GitRemote> {\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            return {\n                port: gitRemoteMatch.groups.port ?? \"22\",\n                host: gitRemoteMatch.groups.host,\n                group: gitRemoteMatch.groups.group,\n                project: gitRemoteMatch.groups.project,\n            };\n        } catch (e) {\n            if (e instanceof ExitError) {\n                writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\n                return this.defaultData.remote;\n            }\n            writeStreams.stderr(chalk`{yellow Using fallback git remote data}\\n`);\n            return this.defaultData.remote;\n        }\n    }\n\n    static async getUserData(cwd: string, writeStreams: WriteStreams): Promise<GitUser> {\n        try {\n            const email = (await Utils.spawn(\"git config user.email\", cwd)).stdout.trimEnd();\n\n            return {\n                GITLAB_USER_NAME: (await Utils.spawn(\"git config user.name\", cwd)).stdout.trimEnd(),\n                GITLAB_USER_ID: (await Utils.spawn(\"id -u\", cwd)).stdout.trimEnd(),\n                GITLAB_USER_EMAIL: email,\n                GITLAB_USER_LOGIN: email.replace(/@.*/, \"\"),\n            };\n        } catch (e) {\n            writeStreams.stderr(chalk`{yellow Using fallback git user data}\\n`);\n            return this.defaultData.user;\n        }\n    }\n}\n"]}
|
|
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"]}
|