gitlab-ci-local 4.41.2 → 4.43.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/src/handler.js CHANGED
@@ -38,7 +38,7 @@ const pretty_hrtime_1 = __importDefault(require("pretty-hrtime"));
38
38
  const job_1 = require("./job");
39
39
  const utils_1 = require("./utils");
40
40
  const argv_1 = require("./argv");
41
- const assert_1 = __importStar(require("assert"));
41
+ const assert_1 = __importDefault(require("assert"));
42
42
  const generateGitIgnore = (cwd, stateDir) => {
43
43
  const gitIgnoreFilePath = `${cwd}/${stateDir}/.gitignore`;
44
44
  const gitIgnoreContent = "*\n!.gitignore\n";
@@ -46,57 +46,24 @@ const generateGitIgnore = (cwd, stateDir) => {
46
46
  fs.outputFileSync(gitIgnoreFilePath, gitIgnoreContent);
47
47
  }
48
48
  };
49
- const cleanupResources = async (parser) => {
50
- if (!parser) {
51
- return;
52
- }
53
- const promises = [];
54
- for (const job of parser.jobs.values()) {
55
- promises.push(job.cleanupResources());
56
- }
57
- await Promise.all(promises);
58
- };
59
- async function handler(args, writeStreams) {
49
+ async function handler(args, writeStreams, jobs = []) {
60
50
  const argv = new argv_1.Argv(args);
61
51
  const cwd = argv.cwd;
62
52
  const stateDir = argv.stateDir;
63
53
  const file = argv.file;
64
54
  let parser = null;
65
- process.on("unhandledRejection", (e) => {
66
- if (e instanceof assert_1.AssertionError) {
67
- process.stderr.write((0, chalk_1.default) `{red ${e.message.trim()}}\n`);
68
- }
69
- else if (e instanceof Error) {
70
- process.stderr.write((0, chalk_1.default) `{red ${e.stack?.trim() ?? e.message.trim()}}\n`);
71
- }
72
- else if (e) {
73
- process.stderr.write((0, chalk_1.default) `{red ${e.toString().trim()}}\n`);
74
- }
75
- if (parser) {
76
- cleanupResources(parser).finally(process.exit(1));
77
- }
78
- else {
79
- process.exit(1);
80
- }
81
- });
82
- process.on("exit", (_, code) => {
83
- cleanupResources(parser).finally(process.exit(code));
84
- });
85
- process.on("SIGINT", (_, code) => {
86
- cleanupResources(parser).finally(process.exit(code));
87
- });
88
55
  if (argv.completion) {
89
56
  yargs.showCompletionScript();
90
57
  return [];
91
58
  }
92
59
  (0, assert_1.default)(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);
93
60
  if (argv.fetchIncludes) {
94
- parser = await parser_1.Parser.create(argv, writeStreams, 0);
61
+ await parser_1.Parser.create(argv, writeStreams, 0, jobs);
95
62
  return [];
96
63
  }
97
64
  if (argv.preview) {
98
65
  const pipelineIid = await state.getPipelineIid(cwd, stateDir);
99
- parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
66
+ parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid, jobs);
100
67
  const gitlabData = parser.gitlabData;
101
68
  for (const jobName of Object.keys(gitlabData)) {
102
69
  if (jobName === "stages") {
@@ -110,17 +77,17 @@ async function handler(args, writeStreams) {
110
77
  }
111
78
  else if (argv.list || argv.listAll) {
112
79
  const pipelineIid = await state.getPipelineIid(cwd, stateDir);
113
- parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
80
+ parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid, jobs);
114
81
  commander_1.Commander.runList(parser, writeStreams, argv.listAll);
115
82
  }
116
83
  else if (argv.listJson) {
117
84
  const pipelineIid = await state.getPipelineIid(cwd, stateDir);
118
- parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
85
+ parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid, jobs);
119
86
  commander_1.Commander.runJson(parser, writeStreams);
120
87
  }
121
88
  else if (argv.listCsv || argv.listCsvAll) {
122
89
  const pipelineIid = await state.getPipelineIid(cwd, stateDir);
123
- parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
90
+ parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid, jobs);
124
91
  commander_1.Commander.runCsv(parser, writeStreams, argv.listCsvAll);
125
92
  }
126
93
  else if (argv.job.length > 0) {
@@ -132,7 +99,7 @@ async function handler(args, writeStreams) {
132
99
  await state.incrementPipelineIid(cwd, stateDir);
133
100
  }
134
101
  const pipelineIid = await state.getPipelineIid(cwd, stateDir);
135
- parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
102
+ parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid, jobs);
136
103
  await utils_1.Utils.rsyncTrackedFiles(cwd, stateDir, ".docker");
137
104
  await commander_1.Commander.runJobs(argv, parser, writeStreams);
138
105
  if (argv.needs || argv.onlyNeeds) {
@@ -143,7 +110,7 @@ async function handler(args, writeStreams) {
143
110
  generateGitIgnore(cwd, stateDir);
144
111
  const time = process.hrtime();
145
112
  const pipelineIid = await state.getPipelineIid(cwd, stateDir);
146
- parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
113
+ parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid, jobs);
147
114
  await utils_1.Utils.rsyncTrackedFiles(cwd, stateDir, ".docker");
148
115
  await commander_1.Commander.runJobsInStage(argv, parser, writeStreams);
149
116
  writeStreams.stderr((0, chalk_1.default) `{grey pipeline finished} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
@@ -154,14 +121,13 @@ async function handler(args, writeStreams) {
154
121
  await fs.remove(`${cwd}/${stateDir}/artifacts`);
155
122
  await state.incrementPipelineIid(cwd, stateDir);
156
123
  const pipelineIid = await state.getPipelineIid(cwd, stateDir);
157
- parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
124
+ parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid, jobs);
158
125
  await utils_1.Utils.rsyncTrackedFiles(cwd, stateDir, ".docker");
159
126
  await commander_1.Commander.runPipeline(argv, parser, writeStreams);
160
127
  writeStreams.stderr((0, chalk_1.default) `{grey pipeline finished} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
161
128
  }
162
129
  writeStreams.flush();
163
- await cleanupResources(parser);
164
- return parser.jobs;
130
+ return (0, job_1.cleanupJobResources)(jobs);
165
131
  }
166
132
  exports.handler = handler;
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["handler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as yaml from \"js-yaml\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as yargs from \"yargs\";\nimport {Commander} from \"./commander\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {WriteStreams} from \"./write-streams\";\nimport {Job} from \"./job\";\nimport {Utils} from \"./utils\";\nimport {Argv} from \"./argv\";\nimport assert, {AssertionError} from \"assert\";\n\nconst generateGitIgnore = (cwd: string, stateDir: string) => {\n    const gitIgnoreFilePath = `${cwd}/${stateDir}/.gitignore`;\n    const gitIgnoreContent = \"*\\n!.gitignore\\n\";\n    if (!fs.existsSync(gitIgnoreFilePath)) {\n        fs.outputFileSync(gitIgnoreFilePath, gitIgnoreContent);\n    }\n};\n\nconst cleanupResources = async (parser: Parser | null) => {\n    if (!parser) {\n        return;\n    }\n    const promises = [];\n    for (const job of parser.jobs.values()) {\n        promises.push(job.cleanupResources());\n    }\n    await Promise.all(promises);\n};\n\nexport async function handler (args: any, writeStreams: WriteStreams): Promise<ReadonlyArray<Job>> {\n    const argv = new Argv(args);\n    const cwd = argv.cwd;\n    const stateDir = argv.stateDir;\n    const file = argv.file;\n    let parser: Parser | null = null;\n\n    process.on(\"unhandledRejection\", (e) => {\n        if (e instanceof AssertionError) {\n            process.stderr.write(chalk`{red ${e.message.trim()}}\\n`);\n        } else if (e instanceof Error) {\n            process.stderr.write(chalk`{red ${e.stack?.trim() ?? e.message.trim()}}\\n`);\n        } else if (e) {\n            process.stderr.write(chalk`{red ${e.toString().trim()}}\\n`);\n        }\n        if (parser) {\n            cleanupResources(parser).finally(process.exit(1));\n        } else {\n            process.exit(1);\n        }\n    });\n\n    process.on(\"exit\", (_: string, code: number) => {\n        cleanupResources(parser).finally(process.exit(code));\n    });\n\n    process.on(\"SIGINT\", (_: string, code: number) => {\n        cleanupResources(parser).finally(process.exit(code));\n    });\n\n    if (argv.completion) {\n        yargs.showCompletionScript();\n        return [];\n    }\n\n    assert(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);\n\n    if (argv.fetchIncludes) {\n        parser = await Parser.create(argv, writeStreams, 0);\n        return [];\n    }\n\n    if (argv.preview) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        const gitlabData = parser.gitlabData;\n        for (const jobName of Object.keys(gitlabData)) {\n            if (jobName === \"stages\") {\n                continue;\n            }\n            if (Job.illegalJobNames.has(jobName) || jobName.startsWith(\".\")) {\n                delete gitlabData[jobName];\n            }\n        }\n        writeStreams.stdout(`---\\n${yaml.dump(gitlabData, {lineWidth: 160})}`);\n    } else if (argv.list || argv.listAll) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        Commander.runList(parser, writeStreams, argv.listAll);\n    } else if (argv.listJson) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        Commander.runJson(parser, writeStreams);\n    } else if (argv.listCsv || argv.listCsvAll) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        Commander.runCsv(parser, writeStreams, argv.listCsvAll);\n    } else if (argv.job.length > 0) {\n        assert(argv.stage == null, \"You cannot use --stage when starting individual jobs\");\n        generateGitIgnore(cwd, stateDir);\n        const time = process.hrtime();\n        if (argv.needs || argv.onlyNeeds) {\n            await fs.remove(`${cwd}/${stateDir}/artifacts`);\n            await state.incrementPipelineIid(cwd, stateDir);\n        }\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, stateDir, \".docker\");\n        await Commander.runJobs(argv, parser, writeStreams);\n        if (argv.needs || argv.onlyNeeds) {\n            writeStreams.stderr(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n    } else if (argv.stage) {\n        generateGitIgnore(cwd, stateDir);\n        const time = process.hrtime();\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, stateDir, \".docker\");\n        await Commander.runJobsInStage(argv, parser, writeStreams);\n        writeStreams.stderr(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    } else {\n        generateGitIgnore(cwd, stateDir);\n        const time = process.hrtime();\n        await fs.remove(`${cwd}/${stateDir}/artifacts`);\n        await state.incrementPipelineIid(cwd, stateDir);\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, stateDir, \".docker\");\n        await Commander.runPipeline(argv, parser, writeStreams);\n        writeStreams.stderr(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    }\n    writeStreams.flush();\n\n    await cleanupResources(parser);\n    return parser.jobs;\n}\n\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["handler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as yaml from \"js-yaml\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as yargs from \"yargs\";\nimport {Commander} from \"./commander\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport prettyHrtime from \"pretty-hrtime\";\nimport {WriteStreams} from \"./write-streams\";\nimport {cleanupJobResources, Job} from \"./job\";\nimport {Utils} from \"./utils\";\nimport {Argv} from \"./argv\";\nimport assert from \"assert\";\n\nconst generateGitIgnore = (cwd: string, stateDir: string) => {\n    const gitIgnoreFilePath = `${cwd}/${stateDir}/.gitignore`;\n    const gitIgnoreContent = \"*\\n!.gitignore\\n\";\n    if (!fs.existsSync(gitIgnoreFilePath)) {\n        fs.outputFileSync(gitIgnoreFilePath, gitIgnoreContent);\n    }\n};\n\nexport async function handler (args: any, writeStreams: WriteStreams, jobs: Job[] = []) {\n    const argv = new Argv(args);\n    const cwd = argv.cwd;\n    const stateDir = argv.stateDir;\n    const file = argv.file;\n    let parser: Parser | null = null;\n\n    if (argv.completion) {\n        yargs.showCompletionScript();\n        return [];\n    }\n\n    assert(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);\n\n    if (argv.fetchIncludes) {\n        await Parser.create(argv, writeStreams, 0, jobs);\n        return [];\n    }\n\n    if (argv.preview) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid, jobs);\n        const gitlabData = parser.gitlabData;\n        for (const jobName of Object.keys(gitlabData)) {\n            if (jobName === \"stages\") {\n                continue;\n            }\n            if (Job.illegalJobNames.has(jobName) || jobName.startsWith(\".\")) {\n                delete gitlabData[jobName];\n            }\n        }\n        writeStreams.stdout(`---\\n${yaml.dump(gitlabData, {lineWidth: 160})}`);\n    } else if (argv.list || argv.listAll) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid, jobs);\n        Commander.runList(parser, writeStreams, argv.listAll);\n    } else if (argv.listJson) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid, jobs);\n        Commander.runJson(parser, writeStreams);\n    } else if (argv.listCsv || argv.listCsvAll) {\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid, jobs);\n        Commander.runCsv(parser, writeStreams, argv.listCsvAll);\n    } else if (argv.job.length > 0) {\n        assert(argv.stage == null, \"You cannot use --stage when starting individual jobs\");\n        generateGitIgnore(cwd, stateDir);\n        const time = process.hrtime();\n        if (argv.needs || argv.onlyNeeds) {\n            await fs.remove(`${cwd}/${stateDir}/artifacts`);\n            await state.incrementPipelineIid(cwd, stateDir);\n        }\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid, jobs);\n        await Utils.rsyncTrackedFiles(cwd, stateDir, \".docker\");\n        await Commander.runJobs(argv, parser, writeStreams);\n        if (argv.needs || argv.onlyNeeds) {\n            writeStreams.stderr(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n        }\n    } else if (argv.stage) {\n        generateGitIgnore(cwd, stateDir);\n        const time = process.hrtime();\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid, jobs);\n        await Utils.rsyncTrackedFiles(cwd, stateDir, \".docker\");\n        await Commander.runJobsInStage(argv, parser, writeStreams);\n        writeStreams.stderr(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    } else {\n        generateGitIgnore(cwd, stateDir);\n        const time = process.hrtime();\n        await fs.remove(`${cwd}/${stateDir}/artifacts`);\n        await state.incrementPipelineIid(cwd, stateDir);\n        const pipelineIid = await state.getPipelineIid(cwd, stateDir);\n        parser = await Parser.create(argv, writeStreams, pipelineIid, jobs);\n        await Utils.rsyncTrackedFiles(cwd, stateDir, \".docker\");\n        await Commander.runPipeline(argv, parser, writeStreams);\n        writeStreams.stderr(chalk`{grey pipeline finished} in {grey ${prettyHrtime(process.hrtime(time))}}\\n`);\n    }\n    writeStreams.flush();\n\n    return cleanupJobResources(jobs);\n}\n\n"]}
package/src/index.js CHANGED
@@ -39,6 +39,14 @@ const handler_1 = require("./handler");
39
39
  const executor_1 = require("./executor");
