gitlab-ci-local 4.28.2 → 4.31.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 +40 -11
- package/package.json +21 -17
- package/src/argv.js +132 -0
- package/src/commander.js +32 -10
- package/src/git-data.js +42 -36
- package/src/handler.js +52 -76
- package/src/index.js +31 -17
- package/src/job-executor.js +4 -4
- package/src/job-expanders.js +17 -24
- package/src/job.js +187 -118
- package/src/parser-includes.js +9 -4
- package/src/parser.js +27 -32
- package/src/state.js +6 -2
- package/src/types/job-options.js +1 -1
- package/src/utils.js +19 -29
- package/src/validator.js +30 -8
- package/src/variables-from-files.js +98 -52
- package/src/types/parser-options.js +0 -3
package/src/git-data.js
CHANGED
|
@@ -42,39 +42,43 @@ class GitData {
|
|
|
42
42
|
}
|
|
43
43
|
static async init(cwd, writeStreams) {
|
|
44
44
|
const gitData = new GitData();
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
writeStreams.stderr((0, chalk_1.default) `{yellow Git not available using fallback}\n`);
|
|
51
|
-
return gitData;
|
|
52
|
-
}
|
|
53
|
-
await gitData.initCommitData(cwd, writeStreams);
|
|
54
|
-
await gitData.initRemoteData(cwd, writeStreams);
|
|
55
|
-
await gitData.initUserData(cwd, writeStreams);
|
|
45
|
+
const promises = [];
|
|
46
|
+
promises.push(gitData.initCommitData(cwd, writeStreams));
|
|
47
|
+
promises.push(gitData.initRemoteData(cwd, writeStreams));
|
|
48
|
+
promises.push(gitData.initUserData(cwd, writeStreams));
|
|
49
|
+
await Promise.all(promises);
|
|
56
50
|
return gitData;
|
|
57
51
|
}
|
|
58
52
|
async initCommitData(cwd, writeStreams) {
|
|
53
|
+
const promises = [];
|
|
54
|
+
const refNamePromise = utils_1.Utils.spawn(["git", "rev-parse", "--abbrev-ref", "HEAD"], cwd);
|
|
55
|
+
refNamePromise.then(({ stdout }) => {
|
|
56
|
+
this.commit.REF_NAME = stdout.trimEnd();
|
|
57
|
+
});
|
|
58
|
+
promises.push(refNamePromise);
|
|
59
|
+
const shaPromise = utils_1.Utils.spawn(["git", "rev-parse", "HEAD"], cwd);
|
|
60
|
+
shaPromise.then(({ stdout }) => {
|
|
61
|
+
this.commit.SHA = stdout.trimEnd();
|
|
62
|
+
});
|
|
63
|
+
promises.push(shaPromise);
|
|
64
|
+
const shortShaPromise = utils_1.Utils.spawn(["git", "rev-parse", "--short", "HEAD"], cwd);
|
|
65
|
+
shortShaPromise.then(({ stdout }) => {
|
|
66
|
+
this.commit.SHORT_SHA = stdout.trimEnd();
|
|
67
|
+
});
|
|
68
|
+
promises.push(shortShaPromise);
|
|
59
69
|
try {
|
|
60
|
-
|
|
61
|
-
const gitLogMatch = gitLogStdout.match(/(?<short_sha>\S*?) (?<sha>\S*) .*HEAD( -> |, tag: |, )(?<ref_name>.*?)(?:,|$)/);
|
|
62
|
-
(0, asserts_1.assert)(gitLogMatch?.groups != null, "git log -1 didn't provide valid matches");
|
|
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;
|
|
70
|
+
await Promise.all(promises);
|
|
66
71
|
}
|
|
67
72
|
catch (e) {
|
|
68
73
|
if (e instanceof exit_error_1.ExitError) {
|
|
69
|
-
writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
70
|
-
return;
|
|
74
|
+
return writeStreams.stderr((0, chalk_1.default) `{yellow ${e.message}}\n`);
|
|
71
75
|
}
|
|
72
76
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git commit data}\n`);
|
|
73
77
|
}
|
|
74
78
|
}
|
|
75
79
|
async initRemoteData(cwd, writeStreams) {
|
|
76
80
|
try {
|
|
77
|
-
const { stdout: gitRemote } = await utils_1.Utils.spawn("git remote -v", cwd);
|
|
81
|
+
const { stdout: gitRemote } = await utils_1.Utils.spawn(["git", "remote", "-v"], cwd);
|
|
78
82
|
const gitRemoteMatch = gitRemote.match(/.*(?:\/\/|@)(?<host>[^:/]*)(:(?<port>\d+)\/|:|\/)(?<group>.*)\/(?<project>.*?)(?:\r?\n|\.git)/);
|
|
79
83
|
(0, asserts_1.assert)(gitRemoteMatch?.groups != null, "git remote -v didn't provide valid matches");
|
|
80
84
|
this.remote.port = gitRemoteMatch.groups.port ?? "22";
|
|
@@ -91,27 +95,29 @@ class GitData {
|
|
|
91
95
|
}
|
|
92
96
|
}
|
|
93
97
|
async initUserData(cwd, writeStreams) {
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
catch
|
|
98
|
+
const promises = [];
|
|
99
|
+
const gitUsernamePromise = utils_1.Utils.spawn(["git", "config", "user.name"], cwd).then(({ stdout }) => {
|
|
100
|
+
this.user.GITLAB_USER_NAME = stdout.trimEnd();
|
|
101
|
+
}).catch(() => {
|
|
98
102
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git user.name}\n`);
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
|
|
103
|
+
});
|
|
104
|
+
promises.push(gitUsernamePromise);
|
|
105
|
+
const gitEmailPromise = utils_1.Utils.spawn(["git", "config", "user.email"], cwd).then(({ stdout }) => {
|
|
106
|
+
const email = stdout.trimEnd();
|
|
102
107
|
this.user.GITLAB_USER_EMAIL = email;
|
|
103
108
|
this.user.GITLAB_USER_LOGIN = email.replace(/@.*/, "");
|
|
104
|
-
}
|
|
105
|
-
catch (e) {
|
|
109
|
+
}).catch(() => {
|
|
106
110
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback git user.email}\n`);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
catch
|
|
111
|
+
});
|
|
112
|
+
promises.push(gitEmailPromise);
|
|
113
|
+
const osUidPromise = utils_1.Utils.spawn(["id", "-u"], cwd).then(({ stdout }) => {
|
|
114
|
+
this.user.GITLAB_USER_ID = stdout.trimEnd();
|
|
115
|
+
}).catch(() => {
|
|
112
116
|
writeStreams.stderr((0, chalk_1.default) `{yellow Using fallback linux user id}\n`);
|
|
113
|
-
}
|
|
117
|
+
});
|
|
118
|
+
promises.push(osUidPromise);
|
|
119
|
+
await Promise.all(promises);
|
|
114
120
|
}
|
|
115
121
|
}
|
|
116
122
|
exports.GitData = GitData;
|
|
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"]}
|
|
123
|
+
//# 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        const promises = [];\n        promises.push(gitData.initCommitData(cwd, writeStreams));\n        promises.push(gitData.initRemoteData(cwd, writeStreams));\n        promises.push(gitData.initUserData(cwd, writeStreams));\n        await Promise.all(promises);\n        return gitData;\n    }\n\n    private async initCommitData(cwd: string, writeStreams: WriteStreams): Promise<void> {\n        const promises = [];\n\n        const refNamePromise = Utils.spawn([\"git\", \"rev-parse\", \"--abbrev-ref\", \"HEAD\"], cwd);\n        refNamePromise.then(({stdout}) => {\n            this.commit.REF_NAME = stdout.trimEnd();\n        });\n        promises.push(refNamePromise);\n\n        const shaPromise = Utils.spawn([\"git\", \"rev-parse\", \"HEAD\"], cwd);\n        shaPromise.then(({stdout}) => {\n            this.commit.SHA = stdout.trimEnd();\n        });\n        promises.push(shaPromise);\n\n        const shortShaPromise = Utils.spawn([\"git\", \"rev-parse\", \"--short\", \"HEAD\"], cwd);\n        shortShaPromise.then(({stdout}) => {\n            this.commit.SHORT_SHA = stdout.trimEnd();\n        });\n        promises.push(shortShaPromise);\n\n        try {\n            await Promise.all(promises);\n        } catch (e) {\n            if (e instanceof ExitError) {\n                return writeStreams.stderr(chalk`{yellow ${e.message}}\\n`);\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        const promises = [];\n\n        const gitUsernamePromise = Utils.spawn([\"git\", \"config\", \"user.name\"], cwd).then(({stdout}) => {\n            this.user.GITLAB_USER_NAME = stdout.trimEnd();\n        }).catch(() => {\n            writeStreams.stderr(chalk`{yellow Using fallback git user.name}\\n`);\n        });\n        promises.push(gitUsernamePromise);\n\n        const gitEmailPromise = Utils.spawn([\"git\", \"config\", \"user.email\"], cwd).then(({stdout}) => {\n            const email = stdout.trimEnd();\n            this.user.GITLAB_USER_EMAIL = email;\n            this.user.GITLAB_USER_LOGIN = email.replace(/@.*/, \"\");\n        }).catch(() => {\n            writeStreams.stderr(chalk`{yellow Using fallback git user.email}\\n`);\n        });\n        promises.push(gitEmailPromise);\n\n        const osUidPromise = Utils.spawn([\"id\", \"-u\"], cwd).then(({stdout}) => {\n            this.user.GITLAB_USER_ID = stdout.trimEnd();\n        }).catch(() => {\n            writeStreams.stderr(chalk`{yellow Using fallback linux user id}\\n`);\n        });\n        promises.push(osUidPromise);\n\n        await Promise.all(promises);\n    }\n}\n"]}
|
package/src/handler.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -30,18 +34,12 @@ const yargs = __importStar(require("yargs"));
|
|
|
30
34
|
const commander_1 = require("./commander");
|
|
31
35
|
const parser_1 = require("./parser");
|
|
32
36
|
const state = __importStar(require("./state"));
|
|
33
|
-
const asserts_1 = require("./asserts");
|
|
34
|
-
const dotenv = __importStar(require("dotenv"));
|
|
35
|
-
const camelcase_1 = __importDefault(require("camelcase"));
|
|
36
37
|
const pretty_hrtime_1 = __importDefault(require("pretty-hrtime"));
|
|
37
38
|
const job_1 = require("./job");
|
|
38
39
|
const utils_1 = require("./utils");
|
|
39
40
|
const exit_error_1 = require("./types/exit-error");
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
const gitlabFilePath = file ? `${cwd}/${file}` : `${cwd}/.gitlab-ci.yml`;
|
|
43
|
-
(0, asserts_1.assert)(fs.existsSync(gitlabFilePath), `${cwd} does not contain ${file ?? ".gitlab-ci.yml"}`);
|
|
44
|
-
};
|
|
41
|
+
const argv_1 = require("./argv");
|
|
42
|
+
const asserts_1 = require("./asserts");
|
|
45
43
|
const generateGitIgnore = (cwd) => {
|
|
46
44
|
const gitIgnoreFilePath = `${cwd}/.gitlab-ci-local/.gitignore`;
|
|
47
45
|
const gitIgnoreContent = "*\n!.gitignore\n";
|
|
@@ -51,7 +49,7 @@ const generateGitIgnore = (cwd) => {
|
|
|
51
49
|
};
|
|
52
50
|
const cleanupResources = async (parser) => {
|
|
53
51
|
if (!parser) {
|
|
54
|
-
|
|
52
|
+
return;
|
|
55
53
|
}
|
|
56
54
|
const promises = [];
|
|
57
55
|
for (const job of parser.jobs.values()) {
|
|
@@ -59,61 +57,45 @@ const cleanupResources = async (parser) => {
|
|
|
59
57
|
}
|
|
60
58
|
await Promise.all(promises);
|
|
61
59
|
};
|
|
62
|
-
async function handler(
|
|
63
|
-
|
|
64
|
-
const cwd = argv.cwd
|
|
60
|
+
async function handler(args, writeStreams) {
|
|
61
|
+
const argv = new argv_1.Argv(args);
|
|
62
|
+
const cwd = argv.cwd;
|
|
63
|
+
const file = argv.file;
|
|
64
|
+
let parser = null;
|
|
65
|
+
process.on("exit", () => {
|
|
66
|
+
if (parser)
|
|
67
|
+
cleanupResources(parser).then().catch();
|
|
68
|
+
});
|
|
65
69
|
process.on("unhandledRejection", async (e) => {
|
|
66
70
|
if (e instanceof exit_error_1.ExitError) {
|
|
67
|
-
process.stderr.write((0, chalk_1.default) `{red ${e.message}}\n`);
|
|
71
|
+
process.stderr.write((0, chalk_1.default) `{red ${e.message.trim()}}\n`);
|
|
68
72
|
}
|
|
69
73
|
else if (e instanceof Error) {
|
|
70
|
-
process.stderr.write((0, chalk_1.default) `{red ${e.stack ?? e.message}}\n`);
|
|
74
|
+
process.stderr.write((0, chalk_1.default) `{red ${e.stack?.trim() ?? e.message.trim()}}\n`);
|
|
71
75
|
}
|
|
72
76
|
else if (e) {
|
|
73
|
-
process.stderr.write((0, chalk_1.default) `{red ${e.toString()}}\n`);
|
|
77
|
+
process.stderr.write((0, chalk_1.default) `{red ${e.toString().trim()}}\n`);
|
|
74
78
|
}
|
|
75
|
-
|
|
79
|
+
if (parser)
|
|
80
|
+
await cleanupResources(parser);
|
|
76
81
|
process.exit(1);
|
|
77
82
|
});
|
|
78
83
|
process.on("SIGINT", async (_, code) => {
|
|
79
84
|
await cleanupResources(parser);
|
|
80
85
|
process.exit(code);
|
|
81
86
|
});
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
const config = dotenv.parse(fs.readFileSync(`${cwd}/.gitlab-ci-local-env`));
|
|
85
|
-
for (const [key, value] of Object.entries(config)) {
|
|
86
|
-
const argKey = (0, camelcase_1.default)(key);
|
|
87
|
-
if (argv[argKey] == null) {
|
|
88
|
-
argv[argKey] = value;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
const volumes = typeof argv.volume == "string" ? argv.volume.split(" ") : argv.volume;
|
|
93
|
-
const extraHosts = typeof argv.extraHost == "string" ? argv.extraHost.split(" ") : argv.extraHost;
|
|
94
|
-
const variablePairs = typeof argv.variable == "string" ? argv.variable.split(" ") : argv.variable;
|
|
95
|
-
const shellIsolation = argv.shellIsolation;
|
|
96
|
-
const variables = {};
|
|
97
|
-
(variablePairs ?? []).forEach((variablePair) => {
|
|
98
|
-
const exec = /(?<key>\w*?)(=)(?<value>\w.*)/.exec(variablePair);
|
|
99
|
-
if (exec?.groups?.key) {
|
|
100
|
-
variables[exec.groups.key] = exec?.groups?.value;
|
|
101
|
-
}
|
|
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
|
-
});
|
|
87
|
+
if (argv.completion) {
|
|
88
|
+
yargs.showCompletionScript();
|
|
107
89
|
return new Map();
|
|
108
90
|
}
|
|
109
|
-
|
|
110
|
-
|
|
91
|
+
(0, asserts_1.assert)(fs.existsSync(`${cwd}/${file}`), `${cwd}/${file} could not be found`);
|
|
92
|
+
if (argv.fetchIncludes) {
|
|
93
|
+
parser = await parser_1.Parser.create(argv, writeStreams, 0);
|
|
94
|
+
return new Map();
|
|
111
95
|
}
|
|
112
|
-
|
|
96
|
+
if (argv.preview) {
|
|
113
97
|
const pipelineIid = await state.getPipelineIid(cwd);
|
|
114
|
-
parser = await parser_1.Parser.create(
|
|
115
|
-
cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, variables, mountCache: argv.mountCache,
|
|
116
|
-
});
|
|
98
|
+
parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
|
|
117
99
|
const gitlabData = parser.gitlabData;
|
|
118
100
|
for (const jobName of Object.keys(gitlabData)) {
|
|
119
101
|
if (jobName === "stages") {
|
|
@@ -125,51 +107,45 @@ async function handler(argv, writeStreams) {
|
|
|
125
107
|
}
|
|
126
108
|
writeStreams.stdout(`---\n${yaml.dump(gitlabData, { lineWidth: 160 })}`);
|
|
127
109
|
}
|
|
128
|
-
else if (argv.list
|
|
129
|
-
checkFolderAndFile(cwd, argv.file);
|
|
110
|
+
else if (argv.list || argv.listAll) {
|
|
130
111
|
const pipelineIid = await state.getPipelineIid(cwd);
|
|
131
|
-
parser = await parser_1.Parser.create(
|
|
132
|
-
|
|
133
|
-
});
|
|
134
|
-
commander_1.Commander.runList(parser, writeStreams, argv.listAll != null);
|
|
112
|
+
parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
|
|
113
|
+
commander_1.Commander.runList(parser, writeStreams, argv.listAll);
|
|
135
114
|
}
|
|
136
|
-
else if (argv.
|
|
137
|
-
const
|
|
138
|
-
|
|
115
|
+
else if (argv.listJson) {
|
|
116
|
+
const pipelineIid = await state.getPipelineIid(cwd);
|
|
117
|
+
parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
|
|
118
|
+
commander_1.Commander.runJson(parser, writeStreams);
|
|
119
|
+
}
|
|
120
|
+
else if (argv.job.length > 0) {
|
|
139
121
|
generateGitIgnore(cwd);
|
|
140
|
-
|
|
122
|
+
const time = process.hrtime();
|
|
123
|
+
if (argv.needs || argv.onlyNeeds) {
|
|
141
124
|
await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);
|
|
142
125
|
await state.incrementPipelineIid(cwd);
|
|
143
126
|
}
|
|
144
127
|
const pipelineIid = await state.getPipelineIid(cwd);
|
|
145
|
-
parser = await parser_1.Parser.create(
|
|
146
|
-
cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,
|
|
147
|
-
});
|
|
128
|
+
parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
|
|
148
129
|
await utils_1.Utils.rsyncTrackedFiles(cwd, ".docker");
|
|
149
|
-
await commander_1.Commander.
|
|
150
|
-
if (argv.needs
|
|
151
|
-
writeStreams.
|
|
130
|
+
await commander_1.Commander.runJobs(argv, parser, writeStreams);
|
|
131
|
+
if (argv.needs || argv.onlyNeeds) {
|
|
132
|
+
writeStreams.stderr((0, chalk_1.default) `{grey pipeline finished} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
|
|
152
133
|
}
|
|
153
134
|
}
|
|
154
135
|
else {
|
|
155
|
-
const time = process.hrtime();
|
|
156
|
-
checkFolderAndFile(cwd, argv.file);
|
|
157
136
|
generateGitIgnore(cwd);
|
|
137
|
+
const time = process.hrtime();
|
|
158
138
|
await fs.remove(`${cwd}/.gitlab-ci-local/artifacts`);
|
|
159
139
|
await state.incrementPipelineIid(cwd);
|
|
160
140
|
const pipelineIid = await state.getPipelineIid(cwd);
|
|
161
|
-
parser = await parser_1.Parser.create(
|
|
162
|
-
cwd, writeStreams, pipelineIid, file: argv.file, home: argv.home, extraHosts, volumes, shellIsolation, variables, mountCache: argv.mountCache,
|
|
163
|
-
});
|
|
141
|
+
parser = await parser_1.Parser.create(argv, writeStreams, pipelineIid);
|
|
164
142
|
await utils_1.Utils.rsyncTrackedFiles(cwd, ".docker");
|
|
165
|
-
await commander_1.Commander.runPipeline(
|
|
166
|
-
writeStreams.
|
|
143
|
+
await commander_1.Commander.runPipeline(argv, parser, writeStreams);
|
|
144
|
+
writeStreams.stderr((0, chalk_1.default) `{grey pipeline finished} in {grey ${(0, pretty_hrtime_1.default)(process.hrtime(time))}}\n`);
|
|
167
145
|
}
|
|
168
146
|
writeStreams.flush();
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
}
|
|
172
|
-
return new Map();
|
|
147
|
+
await cleanupResources(parser);
|
|
148
|
+
return parser.jobs;
|
|
173
149
|
}
|
|
174
150
|
exports.handler = handler;
|
|
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"]}
|
|
151
|
+
//# 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 \"./types/write-streams\";\nimport {Job} from \"./job\";\nimport {Utils} from \"./utils\";\nimport {ExitError} from \"./types/exit-error\";\nimport {Argv} from \"./argv\";\nimport {assert} from \"./asserts\";\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        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<ReadonlyMap<string, Job>> {\n    const argv = new Argv(args);\n    const cwd = argv.cwd;\n    const file = argv.file;\n    let parser: Parser | null = null;\n\n    process.on(\"exit\", () => {\n        if (parser) cleanupResources(parser).then().catch();\n    });\n\n    process.on(\"unhandledRejection\", async (e) => {\n        if (e instanceof ExitError) {\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) 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    if (argv.completion) {\n        yargs.showCompletionScript();\n        return new Map<string, Job>();\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 new Map<string, Job>();\n    }\n\n    if (argv.preview) {\n        const pipelineIid = await state.getPipelineIid(cwd);\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.includes(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);\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);\n        parser = await Parser.create(argv, writeStreams, pipelineIid);\n        Commander.runJson(parser, writeStreams);\n    } else if (argv.job.length > 0) {\n        generateGitIgnore(cwd);\n        const time = process.hrtime();\n        if (argv.needs || argv.onlyNeeds) {\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(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, \".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 {\n        generateGitIgnore(cwd);\n        const time = process.hrtime();\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(argv, writeStreams, pipelineIid);\n        await Utils.rsyncTrackedFiles(cwd, \".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"]}
|
package/src/index.js
CHANGED
|
@@ -2,7 +2,11 @@
|
|
|
2
2
|
"use strict";
|
|
3
3
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
4
|
if (k2 === undefined) k2 = k;
|
|
5
|
-
Object.
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
6
10
|
}) : (function(o, m, k, k2) {
|
|
7
11
|
if (k2 === undefined) k2 = k;
|
|
8
12
|
o[k2] = m[k];
|
|
@@ -35,11 +39,12 @@ const process_write_streams_1 = require("./process-write-streams");
|
|
|
35
39
|
const handler_1 = require("./handler");
|
|
36
40
|
const job_executor_1 = require("./job-executor");
|
|
37
41
|
const mock_write_streams_1 = require("./mock-write-streams");
|
|
42
|
+
const argv_1 = require("./argv");
|
|
38
43
|
(() => {
|
|
39
44
|
const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, "../package.json"), "utf8"));
|
|
40
45
|
(0, yargs_1.default)(process.argv.slice(2))
|
|
41
|
-
.version(packageJson["version"])
|
|
42
46
|
.showHelpOnFail(false)
|
|
47
|
+
.version(packageJson["version"])
|
|
43
48
|
.wrap(yargs_1.default.terminalWidth())
|
|
44
49
|
.command({
|
|
45
50
|
handler: async (argv) => {
|
|
@@ -74,17 +79,22 @@ const mock_write_streams_1 = require("./mock-write-streams");
|
|
|
74
79
|
requiresArg: true,
|
|
75
80
|
})
|
|
76
81
|
.option("list", {
|
|
77
|
-
type: "
|
|
82
|
+
type: "boolean",
|
|
78
83
|
description: "List jobs and job information, when:never excluded",
|
|
79
84
|
requiresArg: false,
|
|
80
85
|
})
|
|
81
86
|
.option("list-all", {
|
|
82
|
-
type: "
|
|
87
|
+
type: "boolean",
|
|
83
88
|
description: "List jobs and job information, when:never included",
|
|
84
89
|
requiresArg: false,
|
|
90
|
+
})
|
|
91
|
+
.option("list-json", {
|
|
92
|
+
type: "boolean",
|
|
93
|
+
description: "List jobs and job information in json format, when:never included",
|
|
94
|
+
requiresArg: false,
|
|
85
95
|
})
|
|
86
96
|
.option("preview", {
|
|
87
|
-
type: "
|
|
97
|
+
type: "boolean",
|
|
88
98
|
description: "Print YML with defaults, includes, extends and reference's expanded",
|
|
89
99
|
requiresArg: false,
|
|
90
100
|
})
|
|
@@ -94,19 +104,29 @@ const mock_write_streams_1 = require("./mock-write-streams");
|
|
|
94
104
|
requiresArg: true,
|
|
95
105
|
})
|
|
96
106
|
.option("completion", {
|
|
97
|
-
type: "
|
|
107
|
+
type: "boolean",
|
|
98
108
|
description: "Generate tab completion script",
|
|
99
109
|
requiresArg: false,
|
|
100
110
|
})
|
|
101
111
|
.option("needs", {
|
|
102
112
|
type: "boolean",
|
|
103
|
-
description: "Run needed jobs, when executing
|
|
113
|
+
description: "Run needed jobs, when executing specific jobs",
|
|
114
|
+
requiresArg: false,
|
|
115
|
+
})
|
|
116
|
+
.option("onlyNeeds", {
|
|
117
|
+
type: "boolean",
|
|
118
|
+
description: "Run needed jobs, except the specified jobs themselves",
|
|
104
119
|
requiresArg: false,
|
|
105
120
|
})
|
|
106
121
|
.option("variable", {
|
|
107
122
|
type: "array",
|
|
108
123
|
description: "Add variable to all executed jobs (--variable HELLO=world)",
|
|
109
124
|
requiresArg: false,
|
|
125
|
+
})
|
|
126
|
+
.option("remote-variables", {
|
|
127
|
+
type: "string",
|
|
128
|
+
description: "Fetch variables file from remote location",
|
|
129
|
+
requiresArg: false,
|
|
110
130
|
})
|
|
111
131
|
.option("file", {
|
|
112
132
|
type: "string",
|
|
@@ -150,15 +170,9 @@ const mock_write_streams_1 = require("./mock-write-streams");
|
|
|
150
170
|
})
|
|
151
171
|
.completion("completion", false, async (_, yargsArgv) => {
|
|
152
172
|
try {
|
|
153
|
-
const
|
|
154
|
-
const pipelineIid = await state.getPipelineIid(cwd);
|
|
155
|
-
const parser = await parser_1.Parser.create(
|
|
156
|
-
cwd,
|
|
157
|
-
writeStreams: new mock_write_streams_1.MockWriteStreams(),
|
|
158
|
-
pipelineIid,
|
|
159
|
-
file: yargsArgv.file,
|
|
160
|
-
variables: {},
|
|
161
|
-
});
|
|
173
|
+
const argv = new argv_1.Argv({ ...yargsArgv, autoCompleting: true });
|
|
174
|
+
const pipelineIid = await state.getPipelineIid(argv.cwd);
|
|
175
|
+
const parser = await parser_1.Parser.create(argv, new mock_write_streams_1.MockWriteStreams(), pipelineIid);
|
|
162
176
|
return [...parser.jobs.values()].filter((j) => j.when != "never").map((j) => j.name);
|
|
163
177
|
}
|
|
164
178
|
catch (e) {
|
|
@@ -167,4 +181,4 @@ const mock_write_streams_1 = require("./mock-write-streams");
|
|
|
167
181
|
})
|
|
168
182
|
.parse();
|
|
169
183
|
})();
|
|
170
|
-
//# 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 {ExitError} from \"./types/exit-error\";\nimport {ProcessWriteStreams} from \"./process-write-streams\";\nimport {handler} from \"./handler\";\nimport {JobExecutor} from \"./job-executor\";\nimport {MockWriteStreams} from \"./mock-write-streams\";\n\n(() => {\n    const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, \"../package.json\"), \"utf8\"));\n    yargs(process.argv.slice(2))\n        .version(packageJson[\"version\"])\n        .showHelpOnFail(false)\n        .wrap(yargs.terminalWidth())\n        .command({\n            handler: async (argv) => {\n                try {\n                    const jobs = await handler(argv, new ProcessWriteStreams());\n                    const failedJobs = JobExecutor.getFailed(jobs);\n                    process.exit(failedJobs.length > 0 ? 1 : 0);\n                } catch (e) {\n                    if (e instanceof ExitError) {\n                        process.stderr.write(chalk`{red ${e.message}}\\n`);\n                        process.exit(1);\n                    }\n                    throw e;\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: \"string\",\n            description: \"List jobs and job information, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-all\", {\n            type: \"string\",\n            description: \"List jobs and job information, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"preview\", {\n            type: \"string\",\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: \"string\",\n            description: \"Generate tab completion script\",\n            requiresArg: false,\n        })\n        .option(\"needs\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, when executing a single job\",\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(\"file\", {\n            type: \"string\",\n            description: \"Specify custom 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: \"Specify custom HOME location ($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(\"privileged\", {\n            type: \"boolean\",\n            description: \"Set docker executor to privileged mode\",\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        .completion(\"completion\", false, async (_, yargsArgv) => {\n            try {\n                const cwd = yargsArgv.cwd || process.cwd();\n                const pipelineIid = await state.getPipelineIid(cwd);\n                const parser = await Parser.create({\n                    cwd,\n                    writeStreams: new MockWriteStreams(),\n                    pipelineIid,\n                    file: yargsArgv.file,\n                    variables: {},\n                });\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"]}
|
|
184
|
+
//# 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 {ExitError} from \"./types/exit-error\";\nimport {ProcessWriteStreams} from \"./process-write-streams\";\nimport {handler} from \"./handler\";\nimport {JobExecutor} from \"./job-executor\";\nimport {MockWriteStreams} from \"./mock-write-streams\";\nimport {Argv} from \"./argv\";\n\n(() => {\n    const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, \"../package.json\"), \"utf8\"));\n    yargs(process.argv.slice(2))\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 ProcessWriteStreams());\n                    const failedJobs = JobExecutor.getFailed(jobs);\n                    process.exit(failedJobs.length > 0 ? 1 : 0);\n                } catch (e) {\n                    if (e instanceof ExitError) {\n                        process.stderr.write(chalk`{red ${e.message}}\\n`);\n                        process.exit(1);\n                    }\n                    throw e;\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 jobs and job information, when:never excluded\",\n            requiresArg: false,\n        })\n        .option(\"list-all\", {\n            type: \"boolean\",\n            description: \"List jobs and job information, when:never included\",\n            requiresArg: false,\n        })\n        .option(\"list-json\", {\n            type: \"boolean\",\n            description: \"List jobs and job information in json 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(\"onlyNeeds\", {\n            type: \"boolean\",\n            description: \"Run needed jobs, except the specified jobs themselves\",\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(\"remote-variables\", {\n            type: \"string\",\n            description: \"Fetch variables file from remote location\",\n            requiresArg: false,\n        })\n        .option(\"file\", {\n            type: \"string\",\n            description: \"Specify custom 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: \"Specify custom HOME location ($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(\"privileged\", {\n            type: \"boolean\",\n            description: \"Set docker executor to privileged mode\",\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        .completion(\"completion\", false, async (_, yargsArgv) => {\n            try {\n                const argv = new Argv({...yargsArgv, autoCompleting: true});\n                const pipelineIid = await state.getPipelineIid(argv.cwd);\n                const parser = await Parser.create(argv, new MockWriteStreams(), 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"]}
|