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 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.26.3",
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.0",
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.20",
34
- "yargs": "^17.2.1"
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.2",
40
+ "@types/jest": "27.0.3",
42
41
  "@types/jest-when": "2.7.3",
43
- "@types/js-yaml": "4.0.4",
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.5",
48
- "@typescript-eslint/eslint-plugin": "5.3.1",
49
- "@typescript-eslint/parser": "5.3.1",
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.2.0",
52
- "jest": "27.3.1",
53
- "jest-when": "3.4.2",
54
- "pkg": "5.4.1",
55
- "ts-jest": "27.0.7",
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.4.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
- preScripts.warned.forEach(({ name }) => {
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
- preScripts.failed.forEach(({ name }) => {
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(data) {
13
- this.remote = data.remote;
14
- this.commit = data.commit;
15
- this.user = data.user;
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 this.defaultData;
51
+ return gitData;
37
52
  }
38
- return new GitData({
39
- user: await GitData.getUserData(cwd, writeStreams),
40
- remote: await GitData.getRemoteData(cwd, writeStreams),
41
- commit: await GitData.getCommitData(cwd, writeStreams),
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
- static async getCommitData(cwd, writeStreams) {
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
- return {
50
- REF_NAME: gitLogMatch.groups.ref_name,
51
- SHA: gitLogMatch.groups.sha,
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 this.defaultData.commit;
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
- static async getRemoteData(cwd, writeStreams) {
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
- return {
70
- port: gitRemoteMatch.groups.port ?? "22",
71
- host: gitRemoteMatch.groups.host,
72
- group: gitRemoteMatch.groups.group,
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 this.defaultData.remote;
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
- static async getUserData(cwd, writeStreams) {
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
- return {
89
- GITLAB_USER_NAME: (await utils_1.Utils.spawn("git config user.name", cwd)).stdout.trimEnd(),
90
- GITLAB_USER_ID: (await utils_1.Utils.spawn("id -u", cwd)).stdout.trimEnd(),
91
- GITLAB_USER_EMAIL: email,
92
- GITLAB_USER_LOGIN: email.replace(/@.*/, ""),
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 git user data}\n`);
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"]}