From 2cb325c0a87e75bc56dc0ee38c6decfb4414719c Mon Sep 17 00:00:00 2001 From: Koen Van Geert Date: Thu, 7 Dec 2023 17:01:08 +0100 Subject: [PATCH] feat: improve performance combining coverage on large codebases --- task.js | 26 +++++++++++--------------- 1 file changed, 11 insertions(+), 15 deletions(-) diff --git a/task.js b/task.js index fc505155..9cf1eca7 100644 --- a/task.js +++ b/task.js @@ -12,9 +12,9 @@ const { includeAllFiles } = require('./task-utils') const { fixSourcePaths } = require('./support-utils') -const { removePlaceholders } = require('./common-utils') const debug = require('debug')('code-coverage') +require('debug').enable('code-coverage') // these are standard folder and file names used by NYC tools const processWorkingDirectory = process.cwd() @@ -59,6 +59,13 @@ const nycReportOptions = (function getNycOption() { const nycFilename = join(nycReportOptions['temp-dir'], 'out.json') +let coverageMap = (() => { + const previousCoverage = existsSync(nycFilename) + ? JSON.parse(readFileSync(nycFilename, 'utf8')) + : {} + return istanbul.createCoverageMap(previousCoverage) +})() + function saveCoverage(coverage) { if (!existsSync(nycReportOptions.tempDir)) { mkdirSync(nycReportOptions.tempDir, { recursive: true }) @@ -122,7 +129,7 @@ const tasks = { resetCoverage({ isInteractive }) { if (isInteractive) { debug('reset code coverage in interactive mode') - const coverageMap = istanbul.createCoverageMap({}) + coverageMap = istanbul.createCoverageMap({}) saveCoverage(coverageMap) } /* @@ -148,21 +155,9 @@ const tasks = { fixSourcePaths(coverage) - const previousCoverage = existsSync(nycFilename) - ? JSON.parse(readFileSync(nycFilename, 'utf8')) - : {} - - // previous code coverage object might have placeholder entries - // for files that we have not seen yet, - // but the user expects to include in the coverage report - // the merge function messes up, so we should remove any placeholder entries - // and re-insert them again when creating the report - removePlaceholders(previousCoverage) + console.log(coverageMap.toJSON()) - const coverageMap = istanbul.createCoverageMap(previousCoverage) coverageMap.merge(coverage) - saveCoverage(coverageMap) - debug('wrote coverage file %s', nycFilename) return null }, @@ -172,6 +167,7 @@ const tasks = { * NPM script to generate HTML report */ coverageReport() { + saveCoverage(coverageMap) if (!existsSync(nycFilename)) { console.warn('Cannot find coverage file %s', nycFilename) console.warn('Skipping coverage report')