From 1f42c14dc89120cac3d23dada3451867ae4e0167 Mon Sep 17 00:00:00 2001 From: OpenNingia Date: Tue, 23 Jan 2018 10:27:02 +0100 Subject: [PATCH] fix cobertura parsing on Windows --- src/indicators.ts | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/src/indicators.ts b/src/indicators.ts index 8826076..389410c 100644 --- a/src/indicators.ts +++ b/src/indicators.ts @@ -61,8 +61,16 @@ export class Indicators { if (err) { return reject(err); } const section = data.find((lcovSection) => { // consider windows and linux file paths - const cleanFile = file.replace(/[\\\/]/g, ""); - const cleanLcovFileSection = lcovSection.file.replace(/[\\\/]/g, ""); + var cleanFile = file.replace(/[\\\/]/g, ""); + var cleanLcovFileSection = lcovSection.file.replace(/[\\\/]/g, ""); + + // on Windows remove drive letter from path because of cobertura format + // also convert both path to lowercase because Windows's filesystem is case insensitive + if ( process.platform === 'win32' ) { + cleanFile = cleanFile.substr(2).toLowerCase(); + cleanLcovFileSection = cleanLcovFileSection.toLowerCase(); + } + return cleanFile.includes(cleanLcovFileSection); }); @@ -100,6 +108,7 @@ export class Indicators { private filterCoverage(section: Section, coverageLines: ICoverageLines): ICoverageLines { section.lines.details.forEach((detail) => { + if (detail.line < 0) { return ; } const lineRange = new Range(detail.line - 1, 0, detail.line - 1, 0); if (detail.hit > 0) { coverageLines.full.push(lineRange); @@ -111,6 +120,7 @@ export class Indicators { if (section.branches) { section.branches.details.forEach((detail) => { if (detail.branch === 0 && detail.taken === 0) { + if (detail.line < 0) { return ; } const partialRange = new Range(detail.line - 1, 0, detail.line - 1, 0); if (coverageLines.full.find((range) => range.isEqual(partialRange))) { // remove full converage if partial is a better match