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.
		
		
		
		
		
			
		
			
				
					
					
						
							127 lines
						
					
					
						
							3.5 KiB
						
					
					
				
			
		
		
	
	
							127 lines
						
					
					
						
							3.5 KiB
						
					
					
				/* | 
						|
 Copyright 2012-2015, Yahoo Inc. | 
						|
 Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms. | 
						|
 */ | 
						|
'use strict'; | 
						|
 | 
						|
const FileCoverage = require('./file').FileCoverage; | 
						|
const CoverageSummary = require('./file').CoverageSummary; | 
						|
 | 
						|
function loadMap(source) { | 
						|
    const data = Object.create(null); | 
						|
    Object.keys(source).forEach(k => { | 
						|
        const cov = source[k]; | 
						|
        if (cov instanceof FileCoverage) { | 
						|
            data[k] = cov; | 
						|
        } else { | 
						|
            data[k] = new FileCoverage(cov); | 
						|
        } | 
						|
    }); | 
						|
    return data; | 
						|
} | 
						|
/** | 
						|
 * CoverageMap is a map of `FileCoverage` objects keyed by file paths. | 
						|
 * @param {Object} [obj=undefined] obj A coverage map from which to initialize this | 
						|
 * map's contents. This can be the raw global coverage object. | 
						|
 * @constructor | 
						|
 */ | 
						|
function CoverageMap(obj) { | 
						|
    if (!obj) { | 
						|
        this.data = Object.create(null); | 
						|
    } else if (obj instanceof CoverageMap) { | 
						|
        this.data = obj.data; | 
						|
    } else { | 
						|
        this.data = loadMap(obj); | 
						|
    } | 
						|
} | 
						|
/** | 
						|
 * merges a second coverage map into this one | 
						|
 * @param {CoverageMap} obj - a CoverageMap or its raw data. Coverage is merged | 
						|
 *  correctly for the same files and additional file coverage keys are created | 
						|
 *  as needed. | 
						|
 */ | 
						|
CoverageMap.prototype.merge = function(obj) { | 
						|
    let other; | 
						|
    if (obj instanceof CoverageMap) { | 
						|
        other = obj; | 
						|
    } else { | 
						|
        other = new CoverageMap(obj); | 
						|
    } | 
						|
    Object.keys(other.data).forEach(k => { | 
						|
        const fc = other.data[k]; | 
						|
        if (this.data[k]) { | 
						|
            this.data[k].merge(fc); | 
						|
        } else { | 
						|
            this.data[k] = fc; | 
						|
        } | 
						|
    }); | 
						|
}; | 
						|
/** | 
						|
 * filter the coveragemap based on the callback provided | 
						|
 * @param {Function (filename)} callback - Returns true if the path | 
						|
 *  should be included in the coveragemap. False if it should be | 
						|
 *  removed. | 
						|
 */ | 
						|
CoverageMap.prototype.filter = function(callback) { | 
						|
    Object.keys(this.data).forEach(k => { | 
						|
        if (!callback(k)) { | 
						|
            delete this.data[k]; | 
						|
        } | 
						|
    }); | 
						|
}; | 
						|
/** | 
						|
 * returns a JSON-serializable POJO for this coverage map | 
						|
 * @returns {Object} | 
						|
 */ | 
						|
CoverageMap.prototype.toJSON = function() { | 
						|
    return this.data; | 
						|
}; | 
						|
/** | 
						|
 * returns an array for file paths for which this map has coverage | 
						|
 * @returns {Array{string}} - array of files | 
						|
 */ | 
						|
CoverageMap.prototype.files = function() { | 
						|
    return Object.keys(this.data); | 
						|
}; | 
						|
/** | 
						|
 * returns the file coverage for the specified file. | 
						|
 * @param {String} file | 
						|
 * @returns {FileCoverage} | 
						|
 */ | 
						|
CoverageMap.prototype.fileCoverageFor = function(file) { | 
						|
    const fc = this.data[file]; | 
						|
    if (!fc) { | 
						|
        throw new Error('No file coverage available for: ' + file); | 
						|
    } | 
						|
    return fc; | 
						|
}; | 
						|
/** | 
						|
 * adds a file coverage object to this map. If the path for the object, | 
						|
 * already exists in the map, it is merged with the existing coverage | 
						|
 * otherwise a new key is added to the map. | 
						|
 * @param {FileCoverage} fc the file coverage to add | 
						|
 */ | 
						|
CoverageMap.prototype.addFileCoverage = function(fc) { | 
						|
    const cov = new FileCoverage(fc); | 
						|
    const path = cov.path; | 
						|
    if (this.data[path]) { | 
						|
        this.data[path].merge(cov); | 
						|
    } else { | 
						|
        this.data[path] = cov; | 
						|
    } | 
						|
}; | 
						|
/** | 
						|
 * returns the coverage summary for all the file coverage objects in this map. | 
						|
 * @returns {CoverageSummary} | 
						|
 */ | 
						|
CoverageMap.prototype.getCoverageSummary = function() { | 
						|
    const ret = new CoverageSummary(); | 
						|
    this.files().forEach(key => { | 
						|
        ret.merge(this.fileCoverageFor(key).toSummary()); | 
						|
    }); | 
						|
    return ret; | 
						|
}; | 
						|
 | 
						|
module.exports = { | 
						|
    CoverageMap | 
						|
};
 | 
						|
 |