2021-10-29 01:09:59 +03:00
|
|
|
"use strict";
|
|
|
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
|
|
if (k2 === undefined) k2 = k;
|
2023-01-18 23:00:33 +03:00
|
|
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
|
|
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
|
|
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
|
|
}
|
|
|
|
Object.defineProperty(o, k2, desc);
|
2021-10-29 01:09:59 +03:00
|
|
|
}) : (function(o, m, k, k2) {
|
|
|
|
if (k2 === undefined) k2 = k;
|
|
|
|
o[k2] = m[k];
|
|
|
|
}));
|
|
|
|
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
|
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
|
|
}) : function(o, v) {
|
|
|
|
o["default"] = v;
|
|
|
|
});
|
|
|
|
var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
|
if (mod && mod.__esModule) return mod;
|
|
|
|
var result = {};
|
|
|
|
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
|
|
__setModuleDefault(result, mod);
|
|
|
|
return result;
|
|
|
|
};
|
|
|
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
|
|
};
|
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
|
const ava_1 = __importDefault(require("ava"));
|
|
|
|
const sinon = __importStar(require("sinon"));
|
|
|
|
const actionsUtil = __importStar(require("./actions-util"));
|
|
|
|
const analyze = __importStar(require("./analyze"));
|
2023-07-19 18:40:31 +03:00
|
|
|
const api = __importStar(require("./api-client"));
|
2021-10-29 01:09:59 +03:00
|
|
|
const configUtils = __importStar(require("./config-utils"));
|
2023-08-07 15:42:43 +03:00
|
|
|
const statusReport = __importStar(require("./status-report"));
|
2021-10-29 01:09:59 +03:00
|
|
|
const testing_utils_1 = require("./testing-utils");
|
|
|
|
const util = __importStar(require("./util"));
|
|
|
|
(0, testing_utils_1.setupTests)(ava_1.default);
|
|
|
|
// This test needs to be in its own file so that ava would run it in its own
|
|
|
|
// nodejs process. The code being tested is in analyze-action.ts, which runs
|
|
|
|
// immediately on load. So the file needs to be loaded during part of the test,
|
|
|
|
// and that can happen only once per nodejs process. If multiple such tests are
|
|
|
|
// in the same test file, ava would run them in the same nodejs process, and all
|
|
|
|
// but the first test would fail.
|
|
|
|
(0, ava_1.default)("analyze action with RAM & threads from environment variables", async (t) => {
|
|
|
|
await util.withTmpDir(async (tmpDir) => {
|
2022-05-11 17:52:56 +03:00
|
|
|
process.env["GITHUB_SERVER_URL"] = util.GITHUB_DOTCOM_URL;
|
|
|
|
process.env["GITHUB_REPOSITORY"] = "github/codeql-action-fake-repository";
|
2022-08-10 23:11:50 +03:00
|
|
|
process.env["GITHUB_API_URL"] = "https://api.github.com";
|
2021-10-29 01:09:59 +03:00
|
|
|
sinon
|
2023-08-07 15:42:43 +03:00
|
|
|
.stub(statusReport, "createStatusReportBase")
|
2021-10-29 01:09:59 +03:00
|
|
|
.resolves({});
|
2023-08-07 15:42:43 +03:00
|
|
|
sinon.stub(statusReport, "sendStatusReport").resolves(true);
|
2022-11-29 01:08:01 +03:00
|
|
|
sinon.stub(actionsUtil, "isAnalyzingDefaultBranch").resolves(true);
|
2022-05-11 17:52:56 +03:00
|
|
|
const gitHubVersion = {
|
|
|
|
type: util.GitHubVariant.DOTCOM,
|
|
|
|
};
|
2021-10-29 01:09:59 +03:00
|
|
|
sinon.stub(configUtils, "getConfig").resolves({
|
2022-05-11 17:52:56 +03:00
|
|
|
gitHubVersion,
|
2021-10-29 01:09:59 +03:00
|
|
|
languages: [],
|
2022-02-15 17:42:55 +03:00
|
|
|
packs: [],
|
2022-09-23 18:15:16 +03:00
|
|
|
trapCaches: {},
|
2021-10-29 01:09:59 +03:00
|
|
|
});
|
|
|
|
const requiredInputStub = sinon.stub(actionsUtil, "getRequiredInput");
|
|
|
|
requiredInputStub.withArgs("token").returns("fake-token");
|
|
|
|
requiredInputStub.withArgs("upload-database").returns("false");
|
|
|
|
const optionalInputStub = sinon.stub(actionsUtil, "getOptionalInput");
|
|
|
|
optionalInputStub.withArgs("cleanup-level").returns("none");
|
2022-08-17 17:02:46 +03:00
|
|
|
optionalInputStub.withArgs("expect-error").returns("false");
|
2023-07-19 18:40:31 +03:00
|
|
|
sinon.stub(api, "getGitHubVersion").resolves(gitHubVersion);
|
2021-10-29 01:09:59 +03:00
|
|
|
(0, testing_utils_1.setupActionsVars)(tmpDir, tmpDir);
|
2021-12-16 16:30:31 +03:00
|
|
|
(0, testing_utils_1.mockFeatureFlagApiEndpoint)(200, {});
|
2021-10-29 01:09:59 +03:00
|
|
|
// When there are no action inputs for RAM and threads, the action uses
|
|
|
|
// environment variables (passed down from the init action) to set RAM and
|
|
|
|
// threads usage.
|
|
|
|
process.env["CODEQL_THREADS"] = "-1";
|
|
|
|
process.env["CODEQL_RAM"] = "4992";
|
|
|
|
const runFinalizeStub = sinon.stub(analyze, "runFinalize");
|
|
|
|
const runQueriesStub = sinon.stub(analyze, "runQueries");
|
|
|
|
const analyzeAction = require("./analyze-action");
|
|
|
|
// When analyze-action.ts loads, it runs an async function from the top
|
|
|
|
// level but does not wait for it to finish. To ensure that calls to
|
|
|
|
// runFinalize and runQueries are correctly captured by spies, we explicitly
|
|
|
|
// wait for the action promise to complete before starting verification.
|
|
|
|
await analyzeAction.runPromise;
|
|
|
|
t.deepEqual(runFinalizeStub.firstCall.args[1], "--threads=-1");
|
|
|
|
t.deepEqual(runFinalizeStub.firstCall.args[2], "--ram=4992");
|
|
|
|
t.deepEqual(runQueriesStub.firstCall.args[3], "--threads=-1");
|
|
|
|
t.deepEqual(runQueriesStub.firstCall.args[1], "--ram=4992");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
//# sourceMappingURL=analyze-action-env.test.js.map
|