Add initial code coverage reporting
This commit is contained in:
parent
15e6028f38
commit
afdff69482
4 changed files with 53 additions and 1 deletions
|
@ -5,9 +5,11 @@
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"basic-auth": "^1.0.0",
|
"basic-auth": "^1.0.0",
|
||||||
|
"glob": "^7.0.5",
|
||||||
"graceful-fs": "3.0.5",
|
"graceful-fs": "3.0.5",
|
||||||
"mocha": "2.1.0",
|
"istanbul": "^0.4.4",
|
||||||
"mkdirp": "0.5.1",
|
"mkdirp": "0.5.1",
|
||||||
|
"mocha": "2.1.0",
|
||||||
"multiparty": "4.1.2",
|
"multiparty": "4.1.2",
|
||||||
"q": "0.9.7",
|
"q": "0.9.7",
|
||||||
"temp": "0.8.1",
|
"temp": "0.8.1",
|
||||||
|
|
45
spec/static/coverage.js
Normal file
45
spec/static/coverage.js
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
const fs = require('fs')
|
||||||
|
const glob = require('glob')
|
||||||
|
const path = require('path')
|
||||||
|
const {ipcRenderer} = require('electron')
|
||||||
|
const {Collector, Instrumenter, Reporter} = require('istanbul')
|
||||||
|
|
||||||
|
const addUnrequiredFiles = (coverage) => {
|
||||||
|
const instrumenter = new Instrumenter()
|
||||||
|
const transformer = instrumenter.instrumentSync.bind(instrumenter)
|
||||||
|
const libPath = path.join(__dirname, '..', '..', 'lib')
|
||||||
|
|
||||||
|
glob.sync('**/*.js', {cwd: libPath}).map(function (relativePath) {
|
||||||
|
return path.join(libPath, relativePath)
|
||||||
|
}).filter(function (filePath) {
|
||||||
|
return coverage[filePath] == null
|
||||||
|
}).forEach(function (filePath) {
|
||||||
|
transformer(fs.readFileSync(filePath, 'utf8'), filePath)
|
||||||
|
|
||||||
|
// When instrumenting the code, istanbul will give each FunctionDeclaration
|
||||||
|
// a value of 1 in coverState.s,presumably to compensate for function
|
||||||
|
// hoisting. We need to reset this, as the function was not hoisted, as it
|
||||||
|
// was never loaded.
|
||||||
|
Object.keys(instrumenter.coverState.s).forEach(function (key) {
|
||||||
|
instrumenter.coverState.s[key] = 0
|
||||||
|
});
|
||||||
|
|
||||||
|
coverage[filePath] = instrumenter.coverState
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
exports.generate = () => {
|
||||||
|
const coverage = window.__coverage__
|
||||||
|
if (coverage == null) return
|
||||||
|
|
||||||
|
addUnrequiredFiles(coverage)
|
||||||
|
|
||||||
|
const collector = new Collector()
|
||||||
|
collector.add(coverage)
|
||||||
|
collector.add(ipcRenderer.sendSync('get-coverage'))
|
||||||
|
|
||||||
|
const outPath = path.join(__dirname, '..', '..', 'out', 'coverage')
|
||||||
|
const reporter = new Reporter(null, outPath)
|
||||||
|
reporter.addAll(['text', 'lcov'])
|
||||||
|
reporter.write(collector, true, function () {})
|
||||||
|
}
|
|
@ -83,6 +83,7 @@
|
||||||
Mocha.utils.highlightTags('code');
|
Mocha.utils.highlightTags('code');
|
||||||
if (isCi)
|
if (isCi)
|
||||||
ipcRenderer.send('process.exit', runner.failures);
|
ipcRenderer.send('process.exit', runner.failures);
|
||||||
|
require('./coverage').generate()
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
})();
|
})();
|
||||||
|
|
|
@ -63,6 +63,10 @@ ipcMain.on('echo', function (event, msg) {
|
||||||
event.returnValue = msg
|
event.returnValue = msg
|
||||||
})
|
})
|
||||||
|
|
||||||
|
ipcMain.on('get-coverage', function(event) {
|
||||||
|
event.returnValue = global.__coverage__
|
||||||
|
})
|
||||||
|
|
||||||
global.isCi = !!argv.ci
|
global.isCi = !!argv.ci
|
||||||
if (global.isCi) {
|
if (global.isCi) {
|
||||||
process.removeAllListeners('uncaughtException')
|
process.removeAllListeners('uncaughtException')
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue