gitlab-ci-local 4.27.0 → 4.28.2

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
@@ -34,6 +34,7 @@ Get rid of all those dev specific shell scripts and make files.
34
34
  * [Home Variables](#home-variables)
35
35
  * [Project Variables](#project-variables)
36
36
  * [Decorators](#decorators)
37
+ * [Includes](#includes)
37
38
  * [Artifacts](#artifacts)
38
39
  * [Development](#development)
39
40
  * [Scripts](#scripts)
@@ -205,6 +206,9 @@ produce:
205
206
  artifacts: {paths: [path/] }
206
207
  ```
207
208
 
209
+ ### Includes
210
+ Includes from external sources are only fetched once. Use `--fetch-includes` to invoke an external fetching rutine.
211
+
208
212
  ### Artifacts
209
213
 
210
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.27.0",
6
+ "version": "4.28.2",
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",
@@ -12,7 +12,7 @@
12
12
  "pkg-all": "npm run pkg-linux && npm run pkg-macos && npm run pkg-win",
13
13
  "pkg": "pkg",
14
14
  "build": "rm -f src/*.js src/*.d.ts && tsc",
15
- "check-all": "npm run build && npm run lint && npm run coverage && npm run audit",
15
+ "check-all": "npm run build && npm run lint && npm run coverage",
16
16
  "audit": "npm audit --parseable",
17
17
  "lint": "npx eslint .",
18
18
  "test": "jest --testTimeout 30000",
@@ -20,39 +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
+ "axios": "^0.25.0",
24
24
  "base64url": "^3.0.1",
25
- "camelcase": "^6.2.1",
25
+ "camelcase": "^6.3.0",
26
26
  "chalk": "^4.1.2",
27
27
  "checksum": "^1.0.0",
28
28
  "deep-extend": "^0.6.0",
29
- "dotenv": "^10.0.0",
29
+ "dotenv": "^14.3.2",
30
30
  "fs-extra": "^10.0.0",
31
31
  "js-yaml": "^4.1.0",
32
32
  "pretty-hrtime": "^1.0.3",
33
33
  "source-map-support": "^0.5.21",
34
- "yargs": "^17.3.0"
34
+ "yargs": "^17.3.1"
35
35
  },
36
36
  "devDependencies": {
37
37
  "@types/checksum": "0.1.33",
38
38
  "@types/deep-extend": "0.4.32",
39
39
  "@types/fs-extra": "9.0.13",
40
- "@types/jest": "27.0.3",
41
- "@types/jest-when": "2.7.3",
40
+ "@types/jest": "27.4.0",
41
+ "@types/jest-when": "2.7.4",
42
42
  "@types/js-yaml": "4.0.5",
43
43
  "@types/pretty-hrtime": "1.0.1",
44
44
  "@types/source-map-support": "0.5.4",
45
- "@types/yargs": "17.0.7",
46
- "@typescript-eslint/eslint-plugin": "5.6.0",
47
- "@typescript-eslint/parser": "5.6.0",
48
- "depcheck": "1.4.2",
49
- "eslint": "8.4.1",
50
- "jest": "27.4.3",
51
- "jest-when": "3.4.2",
52
- "pkg": "5.5.1",
53
- "ts-jest": "27.1.0",
45
+ "@types/yargs": "17.0.8",
46
+ "@typescript-eslint/eslint-plugin": "5.10.1",
47
+ "@typescript-eslint/parser": "5.10.1",
48
+ "axios-mock-adapter": "1.20.0",
49
+ "depcheck": "1.4.3",
50
+ "eslint": "8.7.0",
51
+ "jest": "27.4.7",
52
+ "jest-when": "3.5.0",
53
+ "pkg": "5.5.2",
54
+ "ts-jest": "27.1.3",
54
55
  "ts-node": "10.4.0",
55
- "typescript": "4.5.2"
56
+ "typescript": "4.5.5"
56
57
  },
57
58
  "engines": {
58
59
  "node": ">=16.10.0"
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"]}
package/src/handler.js CHANGED
@@ -100,13 +100,19 @@ async function handler(argv, writeStreams) {
100
100
  variables[exec.groups.key] = exec?.groups?.value;
101
101
  }
102
102
  });
103
+ if (argv["fetch-includes"] != null && argv["fetch-includes"]) {
104
+ parser = await parser_1.Parser.create({
105
+ cwd, writeStreams, pipelineIid: 0, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache, fetchIncludes: true,
106
+ });
107
+ return new Map();
108
+ }
103
109
  if (argv.completion != null) {
104
110
  yargs.showCompletionScript();
105
111
  }
106
112
  else if (argv.preview != null) {
107
113
  const pipelineIid = await state.getPipelineIid(cwd);
108
114
  parser = await parser_1.Parser.create({
109
- cwd, writeStreams, pipelineIid, showInitMessage: false, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,
115
+ cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,
110
116
  });
111
117
  const gitlabData = parser.gitlabData;
112
118
  for (const jobName of Object.keys(gitlabData)) {
@@ -123,7 +129,7 @@ async function handler(argv, writeStreams) {
123
129
  checkFolderAndFile(cwd, argv.file);
124
130
  const pipelineIid = await state.getPipelineIid(cwd);
125
131
  parser = await parser_1.Parser.create({
126
- cwd, writeStreams, pipelineIid, showInitMessage: false, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,
132
+ cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,
127
133
  });
128
134
  commander_1.Commander.runList(parser, writeStreams, argv.listAll != null);
129
135
  }
@@ -140,7 +146,7 @@ async function handler(argv, writeStreams) {
140
146
  cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,
141
147
  });
142
148
  await utils_1.Utils.rsyncTrackedFiles(cwd, ".docker");
143
- await commander_1.Commander.runSingleJob(parser, writeStreams, argv.job, argv.needs || false, argv.manual || [], argv.privileged || false);
149
+ await commander_1.Commander.runSingleJob(parser, writeStreams, argv.job, argv.needs || false, argv.manual || [], argv.privileged || false, cwd);
144
150
  if (argv.needs === true) {
145
151
  writeStreams.stdout((0, chalk_1.default) `{grey pipeline finished} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
146
152
  }
@@ -156,7 +162,7 @@ async function handler(argv, writeStreams) {
156
162
  cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,
157
163
  });
158
164
  await utils_1.Utils.rsyncTrackedFiles(cwd, ".docker");
159
- await commander_1.Commander.runPipeline(parser, writeStreams, argv.manual || [], argv.privileged || false);
165
+ await commander_1.Commander.runPipeline(parser, writeStreams, argv.manual || [], argv.privileged || false, cwd);
160
166
  writeStreams.stdout((0, chalk_1.default) `{grey pipeline finished} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
161
167
  }
162
168
  writeStreams.flush();
@@ -166,4 +172,4 @@ async function handler(argv, writeStreams) {
166
172
  return new Map();
167
173
  }
168
174
  exports.handler = handler;
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["handler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as yaml from \"js-yaml\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as yargs from \"yargs\";\nimport {Commander} from \"./commander\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport {assert} from \"./asserts\";\nimport * as dotenv from \"dotenv\";\nimport camelCase from \"camelcase\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport {Job} from \"./job\";\nimport {Utils} from \"./utils\";\nimport {ExitError} from \"./types/exit-error\";\n\nconst checkFolderAndFile = (cwd: string, file?: string) => {\n    assert(fs.pathExistsSync(cwd), `${cwd} is not a directory`);\n\n    const gitlabFilePath = file ? `${cwd}/${file}` : `${cwd}/.gitlab-ci.yml`;\n    assert(fs.existsSync(gitlabFilePath), `${cwd} does not contain ${file ?? \".gitlab-ci.yml\"}`);\n};\n\nconst generateGitIgnore = (cwd: string) => {\n    const gitIgnoreFilePath = `${cwd}/.gitlab-ci-local/.gitignore`;\n    const gitIgnoreContent = \"*\\n!.gitignore\\n\";\n    if (!fs.existsSync(gitIgnoreFilePath)) {\n        fs.outputFileSync(gitIgnoreFilePath, gitIgnoreContent);\n    }\n};\n\nconst cleanupResources = async(parser: Parser|null) => {\n    if (!parser) {\n        process.exit(1);\n    }\n    const promises = [];\n    for (const job of parser.jobs.values()) {\n        promises.push(job.cleanupResources());\n    }\n    await Promise.all(promises);\n};\n\nexport async function handler(argv: any, writeStreams: WriteStreams): Promise<ReadonlyMap<string, Job>> {\n    assert(typeof argv.cwd != \"object\", \"--cwd option cannot be an array\");\n    const cwd = argv.cwd?.replace(/\\/$/, \"\") ?? process.cwd();\n\n    process.on(\"unhandledRejection\", async (e) => {\n        if (e instanceof ExitError) {\n            process.stderr.write(chalk`{red ${e.message}}\\n`);\n        } else if (e instanceof Error) {\n            process.stderr.write(chalk`{red ${e.stack ?? e.message}}\\n`);\n        } else if (e) {\n            process.stderr.write(chalk`{red ${e.toString()}}\\n`);\n        }\n        await cleanupResources(parser);\n        process.exit(1);\n    });\n\n    process.on(\"SIGINT\", async (_: string, code: number) => {\n        await cleanupResources(parser);\n        process.exit(code);\n    });\n\n    let parser: Parser | null = null;\n\n    if (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                argv[argKey] = value;\n            }\n        }\n    }\n\n    const volumes = typeof argv.volume == \"string\" ? argv.volume.split(\" \") : argv.volume;\n    const extraHosts = typeof argv.extraHost == \"string\" ? argv.extraHost.split(\" \") : argv.extraHost;\n    const variablePairs = typeof argv.variable == \"string\" ? argv.variable.split(\" \") : argv.variable;\n    const shellIsolation = argv.shellIsolation;\n\n    const variables: { [key: string]: string } = {};\n\n    (variablePairs ?? []).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\n    if (argv.completion != null) {\n        yargs.showCompletionScript();\n    } else if (argv.preview != null) {\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, showInitMessage: false, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,\n        });\n        const gitlabData = parser.gitlabData;\n        for (const jobName of Object.keys(gitlabData)) {\n            if (jobName === \"stages\") {\n                continue;\n            }\n            if (Job.illegalJobNames.includes(jobName) || jobName.startsWith(\".\")) {\n                delete gitlabData[jobName];\n            }\n        }\n        writeStreams.stdout(`---\\n${yaml.dump(gitlabData, {lineWidth: 160})}`);\n    } else if (argv.list != null || argv.listAll != null) {\n        checkFolderAndFile(cwd, argv.file);\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, showInitMessage: false, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,\n        });\n        Commander.runList(parser, writeStreams, argv.listAll != null);\n    } else if (argv.job) {\n        const time = process.hrtime();\n        checkFolderAndFile(cwd, argv.file);\n        generateGitIgnore(cwd);\n        if (argv.needs === true) {\n            await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n            await state.incrementPipelineIid(cwd);\n        }\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,\n        });\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runSingleJob(parser, writeStreams, argv.job, argv.needs || false, argv.manual || [], argv.privileged || false);\n        if (argv.needs === true) {\n            writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n    } else {\n        const time = process.hrtime();\n        checkFolderAndFile(cwd, argv.file);\n        generateGitIgnore(cwd);\n        await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n        await state.incrementPipelineIid(cwd);\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,\n        });\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runPipeline(parser, writeStreams, argv.manual || [], argv.privileged || false);\n        writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    }\n    writeStreams.flush();\n\n    if (parser) {\n        return parser.jobs;\n    }\n\n    return new Map<string, Job>();\n}\n\n"]}
175
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["handler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as yaml from \"js-yaml\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as yargs from \"yargs\";\nimport {Commander} from \"./commander\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport {assert} from \"./asserts\";\nimport * as dotenv from \"dotenv\";\nimport camelCase from \"camelcase\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {WriteStreams} from \"./types/write-streams\";\nimport {Job} from \"./job\";\nimport {Utils} from \"./utils\";\nimport {ExitError} from \"./types/exit-error\";\n\nconst checkFolderAndFile = (cwd: string, file?: string) => {\n    assert(fs.pathExistsSync(cwd), `${cwd} is not a directory`);\n\n    const gitlabFilePath = file ? `${cwd}/${file}` : `${cwd}/.gitlab-ci.yml`;\n    assert(fs.existsSync(gitlabFilePath), `${cwd} does not contain ${file ?? \".gitlab-ci.yml\"}`);\n};\n\nconst generateGitIgnore = (cwd: string) => {\n    const gitIgnoreFilePath = `${cwd}/.gitlab-ci-local/.gitignore`;\n    const gitIgnoreContent = \"*\\n!.gitignore\\n\";\n    if (!fs.existsSync(gitIgnoreFilePath)) {\n        fs.outputFileSync(gitIgnoreFilePath, gitIgnoreContent);\n    }\n};\n\nconst cleanupResources = async(parser: Parser|null) => {\n    if (!parser) {\n        process.exit(1);\n    }\n    const promises = [];\n    for (const job of parser.jobs.values()) {\n        promises.push(job.cleanupResources());\n    }\n    await Promise.all(promises);\n};\n\nexport async function handler(argv: any, writeStreams: WriteStreams): Promise<ReadonlyMap<string, Job>> {\n    assert(typeof argv.cwd != \"object\", \"--cwd option cannot be an array\");\n    const cwd = argv.cwd?.replace(/\\/$/, \"\") ?? process.cwd();\n\n    process.on(\"unhandledRejection\", async (e) => {\n        if (e instanceof ExitError) {\n            process.stderr.write(chalk`{red ${e.message}}\\n`);\n        } else if (e instanceof Error) {\n            process.stderr.write(chalk`{red ${e.stack ?? e.message}}\\n`);\n        } else if (e) {\n            process.stderr.write(chalk`{red ${e.toString()}}\\n`);\n        }\n        await cleanupResources(parser);\n        process.exit(1);\n    });\n\n    process.on(\"SIGINT\", async (_: string, code: number) => {\n        await cleanupResources(parser);\n        process.exit(code);\n    });\n\n    let parser: Parser | null = null;\n\n    if (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                argv[argKey] = value;\n            }\n        }\n    }\n\n    const volumes = typeof argv.volume == \"string\" ? argv.volume.split(\" \") : argv.volume;\n    const extraHosts = typeof argv.extraHost == \"string\" ? argv.extraHost.split(\" \") : argv.extraHost;\n    const variablePairs = typeof argv.variable == \"string\" ? argv.variable.split(\" \") : argv.variable;\n    const shellIsolation = argv.shellIsolation;\n\n    const variables: { [key: string]: string } = {};\n\n    (variablePairs ?? []).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\n    if (argv[\"fetch-includes\"] != null && argv[\"fetch-includes\"]) {\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid: 0, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache, fetchIncludes: true,\n        });\n        return new Map<string, Job>();\n    }\n\n    if (argv.completion != null) {\n        yargs.showCompletionScript();\n    } else if (argv.preview != null) {\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,\n        });\n        const gitlabData = parser.gitlabData;\n        for (const jobName of Object.keys(gitlabData)) {\n            if (jobName === \"stages\") {\n                continue;\n            }\n            if (Job.illegalJobNames.includes(jobName) || jobName.startsWith(\".\")) {\n                delete gitlabData[jobName];\n            }\n        }\n        writeStreams.stdout(`---\\n${yaml.dump(gitlabData, {lineWidth: 160})}`);\n    } else if (argv.list != null || argv.listAll != null) {\n        checkFolderAndFile(cwd, argv.file);\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,\n        });\n        Commander.runList(parser, writeStreams, argv.listAll != null);\n    } else if (argv.job) {\n        const time = process.hrtime();\n        checkFolderAndFile(cwd, argv.file);\n        generateGitIgnore(cwd);\n        if (argv.needs === true) {\n            await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n            await state.incrementPipelineIid(cwd);\n        }\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,\n        });\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runSingleJob(parser, writeStreams, argv.job, argv.needs || false, argv.manual || [], argv.privileged || false, cwd);\n        if (argv.needs === true) {\n            writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n    } else {\n        const time = process.hrtime();\n        checkFolderAndFile(cwd, argv.file);\n        generateGitIgnore(cwd);\n        await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);\n        await state.incrementPipelineIid(cwd);\n        const pipelineIid = await state.getPipelineIid(cwd);\n        parser = await Parser.create({\n            cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,\n        });\n        await Utils.rsyncTrackedFiles(cwd, \".docker\");\n        await Commander.runPipeline(parser, writeStreams, argv.manual || [], argv.privileged || false, cwd);\n        writeStreams.stdout(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    }\n    writeStreams.flush();\n\n    if (parser) {\n        return parser.jobs;\n    }\n\n    return new Map<string, Job>();\n}\n\n"]}