aboutsummaryrefslogtreecommitdiffstats
path: root/packages/sol-tracing-utils/test/instructions_test.ts
diff options
context:
space:
mode:
authorLeonid Logvinov <logvinov.leon@gmail.com>2019-01-10 21:35:13 +0800
committerGitHub <noreply@github.com>2019-01-10 21:35:13 +0800
commit6c22594882c94146519ec6e3b24d558127bd092c (patch)
tree522c5ee89e4af0948b8e645237678f46ec8d3d5c /packages/sol-tracing-utils/test/instructions_test.ts
parent686f27a96f0cd749f6315d7edd2bb56cf1819245 (diff)
parentb8e3829fdbd1f516686618562172cb45fbb63bde (diff)
downloaddexon-sol-tools-6c22594882c94146519ec6e3b24d558127bd092c.tar
dexon-sol-tools-6c22594882c94146519ec6e3b24d558127bd092c.tar.gz
dexon-sol-tools-6c22594882c94146519ec6e3b24d558127bd092c.tar.bz2
dexon-sol-tools-6c22594882c94146519ec6e3b24d558127bd092c.tar.lz
dexon-sol-tools-6c22594882c94146519ec6e3b24d558127bd092c.tar.xz
dexon-sol-tools-6c22594882c94146519ec6e3b24d558127bd092c.tar.zst
dexon-sol-tools-6c22594882c94146519ec6e3b24d558127bd092c.zip
Merge pull request #1492 from 0xProject/feature/sol-cov-sol-profiler-sol-trace-divorce
Refactor out sol-cov, sol-profiler and sol-trace into their separate packages
Diffstat (limited to 'packages/sol-tracing-utils/test/instructions_test.ts')
-rw-r--r--packages/sol-tracing-utils/test/instructions_test.ts19
1 files changed, 19 insertions, 0 deletions
diff --git a/packages/sol-tracing-utils/test/instructions_test.ts b/packages/sol-tracing-utils/test/instructions_test.ts
new file mode 100644
index 000000000..058053cf9
--- /dev/null
+++ b/packages/sol-tracing-utils/test/instructions_test.ts
@@ -0,0 +1,19 @@
+import * as chai from 'chai';
+import 'mocha';
+
+import { constants } from '../src/constants';
+import { getPcToInstructionIndexMapping } from '../src/instructions';
+
+const expect = chai.expect;
+
+describe('instructions', () => {
+ describe('#getPcToInstructionIndexMapping', () => {
+ it('correctly maps pcs to instruction indexed', () => {
+ // tslint:disable-next-line:custom-no-magic-numbers
+ const bytecode = new Uint8Array([constants.PUSH1, 42, constants.PUSH2, 1, 2, constants.TIMESTAMP]);
+ const pcToInstruction = getPcToInstructionIndexMapping(bytecode);
+ const expectedPcToInstruction = { '0': 0, '2': 1, '5': 2 };
+ expect(pcToInstruction).to.be.deep.equal(expectedPcToInstruction);
+ });
+ });
+});