Add coverage measurement category options (#592)
parent
c1bd4bcd64
commit
0ac8e742d7
@ -0,0 +1,121 @@ |
|||||||
|
const assert = require('assert'); |
||||||
|
const util = require('./../util/util.js'); |
||||||
|
|
||||||
|
const client = require('ganache-cli'); |
||||||
|
const Coverage = require('./../../lib/coverage'); |
||||||
|
const Api = require('./../../lib/api') |
||||||
|
|
||||||
|
describe('measureCoverage options', () => { |
||||||
|
let coverage; |
||||||
|
let api; |
||||||
|
|
||||||
|
before(async () => { |
||||||
|
api = new Api({silent: true}); |
||||||
|
await api.ganache(client); |
||||||
|
}) |
||||||
|
beforeEach(() => { |
||||||
|
api.config = {} |
||||||
|
coverage = new Coverage() |
||||||
|
}); |
||||||
|
after(async() => await api.finish()); |
||||||
|
|
||||||
|
async function setupAndRun(solidityFile, val){ |
||||||
|
const contract = await util.bootstrapCoverage(solidityFile, api); |
||||||
|
coverage.addContract(contract.instrumented, util.filePath); |
||||||
|
|
||||||
|
/* some methods intentionally fail */ |
||||||
|
try { |
||||||
|
(val) |
||||||
|
? await contract.instance.a(val) |
||||||
|
: await contract.instance.a(); |
||||||
|
} catch(e){} |
||||||
|
|
||||||
|
return coverage.generate(contract.data, util.pathPrefix); |
||||||
|
} |
||||||
|
|
||||||
|
// if (x == 1 || x == 2) { } else ...
|
||||||
|
it('should ignore OR branches when measureBranchCoverage = false', async function() { |
||||||
|
api.config.measureBranchCoverage = false; |
||||||
|
const mapping = await setupAndRun('or/if-or', 1); |
||||||
|
|
||||||
|
assert.deepEqual(mapping[util.filePath].l, { |
||||||
|
5: 1, 8: 0 |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].b, {}); |
||||||
|
assert.deepEqual(mapping[util.filePath].s, { |
||||||
|
1: 1, 2: 0, |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].f, { |
||||||
|
1: 1, |
||||||
|
}); |
||||||
|
}); |
||||||
|
|
||||||
|
it('should ignore if/else branches when measureBranchCoverage = false', async function() { |
||||||
|
api.config.measureBranchCoverage = false; |
||||||
|
const mapping = await setupAndRun('if/if-with-brackets', 1); |
||||||
|
|
||||||
|
assert.deepEqual(mapping[util.filePath].l, { |
||||||
|
5: 1, |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].b, {}); |
||||||
|
assert.deepEqual(mapping[util.filePath].s, { |
||||||
|
1: 1, 2: 1, |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].f, { |
||||||
|
1: 1, |
||||||
|
}); |
||||||
|
}); |
||||||
|
|
||||||
|
it('should ignore ternary conditionals when measureBranchCoverage = false', async function() { |
||||||
|
api.config.measureBranchCoverage = false; |
||||||
|
const mapping = await setupAndRun('conditional/sameline-consequent'); |
||||||
|
|
||||||
|
assert.deepEqual(mapping[util.filePath].l, { |
||||||
|
5: 1, 6: 1, 7: 1, |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].b, {}); |
||||||
|
|
||||||
|
assert.deepEqual(mapping[util.filePath].s, { |
||||||
|
1: 1, 2: 1, 3: 1, |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].f, { |
||||||
|
1: 1, |
||||||
|
}); |
||||||
|
}); |
||||||
|
|
||||||
|
it('should ignore modifier branches when measureModifierCoverage = false', async function() { |
||||||
|
api.config.measureModifierCoverage = false; |
||||||
|
const mapping = await setupAndRun('modifiers/same-contract-pass'); |
||||||
|
|
||||||
|
assert.deepEqual(mapping[util.filePath].l, { |
||||||
|
5: 1, 6: 1, 10: 1, |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].b, { // Source contains a `require`
|
||||||
|
1: [1, 0] |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].s, { |
||||||
|
1: 1, 2: 1, |
||||||
|
}); |
||||||
|
assert.deepEqual(mapping[util.filePath].f, { |
||||||
|
1: 1, 2: 1 |
||||||
|
}); |
||||||
|
}); |
||||||
|
|
||||||
|
it('should ignore statements when measureStatementCoverage = false', async function() { |
||||||
|
api.config.measureStatementCoverage = false; |
||||||
|
const mapping = await setupAndRun('modifiers/same-contract-pass'); |
||||||
|
assert.deepEqual(mapping[util.filePath].s, {}); |
||||||
|
}); |
||||||
|
|
||||||
|
it('should ignore lines when measureLineCoverage = false', async function() { |
||||||
|
api.config.measureLineCoverage = false; |
||||||
|
const mapping = await setupAndRun('modifiers/same-contract-pass'); |
||||||
|
assert.deepEqual(mapping[util.filePath].l, {}); |
||||||
|
}); |
||||||
|
|
||||||
|
it('should ignore functions when measureFunctionCoverage = false', async function() { |
||||||
|
api.config.measureFunctionCoverage = false; |
||||||
|
const mapping = await setupAndRun('modifiers/same-contract-pass'); |
||||||
|
assert.deepEqual(mapping[util.filePath].f, {}); |
||||||
|
}); |
||||||
|
}); |
Loading…
Reference in new issue