diff options
author | Fabio Berger <me@fabioberger.com> | 2018-03-12 19:32:32 +0800 |
---|---|---|
committer | Fabio Berger <me@fabioberger.com> | 2018-03-12 19:32:32 +0800 |
commit | d61379110486e5d741285fac0f988737c4013524 (patch) | |
tree | 77abc834c30c82b852e47dd317b6233fdaecd8bc /packages/sol-cov/src/coverage_manager.ts | |
parent | 44f7f79bd957dc54cbc562797d6785ad5b295d4f (diff) | |
parent | 1cdfbbadaa1363ed8f5ecfca61576db70c0c1fb1 (diff) | |
download | dexon-sol-tools-d61379110486e5d741285fac0f988737c4013524.tar dexon-sol-tools-d61379110486e5d741285fac0f988737c4013524.tar.gz dexon-sol-tools-d61379110486e5d741285fac0f988737c4013524.tar.bz2 dexon-sol-tools-d61379110486e5d741285fac0f988737c4013524.tar.lz dexon-sol-tools-d61379110486e5d741285fac0f988737c4013524.tar.xz dexon-sol-tools-d61379110486e5d741285fac0f988737c4013524.tar.zst dexon-sol-tools-d61379110486e5d741285fac0f988737c4013524.zip |
Merge branch 'feature/solcov' of github.com:0xProject/0x-monorepo into feature/solcov
* 'feature/solcov' of github.com:0xProject/0x-monorepo:
Add a HACK to detect coverage of the modifiers with no parameters
Diffstat (limited to 'packages/sol-cov/src/coverage_manager.ts')
-rw-r--r-- | packages/sol-cov/src/coverage_manager.ts | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/packages/sol-cov/src/coverage_manager.ts b/packages/sol-cov/src/coverage_manager.ts index 4ca6b0ec8..b70ca6f3f 100644 --- a/packages/sol-cov/src/coverage_manager.ts +++ b/packages/sol-cov/src/coverage_manager.ts @@ -69,6 +69,30 @@ export class CoverageManager { ); functionCoverage[fnId] = isCovered; } + // HACK: Solidity doesn't emit any opcodes that map back to modifiers with no args, that's why we map back to the + // function range and check if there is any covered statement within that range. + for (const modifierStatementId of coverageEntriesDescription.modifiersStatementIds) { + if (statementCoverage[modifierStatementId]) { + // Already detected as covered + continue; + } + const modifierDescription = coverageEntriesDescription.statementMap[modifierStatementId]; + const enclosingFunction = _.find(coverageEntriesDescription.fnMap, functionDescription => + utils.isRangeInside(modifierDescription, functionDescription.loc), + ) as FunctionDescription; + const isModifierCovered = _.some( + coverageEntriesDescription.statementMap, + (statementDescription: StatementDescription, statementId: number) => { + const isInsideTheModifierEnclosingFunction = utils.isRangeInside( + statementDescription, + enclosingFunction.loc, + ); + const isCovered = statementCoverage[statementId]; + return isInsideTheModifierEnclosingFunction && isCovered; + }, + ); + statementCoverage[modifierStatementId] = isModifierCovered; + } const partialCoverage = { [contractData.sources[fileIndex]]: { ...coverageEntriesDescription, |