Check that the database exists before writing diagnostics to it
This commit is contained in:
parent
96f44cb9d2
commit
d4e7b0e493
3 changed files with 36 additions and 21 deletions
23
lib/diagnostics.js
generated
23
lib/diagnostics.js
generated
|
|
@ -32,15 +32,22 @@ exports.makeDiagnostic = makeDiagnostic;
|
||||||
*/
|
*/
|
||||||
function addDiagnostic(config, language, diagnostic) {
|
function addDiagnostic(config, language, diagnostic) {
|
||||||
const logger = (0, logging_1.getActionsLogger)();
|
const logger = (0, logging_1.getActionsLogger)();
|
||||||
const diagnosticsPath = path_1.default.resolve((0, util_1.getCodeQLDatabasePath)(config, language), "diagnostic", "codeql-action");
|
const databasePath = (0, util_1.getCodeQLDatabasePath)(config, language);
|
||||||
try {
|
const diagnosticsPath = path_1.default.resolve(databasePath, "diagnostic", "codeql-action");
|
||||||
// Create the directory if it doesn't exist yet.
|
// Check that the database exists before writing to it.
|
||||||
(0, fs_1.mkdirSync)(diagnosticsPath, { recursive: true });
|
if ((0, fs_1.existsSync)(databasePath)) {
|
||||||
const jsonPath = path_1.default.resolve(diagnosticsPath, `codeql-action-${diagnostic.timestamp}.json`);
|
try {
|
||||||
(0, fs_1.writeFileSync)(jsonPath, JSON.stringify(diagnostic));
|
// Create the directory if it doesn't exist yet.
|
||||||
|
(0, fs_1.mkdirSync)(diagnosticsPath, { recursive: true });
|
||||||
|
const jsonPath = path_1.default.resolve(diagnosticsPath, `codeql-action-${diagnostic.timestamp}.json`);
|
||||||
|
(0, fs_1.writeFileSync)(jsonPath, JSON.stringify(diagnostic));
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
logger.warning(`Unable to write diagnostic message to database: ${err}`);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (err) {
|
else {
|
||||||
logger.warning(`Unable to write diagnostic message to database: ${err}`);
|
logger.info(`Writing a diagnostic for ${language}, but the database at ${databasePath} does not exist yet.`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.addDiagnostic = addDiagnostic;
|
exports.addDiagnostic = addDiagnostic;
|
||||||
|
|
|
||||||
|
|
@ -1 +1 @@
|
||||||
{"version":3,"file":"diagnostics.js","sourceRoot":"","sources":["../src/diagnostics.ts"],"names":[],"mappings":";;;;;;AAAA,2BAA8C;AAC9C,gDAAwB;AAIxB,uCAA6C;AAC7C,iCAA+C;AAmD/C;;;;;;;GAOG;AACH,SAAgB,cAAc,CAC5B,EAAU,EACV,IAAY,EACZ,OAA+C,SAAS;IAExD,OAAO;QACL,GAAG,IAAI;QACP,SAAS,EAAE,IAAI,EAAE,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACtD,MAAM,EAAE,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE;KACtC,CAAC;AACJ,CAAC;AAVD,wCAUC;AAED;;;;;GAKG;AACH,SAAgB,aAAa,CAC3B,MAAc,EACd,QAAkB,EAClB,UAA6B;IAE7B,MAAM,MAAM,GAAG,IAAA,0BAAgB,GAAE,CAAC;IAClC,MAAM,eAAe,GAAG,cAAI,CAAC,OAAO,CAClC,IAAA,4BAAqB,EAAC,MAAM,EAAE,QAAQ,CAAC,EACvC,YAAY,EACZ,eAAe,CAChB,CAAC;IAEF,IAAI,CAAC;QACH,gDAAgD;QAChD,IAAA,cAAS,EAAC,eAAe,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAEhD,MAAM,QAAQ,GAAG,cAAI,CAAC,OAAO,CAC3B,eAAe,EACf,iBAAiB,UAAU,CAAC,SAAS,OAAO,CAC7C,CAAC;QAEF,IAAA,kBAAa,EAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC;IACtD,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,CAAC,OAAO,CAAC,mDAAmD,GAAG,EAAE,CAAC,CAAC;IAC3E,CAAC;AACH,CAAC;AAzBD,sCAyBC"}
|
{"version":3,"file":"diagnostics.js","sourceRoot":"","sources":["../src/diagnostics.ts"],"names":[],"mappings":";;;;;;AAAA,2BAA0D;AAC1D,gDAAwB;AAIxB,uCAA6C;AAC7C,iCAA+C;AAmD/C;;;;;;;GAOG;AACH,SAAgB,cAAc,CAC5B,EAAU,EACV,IAAY,EACZ,OAA+C,SAAS;IAExD,OAAO;QACL,GAAG,IAAI;QACP,SAAS,EAAE,IAAI,EAAE,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACtD,MAAM,EAAE,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE;KACtC,CAAC;AACJ,CAAC;AAVD,wCAUC;AAED;;;;;GAKG;AACH,SAAgB,aAAa,CAC3B,MAAc,EACd,QAAkB,EAClB,UAA6B;IAE7B,MAAM,MAAM,GAAG,IAAA,0BAAgB,GAAE,CAAC;IAClC,MAAM,YAAY,GAAG,IAAA,4BAAqB,EAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IAC7D,MAAM,eAAe,GAAG,cAAI,CAAC,OAAO,CAClC,YAAY,EACZ,YAAY,EACZ,eAAe,CAChB,CAAC;IAEF,uDAAuD;IACvD,IAAI,IAAA,eAAU,EAAC,YAAY,CAAC,EAAE,CAAC;QAC7B,IAAI,CAAC;YACH,gDAAgD;YAChD,IAAA,cAAS,EAAC,eAAe,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YAEhD,MAAM,QAAQ,GAAG,cAAI,CAAC,OAAO,CAC3B,eAAe,EACf,iBAAiB,UAAU,CAAC,SAAS,OAAO,CAC7C,CAAC;YAEF,IAAA,kBAAa,EAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC;QACtD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,CAAC,OAAO,CAAC,mDAAmD,GAAG,EAAE,CAAC,CAAC;QAC3E,CAAC;IACH,CAAC;SAAM,CAAC;QACN,MAAM,CAAC,IAAI,CACT,4BAA4B,QAAQ,yBAAyB,YAAY,sBAAsB,CAChG,CAAC;IACJ,CAAC;AACH,CAAC;AAjCD,sCAiCC"}
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
import { mkdirSync, writeFileSync } from "fs";
|
import { existsSync, mkdirSync, writeFileSync } from "fs";
|
||||||
import path from "path";
|
import path from "path";
|
||||||
|
|
||||||
import { Config } from "./config-utils";
|
import { Config } from "./config-utils";
|
||||||
|
|
@ -87,23 +87,31 @@ export function addDiagnostic(
|
||||||
diagnostic: DiagnosticMessage,
|
diagnostic: DiagnosticMessage,
|
||||||
) {
|
) {
|
||||||
const logger = getActionsLogger();
|
const logger = getActionsLogger();
|
||||||
|
const databasePath = getCodeQLDatabasePath(config, language);
|
||||||
const diagnosticsPath = path.resolve(
|
const diagnosticsPath = path.resolve(
|
||||||
getCodeQLDatabasePath(config, language),
|
databasePath,
|
||||||
"diagnostic",
|
"diagnostic",
|
||||||
"codeql-action",
|
"codeql-action",
|
||||||
);
|
);
|
||||||
|
|
||||||
try {
|
// Check that the database exists before writing to it.
|
||||||
// Create the directory if it doesn't exist yet.
|
if (existsSync(databasePath)) {
|
||||||
mkdirSync(diagnosticsPath, { recursive: true });
|
try {
|
||||||
|
// Create the directory if it doesn't exist yet.
|
||||||
|
mkdirSync(diagnosticsPath, { recursive: true });
|
||||||
|
|
||||||
const jsonPath = path.resolve(
|
const jsonPath = path.resolve(
|
||||||
diagnosticsPath,
|
diagnosticsPath,
|
||||||
`codeql-action-${diagnostic.timestamp}.json`,
|
`codeql-action-${diagnostic.timestamp}.json`,
|
||||||
|
);
|
||||||
|
|
||||||
|
writeFileSync(jsonPath, JSON.stringify(diagnostic));
|
||||||
|
} catch (err) {
|
||||||
|
logger.warning(`Unable to write diagnostic message to database: ${err}`);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
logger.info(
|
||||||
|
`Writing a diagnostic for ${language}, but the database at ${databasePath} does not exist yet.`,
|
||||||
);
|
);
|
||||||
|
|
||||||
writeFileSync(jsonPath, JSON.stringify(diagnostic));
|
|
||||||
} catch (err) {
|
|
||||||
logger.warning(`Unable to write diagnostic message to database: ${err}`);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue