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/README.md +2 -2
- package/package.json +43 -41
- package/src/argv.js +4 -1
- package/src/data-expander.js +8 -14
- package/src/executor.js +5 -5
- package/src/git-data.js +13 -3
- package/src/handler.js +12 -46
- package/src/index.js +39 -13
- package/src/job.js +60 -47
- package/src/mutex.js +1 -1
- package/src/parser-includes.js +22 -4
- package/src/parser.js +8 -10
- package/src/producers.js +2 -2
- package/src/variables-from-files.js +4 -4
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 =
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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 =
|
|
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
|
-
|
|
62
|
-
|
|
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("
|
|
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
|
-
.
|
|
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
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,uCAAqC;AACrC,kDAA0B;AAC1B,6CAA+B;AAC/B,2CAA6B;AAC7B,kDAA0B;AAC1B,qCAAgC;AAChC,+CAAiC;AACjC,mDAAsE;AACtE,uCAAkC;AAClC,yCAAoC;AACpC,iCAA4B;AAC5B,mCAAsC;AAEtC,CAAC,GAAG,EAAE;IACF,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,iBAAiB,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;IACjG,IAAA,eAAK,EAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SACvB,mBAAmB,CAAC,EAAC,eAAe,EAAE,KAAK,EAAC,CAAC;SAC7C,cAAc,CAAC,KAAK,CAAC;SACrB,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;SAC/B,IAAI,CAAC,eAAK,CAAC,aAAa,EAAE,CAAC;SAC3B,OAAO,CAAC;QACL,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACpB,IAAI;gBACA,MAAM,IAAI,GAAG,MAAM,IAAA,iBAAO,EAAC,IAAI,EAAE,IAAI,mCAAmB,EAAE,CAAC,CAAC;gBAC5D,MAAM,UAAU,GAAG,mBAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gBAC5C,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAC/C;YAAC,OAAO,CAAM,EAAE;gBACb,IAAI,CAAC,YAAY,uBAAc,EAAE;oBAC7B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAA,eAAK,EAAA,QAAQ,CAAC,CAAC,OAAO,KAAK,CAAC,CAAC;oBAClD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACnB;gBACD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAA,eAAK,EAAA,QAAQ,CAAC,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;gBACrD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACnB;QACL,CAAC;QACD,OAAO,EAAE,CAAC,CAAM,EAAE,EAAE;YAChB,OAAO,CAAC,CAAC,UAAU,CAAC,KAAK,EAAE;gBACvB,QAAQ,EAAE,sBAAsB;gBAChC,IAAI,EAAE,OAAO;aAChB,CAAC,CAAC;QACP,CAAC;QACD,OAAO,EAAE,YAAY;QACrB,QAAQ,EAAE,mCAAmC;KAChD,CAAC;SACD,KAAK,CAAC,qEAAqE,CAAC;SAC5E,aAAa,EAAE;SACf,GAAG,CAAC,KAAK,CAAC;SACV,MAAM,CAAC,QAAQ,EAAE;QACd,IAAI,EAAE,OAAO;QACb,WAAW,EAAE,kDAAkD;QAC/D,WAAW,EAAE,IAAI;KACpB,CAAC;SACD,MAAM,CAAC,MAAM,EAAE;QACZ,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,2CAA2C;QACxD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,UAAU,EAAE;QAChB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,2CAA2C;QACxD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,WAAW,EAAE;QACjB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,0DAA0D;QACvE,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,UAAU,EAAE;QAChB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,yDAAyD;QACtE,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,cAAc,EAAE;QACpB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,yDAAyD;QACtE,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,SAAS,EAAE;QACf,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,qEAAqE;QAClF,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,KAAK,EAAE;QACX,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,qCAAqC;QAClD,WAAW,EAAE,IAAI;KACpB,CAAC;SACD,MAAM,CAAC,YAAY,EAAE;QAClB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,gCAAgC;QAC7C,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,OAAO,EAAE;QACb,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,+CAA+C;QAC5D,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,YAAY,EAAE;QAClB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,uDAAuD;QACpE,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,OAAO,EAAE;QACb,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,kCAAkC;QAC/C,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,UAAU,EAAE;QAChB,IAAI,EAAE,OAAO;QACb,WAAW,EAAE,4DAA4D;QACzE,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,gBAAgB,EAAE;QACtB,IAAI,EAAE,OAAO;QACb,WAAW,EAAE,4CAA4C;QACzD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,kBAAkB,EAAE;QACxB,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,2CAA2C;QACxD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,WAAW,EAAE;QACjB,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,8FAA8F;QAC3G,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,MAAM,EAAE;QACZ,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,8EAA8E;QAC3F,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,MAAM,EAAE;QACZ,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,qFAAqF;QAClG,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,iBAAiB,EAAE;QACvB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,mDAAmD;QAChE,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,aAAa,EAAE;QACnB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,mCAAmC;QAChD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,OAAO,EAAE;QACb,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,yBAAyB;QACtC,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,YAAY,EAAE;QAClB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,wCAAwC;QACrD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,QAAQ,EAAE;QACd,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,4BAA4B;QACzC,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,QAAQ,EAAE;QACd,IAAI,EAAE,OAAO;QACb,WAAW,EAAE,gCAAgC;QAC7C,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,YAAY,EAAE;QAClB,IAAI,EAAE,OAAO;QACb,WAAW,EAAE,+BAA+B;QAC5C,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,gBAAgB,EAAE;QACtB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,2CAA2C;QACxD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,qBAAqB,EAAE;QAC3B,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,uCAAuC;QACpD,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,SAAS,EAAE;QACf,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,iDAAiD;QAC9D,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,OAAO,EAAE;QACb,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,yBAAyB;QACtC,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,YAAY,EAAE;QAClB,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,8CAA8C;QAC3D,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,MAAM,CAAC,kBAAkB,EAAE;QACxB,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,wDAAwD;QACrE,WAAW,EAAE,KAAK;KACrB,CAAC;SACD,UAAU,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE;QACpD,IAAI;YACA,MAAM,IAAI,GAAG,IAAI,WAAI,CAAC,EAAC,GAAG,SAAS,EAAE,cAAc,EAAE,IAAI,EAAC,CAAC,CAAC;YAC5D,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YACxE,MAAM,MAAM,GAAG,MAAM,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,gCAAgB,EAAE,EAAE,WAAW,CAAC,CAAC;YAC9E,OAAO,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SACxF;QAAC,OAAO,CAAC,EAAE;YACR,OAAO,CAAC,gBAAgB,CAAC,CAAC;SAC7B;IAEL,CAAC,CAAC;SACD,KAAK,EAAE,CAAC;AACjB,CAAC,CAAC,EAAE,CAAC","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"]}
|