source-coverage.js 2.68 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.SourceCoverage = void 0;

var _istanbulLibCoverage = require("istanbul-lib-coverage");

function cloneLocation(loc) {
  return {
    start: {
      line: loc && loc.start.line,
      column: loc && loc.start.column
    },
    end: {
      line: loc && loc.end.line,
      column: loc && loc.end.column
    }
  };
}
/**
 * SourceCoverage provides mutation methods to manipulate the structure of
 * a file coverage object. Used by the instrumenter to create a full coverage
 * object for a file incrementally.
 *
 * @private
 * @param pathOrObj {String|Object} - see the argument for {@link FileCoverage}
 * @extends FileCoverage
 * @constructor
 */


class SourceCoverage extends _istanbulLibCoverage.classes.FileCoverage {
  constructor(pathOrObj) {
    super(pathOrObj);
    this.meta = {
      last: {
        s: 0,
        f: 0,
        b: 0
      }
    };
  }

  newStatement(loc) {
    const s = this.meta.last.s;
    this.data.statementMap[s] = cloneLocation(loc);
    this.data.s[s] = 0;
    this.meta.last.s += 1;
    return s;
  }

  newFunction(name, decl, loc) {
    const f = this.meta.last.f;
    name = name || '(anonymous_' + f + ')';
    this.data.fnMap[f] = {
      name,
      decl: cloneLocation(decl),
      loc: cloneLocation(loc),
      // DEPRECATED: some legacy reports require this info.
      line: loc && loc.start.line
    };
    this.data.f[f] = 0;
    this.meta.last.f += 1;
    return f;
  }

  newBranch(type, loc) {
    const b = this.meta.last.b;
    this.data.b[b] = [];
    this.data.branchMap[b] = {
      loc: cloneLocation(loc),
      type,
      locations: [],
      // DEPRECATED: some legacy reports require this info.
      line: loc && loc.start.line
    };
    this.meta.last.b += 1;
    return b;
  }

  addBranchPath(name, location) {
    const bMeta = this.data.branchMap[name];
    const counts = this.data.b[name];
    /* istanbul ignore if: paranoid check */

    if (!bMeta) {
      throw new Error('Invalid branch ' + name);
    }

    bMeta.locations.push(cloneLocation(location));
    counts.push(0);
    return counts.length - 1;
  }
  /**
   * Assigns an input source map to the coverage that can be used
   * to remap the coverage output to the original source
   * @param sourceMap {object} the source map
   */


  inputSourceMap(sourceMap) {
    this.data.inputSourceMap = sourceMap;
  }

  freeze() {
    // prune empty branches
    const map = this.data.branchMap;
    const branches = this.data.b;
    Object.keys(map).forEach(b => {
      if (map[b].locations.length === 0) {
        delete map[b];
        delete branches[b];
      }
    });
  }

}

exports.SourceCoverage = SourceCoverage;