From ddd70ab15c6017b4319a58bf78448df90c0da2b4 Mon Sep 17 00:00:00 2001 From: tiulpin Date: Tue, 28 Feb 2023 16:33:38 +0100 Subject: [PATCH] :children_crossing: Improve GitHub action summary --- scan/dist/index.js | 32 +++++++++++++++++++------------- scan/src/output.ts | 31 +++++++++++++++++++------------ 2 files changed, 38 insertions(+), 25 deletions(-) diff --git a/scan/dist/index.js b/scan/dist/index.js index 5988f203..2f243113 100644 --- a/scan/dist/index.js +++ b/scan/dist/index.js @@ -72644,15 +72644,20 @@ var require_output = __commonJS({ var ANNOTATION_NOTICE = "notice"; var SUMMARY_TABLE_HEADER = "| Name | Severity | Problems |"; var SUMMARY_TABLE_SEP = "| --- | --- | --- |"; - var SUMMARY_MISC = `### Contact us - - Contact us at [qodana-support@jetbrains.com](mailto:qodana-support@jetbrains.com) + var SUMMARY_MISC = `Contact us at [qodana-support@jetbrains.com](mailto:qodana-support@jetbrains.com) - Or via our issue tracker: https://jb.gg/qodana-issue - Or share your feedback: https://jb.gg/qodana-discussions`; - function getViewReportText(sarifPath) { - var _a, _b, _c, _d; - const sarif = JSON.parse(fs.readFileSync(sarifPath, { encoding: "utf8" })); - const link = (_d = (_c = (_b = (_a = sarif.runs) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.properties) === null || _c === void 0 ? void 0 : _c["reportUrl"]) !== null && _d !== void 0 ? _d : ""; + function wrapToToggleBlock(header, body) { + return `
+${header} + +${body} +
`; + } + __name(wrapToToggleBlock, "wrapToToggleBlock"); + function getViewReportText() { + var _a; + const link = (_a = process.env["QODANA_REPORT_URL"]) !== null && _a !== void 0 ? _a : ""; if (link !== "") { return `\u2601\uFE0F [View the Qodana report](${link})`; } @@ -72667,7 +72672,8 @@ var require_output = __commonJS({ return Array.from(problems.entries()).sort((a, b) => b[1] - a[1]).map(([title, count]) => `| ${title} | ${level} | ${count} |`).join("\n"); } __name(getRowsByLevel, "getRowsByLevel"); - function getSummary(annotations, shortSarifPath) { + function getSummary(annotations) { + const contactBlock = wrapToToggleBlock("Contact Qodana team", SUMMARY_MISC); if (annotations.length === 0) { return [ `# ${QODANA_CHECK_NAME}`, @@ -72675,8 +72681,8 @@ var require_output = __commonJS({ "**It seems all right \u{1F44C}**", "", "No problems found according to the checks applied", - getViewReportText(shortSarifPath), - SUMMARY_MISC + getViewReportText(), + contactBlock ].join("\n"); } return [ @@ -72692,8 +72698,8 @@ var require_output = __commonJS({ getRowsByLevel(annotations.filter((a) => a.level === ANNOTATION_NOTICE), "\u25FD\uFE0F Notice") ].filter((e) => e !== "").join("\n"), "", - getViewReportText(shortSarifPath), - SUMMARY_MISC + getViewReportText(), + contactBlock ].join("\n"); } __name(getSummary, "getSummary"); @@ -72773,7 +72779,7 @@ var require_output = __commonJS({ } } } - yield core2.summary.addRaw(getSummary(problems, shortSarifPath)).write(); + yield core2.summary.addRaw(getSummary(problems)).write(); } catch (error) { core2.warning(`Failed to publish annotations \u2013 ${error.message}`); } diff --git a/scan/src/output.ts b/scan/src/output.ts index 456143c2..a2a63185 100644 --- a/scan/src/output.ts +++ b/scan/src/output.ts @@ -11,9 +11,7 @@ const ANNOTATION_WARNING = 'warning' const ANNOTATION_NOTICE = 'notice' const SUMMARY_TABLE_HEADER = '| Name | Severity | Problems |' const SUMMARY_TABLE_SEP = '| --- | --- | --- |' -const SUMMARY_MISC = `### Contact us - - Contact us at [qodana-support@jetbrains.com](mailto:qodana-support@jetbrains.com) +const SUMMARY_MISC = `Contact us at [qodana-support@jetbrains.com](mailto:qodana-support@jetbrains.com) - Or via our issue tracker: https://jb.gg/qodana-issue - Or share your feedback: https://jb.gg/qodana-discussions` @@ -28,9 +26,16 @@ export interface Annotation { properties: AnnotationProperties } -function getViewReportText(sarifPath: string): string { - const sarif: Log = JSON.parse(fs.readFileSync(sarifPath, {encoding: 'utf8'})) - const link: string = sarif.runs?.[0]?.properties?.['reportUrl'] ?? '' +function wrapToToggleBlock(header: string, body: string): string { + return `
+${header} + +${body} +
` +} + +function getViewReportText(): string { + const link: string = process.env['QODANA_REPORT_URL'] ?? '' if (link !== '') { return `☁️ [View the Qodana report](${link})` } @@ -64,7 +69,9 @@ function getRowsByLevel(annotations: Annotation[], level: string): string { * @param annotations The annotations to generate the summary from. * @param shortSarifPath The path to the SARIF file. */ -function getSummary(annotations: Annotation[], shortSarifPath: string): string { +function getSummary(annotations: Annotation[]): string { + const contactBlock = wrapToToggleBlock('Contact Qodana team', SUMMARY_MISC) + if (annotations.length === 0) { return [ `# ${QODANA_CHECK_NAME}`, @@ -72,8 +79,8 @@ function getSummary(annotations: Annotation[], shortSarifPath: string): string { '**It seems all right 👌**', '', 'No problems found according to the checks applied', - getViewReportText(shortSarifPath), - SUMMARY_MISC + getViewReportText(), + contactBlock ].join('\n') } @@ -103,8 +110,8 @@ function getSummary(annotations: Annotation[], shortSarifPath: string): string { .filter(e => e !== '') .join('\n'), '', - getViewReportText(shortSarifPath), - SUMMARY_MISC + getViewReportText(), + contactBlock ].join('\n') } @@ -216,7 +223,7 @@ export async function publishOutput( } } } - await core.summary.addRaw(getSummary(problems, shortSarifPath)).write() + await core.summary.addRaw(getSummary(problems)).write() } catch (error) { core.warning(`Failed to publish annotations – ${(error as Error).message}`) }