aboutsummaryrefslogtreecommitdiffstats
path: root/packages/sol-cov/src/utils.ts
diff options
context:
space:
mode:
authorAlex Browne <stephenalexbrowne@gmail.com>2018-06-22 04:50:30 +0800
committerGitHub <noreply@github.com>2018-06-22 04:50:30 +0800
commitc7159b2be443ff3cc123472afbce9b443cdee2d5 (patch)
treeb5c4949af009b301ce13539a8080eb60ccb4e2d6 /packages/sol-cov/src/utils.ts
parent2d98193c832958844579e1c44d2771f5b11b6dbf (diff)
parent4cf331067bfa2a99ea39551f9fb2ad330b1c3fb7 (diff)
downloaddexon-sol-tools-c7159b2be443ff3cc123472afbce9b443cdee2d5.tar
dexon-sol-tools-c7159b2be443ff3cc123472afbce9b443cdee2d5.tar.gz
dexon-sol-tools-c7159b2be443ff3cc123472afbce9b443cdee2d5.tar.bz2
dexon-sol-tools-c7159b2be443ff3cc123472afbce9b443cdee2d5.tar.lz
dexon-sol-tools-c7159b2be443ff3cc123472afbce9b443cdee2d5.tar.xz
dexon-sol-tools-c7159b2be443ff3cc123472afbce9b443cdee2d5.tar.zst
dexon-sol-tools-c7159b2be443ff3cc123472afbce9b443cdee2d5.zip
Merge pull request #747 from 0xProject/fix/sol-cov-bugs
Fix some bugs in sol-cov
Diffstat (limited to 'packages/sol-cov/src/utils.ts')
-rw-r--r--packages/sol-cov/src/utils.ts12
1 files changed, 12 insertions, 0 deletions
diff --git a/packages/sol-cov/src/utils.ts b/packages/sol-cov/src/utils.ts
index d31696636..b696bd463 100644
--- a/packages/sol-cov/src/utils.ts
+++ b/packages/sol-cov/src/utils.ts
@@ -5,6 +5,10 @@ import * as _ from 'lodash';
import { ContractData, LineColumn, SingleFileSourceRange } from './types';
+// This is the minimum length of valid contract bytecode. The Solidity compiler
+// metadata is 86 bytes. If you add the '0x' prefix, we get 88.
+const MIN_CONTRACT_BYTECODE_LENGTH = 88;
+
export const utils = {
compareLineColumn(lhs: LineColumn, rhs: LineColumn): number {
return lhs.line !== rhs.line ? lhs.line - rhs.line : lhs.column - rhs.column;
@@ -38,7 +42,15 @@ export const utils = {
}
const contractData = _.find(contractsData, contractDataCandidate => {
const bytecodeRegex = utils.bytecodeToBytecodeRegex(contractDataCandidate.bytecode);
+ // If the bytecode is less than the minimum length, we are probably
+ // dealing with an interface. This isn't what we're looking for.
+ if (bytecodeRegex.length < MIN_CONTRACT_BYTECODE_LENGTH) {
+ return false;
+ }
const runtimeBytecodeRegex = utils.bytecodeToBytecodeRegex(contractDataCandidate.runtimeBytecode);
+ if (runtimeBytecodeRegex.length < MIN_CONTRACT_BYTECODE_LENGTH) {
+ return false;
+ }
// We use that function to find by bytecode or runtimeBytecode. Those are quasi-random strings so
// collisions are practically impossible and it allows us to reuse that code
return !_.isNull(bytecode.match(bytecodeRegex)) || !_.isNull(bytecode.match(runtimeBytecodeRegex));