aboutsummaryrefslogtreecommitdiffstats
path: root/packages/sol-cov/src/coverage_manager.ts
diff options
context:
space:
mode:
authorFabio Berger <me@fabioberger.com>2018-03-12 19:32:32 +0800
committerFabio Berger <me@fabioberger.com>2018-03-12 19:32:32 +0800
commitd61379110486e5d741285fac0f988737c4013524 (patch)
tree77abc834c30c82b852e47dd317b6233fdaecd8bc /packages/sol-cov/src/coverage_manager.ts
parent44f7f79bd957dc54cbc562797d6785ad5b295d4f (diff)
parent1cdfbbadaa1363ed8f5ecfca61576db70c0c1fb1 (diff)
downloaddexon-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.ts24
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,