You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
140 lines
4.6 KiB
140 lines
4.6 KiB
/** |
|
* @fileoverview HTML reporter |
|
* @author Julian Laval |
|
*/ |
|
"use strict"; |
|
|
|
const lodash = require("lodash"); |
|
const fs = require("fs"); |
|
const path = require("path"); |
|
|
|
//------------------------------------------------------------------------------ |
|
// Helpers |
|
//------------------------------------------------------------------------------ |
|
|
|
const pageTemplate = lodash.template(fs.readFileSync(path.join(__dirname, "html-template-page.html"), "utf-8")); |
|
const messageTemplate = lodash.template(fs.readFileSync(path.join(__dirname, "html-template-message.html"), "utf-8")); |
|
const resultTemplate = lodash.template(fs.readFileSync(path.join(__dirname, "html-template-result.html"), "utf-8")); |
|
|
|
/** |
|
* Given a word and a count, append an s if count is not one. |
|
* @param {string} word A word in its singular form. |
|
* @param {int} count A number controlling whether word should be pluralized. |
|
* @returns {string} The original word with an s on the end if count is not one. |
|
*/ |
|
function pluralize(word, count) { |
|
return (count === 1 ? word : `${word}s`); |
|
} |
|
|
|
/** |
|
* Renders text along the template of x problems (x errors, x warnings) |
|
* @param {string} totalErrors Total errors |
|
* @param {string} totalWarnings Total warnings |
|
* @returns {string} The formatted string, pluralized where necessary |
|
*/ |
|
function renderSummary(totalErrors, totalWarnings) { |
|
const totalProblems = totalErrors + totalWarnings; |
|
let renderedText = `${totalProblems} ${pluralize("problem", totalProblems)}`; |
|
|
|
if (totalProblems !== 0) { |
|
renderedText += ` (${totalErrors} ${pluralize("error", totalErrors)}, ${totalWarnings} ${pluralize("warning", totalWarnings)})`; |
|
} |
|
return renderedText; |
|
} |
|
|
|
/** |
|
* Get the color based on whether there are errors/warnings... |
|
* @param {string} totalErrors Total errors |
|
* @param {string} totalWarnings Total warnings |
|
* @returns {int} The color code (0 = green, 1 = yellow, 2 = red) |
|
*/ |
|
function renderColor(totalErrors, totalWarnings) { |
|
if (totalErrors !== 0) { |
|
return 2; |
|
} |
|
if (totalWarnings !== 0) { |
|
return 1; |
|
} |
|
return 0; |
|
} |
|
|
|
/** |
|
* Get HTML (table rows) describing the messages. |
|
* @param {Array} messages Messages. |
|
* @param {int} parentIndex Index of the parent HTML row. |
|
* @param {Object} rulesMeta Dictionary containing metadata for each rule executed by the analysis. |
|
* @returns {string} HTML (table rows) describing the messages. |
|
*/ |
|
function renderMessages(messages, parentIndex, rulesMeta) { |
|
|
|
/** |
|
* Get HTML (table row) describing a message. |
|
* @param {Object} message Message. |
|
* @returns {string} HTML (table row) describing a message. |
|
*/ |
|
return lodash.map(messages, message => { |
|
const lineNumber = message.line || 0; |
|
const columnNumber = message.column || 0; |
|
let ruleUrl; |
|
|
|
if (rulesMeta) { |
|
const meta = rulesMeta[message.ruleId]; |
|
|
|
ruleUrl = lodash.get(meta, "docs.url", null); |
|
} |
|
|
|
return messageTemplate({ |
|
parentIndex, |
|
lineNumber, |
|
columnNumber, |
|
severityNumber: message.severity, |
|
severityName: message.severity === 1 ? "Warning" : "Error", |
|
message: message.message, |
|
ruleId: message.ruleId, |
|
ruleUrl |
|
}); |
|
}).join("\n"); |
|
} |
|
|
|
// eslint-disable-next-line jsdoc/require-description |
|
/** |
|
* @param {Array} results Test results. |
|
* @param {Object} rulesMeta Dictionary containing metadata for each rule executed by the analysis. |
|
* @returns {string} HTML string describing the results. |
|
*/ |
|
function renderResults(results, rulesMeta) { |
|
return lodash.map(results, (result, index) => resultTemplate({ |
|
index, |
|
color: renderColor(result.errorCount, result.warningCount), |
|
filePath: result.filePath, |
|
summary: renderSummary(result.errorCount, result.warningCount) |
|
|
|
}) + renderMessages(result.messages, index, rulesMeta)).join("\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// Public Interface |
|
//------------------------------------------------------------------------------ |
|
|
|
module.exports = function(results, data) { |
|
let totalErrors, |
|
totalWarnings; |
|
|
|
const metaData = data ? data.rulesMeta : {}; |
|
|
|
totalErrors = 0; |
|
totalWarnings = 0; |
|
|
|
// Iterate over results to get totals |
|
results.forEach(result => { |
|
totalErrors += result.errorCount; |
|
totalWarnings += result.warningCount; |
|
}); |
|
|
|
return pageTemplate({ |
|
date: new Date(), |
|
reportColor: renderColor(totalErrors, totalWarnings), |
|
reportSummary: renderSummary(totalErrors, totalWarnings), |
|
results: renderResults(results, metaData) |
|
}); |
|
};
|
|
|