40
40
  const argv_1 = require("./argv");
41
41
  const assert_1 = require("assert");
42
+ const job_js_1 = require("./job.js");
43
+ const jobs = [];
44
+ process.on("exit", (_, code) => {
45
+ (0, job_js_1.cleanupJobResources)(jobs).finally(process.exit(code));
46
+ });
47
+ process.on("SIGINT", (_, code) => {
48
+ (0, job_js_1.cleanupJobResources)(jobs).finally(process.exit(code));
49
+ });
42
50
  (() => {
43
51
  const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, "../package.json"), "utf8"));
44
52
  (0, yargs_1.default)(process.argv.slice(2))
@@ -49,17 +57,19 @@ const assert_1 = require("assert");
49
57
  .command({
50
58
  handler: async (argv) => {
51
59
  try {
52
- const jobs = await (0, handler_1.handler)(argv, new write_streams_1.WriteStreamsProcess());
60
+ const jobs = [];
61
+ await (0, handler_1.handler)(argv, new write_streams_1.WriteStreamsProcess(), jobs);
53
62
  const failedJobs = executor_1.Executor.getFailed(jobs);
54
63
  process.exit(failedJobs.length > 0 ? 1 : 0);
55
64
  }
56
65
  catch (e) {
57
66
  if (e instanceof assert_1.AssertionError) {
58
- process.stderr.write((0, chalk_1.default) `{red ${e.message}}\n`);
59
- process.exit(1);
67
+ process.stderr.write((0, chalk_1.default) `{red ${e.message.trim()}}\n`);
60
68
  }
61
- process.stderr.write((0, chalk_1.default) `{red ${e.stack ?? e}}\n`);
62
- process.exit(1);
69
+ else {
70
+ process.stderr.write((0, chalk_1.default) `{red ${e.stack ?? e}}\n`);
71
+ }
72
+ (0, job_js_1.cleanupJobResources)(jobs).finally(process.exit(1));
63
73
  }
64
74
  },
65
75
  builder: (y) => {
@@ -71,7 +81,7 @@ const assert_1 = require("assert");
71
81
  command: "$0 [job..]",
72
82
  describe: "Runs the entire pipeline or job's",
73
83
  })
74
- .usage("Find more information at https://github.com/firecow/gitlab-ci-local")
84
+ .usage("Find more information at https://github.com/firecow/gitlab-ci-local.\nNote: To negate an option use '--no-(option)'.")
75
85
  .strictOptions()
76
86
  .env("GCL")
77
87
  .option("manual", {
@@ -178,6 +188,7 @@ const assert_1 = require("assert");
178
188
  type: "boolean",
179
189
  description: "Sets docker user to 0:0",
180
190
  requiresArg: false,
191
+ default: true,
181
192
  })
182
193
  .option("privileged", {
183
194
  type: "boolean",
@@ -208,11 +219,13 @@ const assert_1 = require("assert");
208
219
  type: "boolean",
209
220
  description: "Copy the generated artifacts into cwd",
210
221
  requiresArg: false,
222
+ default: true,
211
223
  })
212
224
  .option("cleanup", {
213
225
  type: "boolean",
214
226
  description: "Remove docker resources after they've been used",
215
227
  requiresArg: false,
228
+ default: true,
216
229
  })
217
230
  .option("quiet", {
218
231
  type: "boolean",
@@ -224,17 +237,30 @@ const assert_1 = require("assert");
224
237
  description: "Show timestamps and job duration in the logs",
225
238
  requiresArg: false,
226
239
  })
227
- .option("maxJobNameLength", {
240
+ .option("max-job-name-length", {
228
241
  type: "number",
229
242
  description: "Maximum padding for job name (use <= 0 for no padding)",
230
243
  requiresArg: false,
231
244
  })
232
- .completion("completion", false, async (_, yargsArgv) => {
245
+ .option("concurrency", {
246
+ type: "number",
247
+ description: "Limit the number of jobs that run simultaneously",
248
+ requiresArg: false,
249
+ })
250
+ .completion("completion", false, (current, yargsArgv, completionFilter, done) => {
233
251
  try {
234
- const argv = new argv_1.Argv({ ...yargsArgv, autoCompleting: true });
235
- const pipelineIid = await state.getPipelineIid(argv.cwd, argv.stateDir);
236
- const parser = await parser_1.Parser.create(argv, new write_streams_1.WriteStreamsMock(), pipelineIid);
237
- return [...parser.jobs.values()].filter((j) => j.when != "never").map((j) => j.name);
252
+ if (current.startsWith("-")) {
253
+ completionFilter();
254
+ }
255
+ else {
256
+ const argv = new argv_1.Argv({ ...yargsArgv, autoCompleting: true });
257
+ state.getPipelineIid(argv.cwd, argv.stateDir).then((pipelineIid) => {
258
+ parser_1.Parser.create(argv, new write_streams_1.WriteStreamsMock(), pipelineIid, []).then((parser) => {
259
+ const jobNames = [...parser.jobs.values()].filter((j) => j.when != "never").map((j) => j.name);
260
+ done(jobNames);
261
+ });
262
+ });
263
+ }
238
264
  }
239
265
  catch (e) {
240
266
  return ["Parser-Failed!"];
@@ -242,4 +268,4 @@ const assert_1 = require("assert");
242
268
  })
243
269
  .parse();
244
270
  })();
245
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport \"source-map-support/register\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as path from \"path\";\nimport yargs from \"yargs\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport {WriteStreamsProcess, WriteStreamsMock} from \"./write-streams\";\nimport {handler} from \"./handler\";\nimport {Executor} from \"./executor\";\nimport {Argv} from \"./argv\";\nimport {AssertionError} from \"assert\";\n\n(() => {\n    const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, \"../package.json\"), \"utf8\"));\n    yargs(process.argv.slice(2))\n        .parserConfiguration({\"greedy-arrays\": false})\n        .showHelpOnFail(false)\n        .version(packageJson[\"version\"])\n        .wrap(yargs.terminalWidth())\n        .command({\n            handler: async (argv) => {\n                try {\n                    const jobs = await handler(argv, new WriteStreamsProcess());\n                    const failedJobs = Executor.getFailed(jobs);\n                    process.exit(failedJobs.length > 0 ? 1 : 0);\n                } catch (e: any) {\n                    if (e instanceof AssertionError) {\n                        process.stderr.write(chalk`{red ${e.message}}\\n`);\n                        process.exit(1);\n                    }\n                    process.stderr.write(chalk`{red ${e.stack ?? e}}\\n`);\n                    process.exit(1);\n                }\n            },\n            builder: (y: any) => {\n                return y.positional(\"job\", {\n                    describe: \"Jobname's to execute\",\n                    type: \"array\",\n                });\n            },\n            command: \"$0 [job..]\",\n            describe: \"Runs the entire pipeline or job's\",\n        })\n        .usage(\"Find more information at https://github.com/firecow/gitlab-ci-local\")\n        .strictOptions()\n        .env(\"GCL\")\n        .option(\"manual\", {\n            type: \"array\",\n            description: \"One or more manual jobs to run during a pipeline\",\n            requiresArg: true,\n        })\n        .option(\"list\", {\n            type: \"boolean\",\n            description: \"List job information, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-all\", {\n            type: \"boolean\",\n            description: \"List job information, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"list-json\", {\n            type: \"boolean\",\n            description: \"List job information in json format, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"list-csv\", {\n            type: \"boolean\",\n            description: \"List job information in csv format, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-csv-all\", {\n            type: \"boolean\",\n            description: \"List job information in csv format, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"preview\", {\n            type: \"boolean\",\n            description: \"Print YML with defaults, includes, extends and reference's expanded\",\n            requiresArg: false,\n        })\n        .option(\"cwd\", {\n            type: \"string\",\n            description: \"Path to a current working directory\",\n            requiresArg: true,\n        })\n        .option(\"completion\", {\n            type: \"boolean\",\n            description: \"Generate tab completion script\",\n            requiresArg: false,\n        })\n        .option(\"needs\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, when executing specific jobs\",\n            requiresArg: false,\n        })\n        .option(\"only-needs\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, except the specified jobs themselves\",\n            requiresArg: false,\n        })\n        .option(\"stage\", {\n            type: \"string\",\n            description: \"Run all jobs in a specific stage\",\n            requiresArg: false,\n        })\n        .option(\"variable\", {\n            type: \"array\",\n            description: \"Add variable to all executed jobs (--variable HELLO=world)\",\n            requiresArg: false,\n        })\n        .option(\"unset-variable\", {\n            type: \"array\",\n            description: \"Unsets a variable (--unset-variable HELLO)\",\n            requiresArg: false,\n        })\n        .option(\"remote-variables\", {\n            type: \"string\",\n            description: \"Fetch variables file from remote location\",\n            requiresArg: false,\n        })\n        .option(\"state-dir\", {\n            type: \"string\",\n            description: \"Location of the .gitlab-ci-local state dir, relative to cwd, eg. (symfony/.gitlab-ci-local/)\",\n            requiresArg: false,\n        })\n        .option(\"file\", {\n            type: \"string\",\n            description: \"Location of the .gitlab-ci.yml, relative to cwd, eg. (gitlab/.gitlab-ci.yml)\",\n            requiresArg: false,\n        })\n        .option(\"home\", {\n            type: \"string\",\n            description: \"Location of the HOME .gitlab-ci-local folder ($HOME/.gitlab-ci-local/variables.yml)\",\n            requiresArg: false,\n        })\n        .option(\"shell-isolation\", {\n            type: \"boolean\",\n            description: \"Enable artifact isolation for shell-executor jobs\",\n            requiresArg: false,\n        })\n        .option(\"mount-cache\", {\n            type: \"boolean\",\n            description: \"Enable docker mount based caching\",\n            requiresArg: false,\n        })\n        .option(\"umask\", {\n            type: \"boolean\",\n            description: \"Sets docker user to 0:0\",\n            requiresArg: false,\n        })\n        .option(\"privileged\", {\n            type: \"boolean\",\n            description: \"Set docker executor to privileged mode\",\n            requiresArg: false,\n        })\n        .option(\"ulimit\", {\n            type: \"number\",\n            description: \"Set docker executor ulimit\",\n            requiresArg: false,\n        })\n        .option(\"volume\", {\n            type: \"array\",\n            description: \"Add volumes to docker executor\",\n            requiresArg: false,\n        })\n        .option(\"extra-host\", {\n            type: \"array\",\n            description: \"Add extra docker host entries\",\n            requiresArg: false,\n        })\n        .option(\"fetch-includes\", {\n            type: \"boolean\",\n            description: \"Fetch all external includes one more time\",\n            requiresArg: false,\n        })\n        .option(\"artifacts-to-source\", {\n            type: \"boolean\",\n            description: \"Copy the generated artifacts into cwd\",\n            requiresArg: false,\n        })\n        .option(\"cleanup\", {\n            type: \"boolean\",\n            description: \"Remove docker resources after they've been used\",\n            requiresArg: false,\n        })\n        .option(\"quiet\", {\n            type: \"boolean\",\n            description: \"Suppress all job output\",\n            requiresArg: false,\n        })\n        .option(\"timestamps\", {\n            type: \"boolean\",\n            description: \"Show timestamps and job duration in the logs\",\n            requiresArg: false,\n        })\n        .option(\"maxJobNameLength\", {\n            type: \"number\",\n            description: \"Maximum padding for job name (use <= 0 for no padding)\",\n            requiresArg: false,\n        })\n        .completion(\"completion\", false, async (_, yargsArgv) => {\n            try {\n                const argv = new Argv({...yargsArgv, autoCompleting: true});\n                const pipelineIid = await state.getPipelineIid(argv.cwd, argv.stateDir);\n                const parser = await Parser.create(argv, new WriteStreamsMock(), pipelineIid);\n                return [...parser.jobs.values()].filter((j) => j.when != \"never\").map((j) => j.name);\n            } catch (e) {\n                return [\"Parser-Failed!\"];\n            }\n\n        })\n        .parse();\n})();\n\n"]}
271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport \"source-map-support/register\";\nimport chalk from \"chalk\";\nimport * as fs from \"fs-extra\";\nimport * as path from \"path\";\nimport yargs from \"yargs\";\nimport {Parser} from \"./parser\";\nimport * as state from \"./state\";\nimport {WriteStreamsProcess, WriteStreamsMock} from \"./write-streams\";\nimport {handler} from \"./handler\";\nimport {Executor} from \"./executor\";\nimport {Argv} from \"./argv\";\nimport {AssertionError} from \"assert\";\nimport {Job, cleanupJobResources} from \"./job.js\";\n\nconst jobs: Job[] = [];\n\nprocess.on(\"exit\", (_: string, code: number) => {\n    cleanupJobResources(jobs).finally(process.exit(code));\n});\nprocess.on(\"SIGINT\", (_: string, code: number) => {\n    cleanupJobResources(jobs).finally(process.exit(code));\n});\n\n(() => {\n    const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, \"../package.json\"), \"utf8\"));\n    yargs(process.argv.slice(2))\n        .parserConfiguration({\"greedy-arrays\": false})\n        .showHelpOnFail(false)\n        .version(packageJson[\"version\"])\n        .wrap(yargs.terminalWidth())\n        .command({\n            handler: async (argv) => {\n                try {\n                    const jobs: Job[] = [];\n                    await handler(argv, new WriteStreamsProcess(), jobs);\n                    const failedJobs = Executor.getFailed(jobs);\n                    process.exit(failedJobs.length > 0 ? 1 : 0);\n                } catch (e: any) {\n                    if (e instanceof AssertionError) {\n                        process.stderr.write(chalk`{red ${e.message.trim()}}\\n`);\n                    } else {\n                        process.stderr.write(chalk`{red ${e.stack ?? e}}\\n`);\n                    }\n                    cleanupJobResources(jobs).finally(process.exit(1));\n                }\n            },\n            builder: (y: any) => {\n                return y.positional(\"job\", {\n                    describe: \"Jobname's to execute\",\n                    type: \"array\",\n                });\n            },\n            command: \"$0 [job..]\",\n            describe: \"Runs the entire pipeline or job's\",\n        })\n        .usage(\"Find more information at https://github.com/firecow/gitlab-ci-local.\\nNote: To negate an option use '--no-(option)'.\")\n        .strictOptions()\n        .env(\"GCL\")\n        .option(\"manual\", {\n            type: \"array\",\n            description: \"One or more manual jobs to run during a pipeline\",\n            requiresArg: true,\n        })\n        .option(\"list\", {\n            type: \"boolean\",\n            description: \"List job information, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-all\", {\n            type: \"boolean\",\n            description: \"List job information, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"list-json\", {\n            type: \"boolean\",\n            description: \"List job information in json format, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"list-csv\", {\n            type: \"boolean\",\n            description: \"List job information in csv format, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-csv-all\", {\n            type: \"boolean\",\n            description: \"List job information in csv format, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"preview\", {\n            type: \"boolean\",\n            description: \"Print YML with defaults, includes, extends and reference's expanded\",\n            requiresArg: false,\n        })\n        .option(\"cwd\", {\n            type: \"string\",\n            description: \"Path to a current working directory\",\n            requiresArg: true,\n        })\n        .option(\"completion\", {\n            type: \"boolean\",\n            description: \"Generate tab completion script\",\n            requiresArg: false,\n        })\n        .option(\"needs\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, when executing specific jobs\",\n            requiresArg: false,\n        })\n        .option(\"only-needs\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, except the specified jobs themselves\",\n            requiresArg: false,\n        })\n        .option(\"stage\", {\n            type: \"string\",\n            description: \"Run all jobs in a specific stage\",\n            requiresArg: false,\n        })\n        .option(\"variable\", {\n            type: \"array\",\n            description: \"Add variable to all executed jobs (--variable HELLO=world)\",\n            requiresArg: false,\n        })\n        .option(\"unset-variable\", {\n            type: \"array\",\n            description: \"Unsets a variable (--unset-variable HELLO)\",\n            requiresArg: false,\n        })\n        .option(\"remote-variables\", {\n            type: \"string\",\n            description: \"Fetch variables file from remote location\",\n            requiresArg: false,\n        })\n        .option(\"state-dir\", {\n            type: \"string\",\n            description: \"Location of the .gitlab-ci-local state dir, relative to cwd, eg. (symfony/.gitlab-ci-local/)\",\n            requiresArg: false,\n        })\n        .option(\"file\", {\n            type: \"string\",\n            description: \"Location of the .gitlab-ci.yml, relative to cwd, eg. (gitlab/.gitlab-ci.yml)\",\n            requiresArg: false,\n        })\n        .option(\"home\", {\n            type: \"string\",\n            description: \"Location of the HOME .gitlab-ci-local folder ($HOME/.gitlab-ci-local/variables.yml)\",\n            requiresArg: false,\n        })\n        .option(\"shell-isolation\", {\n            type: \"boolean\",\n            description: \"Enable artifact isolation for shell-executor jobs\",\n            requiresArg: false,\n        })\n        .option(\"mount-cache\", {\n            type: \"boolean\",\n            description: \"Enable docker mount based caching\",\n            requiresArg: false,\n        })\n        .option(\"umask\", {\n            type: \"boolean\",\n            description: \"Sets docker user to 0:0\",\n            requiresArg: false,\n            default: true,\n        })\n        .option(\"privileged\", {\n            type: \"boolean\",\n            description: \"Set docker executor to privileged mode\",\n            requiresArg: false,\n        })\n        .option(\"ulimit\", {\n            type: \"number\",\n            description: \"Set docker executor ulimit\",\n            requiresArg: false,\n        })\n        .option(\"volume\", {\n            type: \"array\",\n            description: \"Add volumes to docker executor\",\n            requiresArg: false,\n        })\n        .option(\"extra-host\", {\n            type: \"array\",\n            description: \"Add extra docker host entries\",\n            requiresArg: false,\n        })\n        .option(\"fetch-includes\", {\n            type: \"boolean\",\n            description: \"Fetch all external includes one more time\",\n            requiresArg: false,\n        })\n        .option(\"artifacts-to-source\", {\n            type: \"boolean\",\n            description: \"Copy the generated artifacts into cwd\",\n            requiresArg: false,\n            default: true,\n        })\n        .option(\"cleanup\", {\n            type: \"boolean\",\n            description: \"Remove docker resources after they've been used\",\n            requiresArg: false,\n            default: true,\n        })\n        .option(\"quiet\", {\n            type: \"boolean\",\n            description: \"Suppress all job output\",\n            requiresArg: false,\n        })\n        .option(\"timestamps\", {\n            type: \"boolean\",\n            description: \"Show timestamps and job duration in the logs\",\n            requiresArg: false,\n        })\n        .option(\"max-job-name-length\", {\n            type: \"number\",\n            description: \"Maximum padding for job name (use <= 0 for no padding)\",\n            requiresArg: false,\n        })\n        .option(\"concurrency\", {\n            type: \"number\",\n            description: \"Limit the number of jobs that run simultaneously\",\n            requiresArg: false,\n        })\n        .completion(\"completion\", false, (current: string, yargsArgv: any, completionFilter: any, done: (completions: string[]) => any) => {\n            try {\n                if (current.startsWith(\"-\")) {\n                    completionFilter();\n                } else {\n                    const argv = new Argv({...yargsArgv, autoCompleting: true});\n                    state.getPipelineIid(argv.cwd, argv.stateDir).then((pipelineIid) => {\n                        Parser.create(argv, new WriteStreamsMock(), pipelineIid, []).then((parser) => {\n                            const jobNames = [...parser.jobs.values()].filter((j) => j.when != \"never\").map((j) => j.name);\n                            done(jobNames);\n                        });\n                    });\n                }\n            } catch (e) {\n                return [\"Parser-Failed!\"];\n            }\n\n        })\n        .parse();\n})();\n\n"]}