diff options
author | Nick Johnson <arachnid@notdot.net> | 2016-08-24 22:50:38 +0800 |
---|---|---|
committer | Nick Johnson <arachnid@notdot.net> | 2016-08-24 23:10:29 +0800 |
commit | 8923325d5c9e14e33478261b6c191e8fb092e1c4 (patch) | |
tree | 3188e4e6624ea79f05ee68bff5f6c7ca43d7bcad /internal/ethapi/tracer_test.go | |
parent | a2b2c8adc9dcd45e86ba26ce69db506c8d4b018a (diff) | |
download | dexon-8923325d5c9e14e33478261b6c191e8fb092e1c4.tar dexon-8923325d5c9e14e33478261b6c191e8fb092e1c4.tar.gz dexon-8923325d5c9e14e33478261b6c191e8fb092e1c4.tar.bz2 dexon-8923325d5c9e14e33478261b6c191e8fb092e1c4.tar.lz dexon-8923325d5c9e14e33478261b6c191e8fb092e1c4.tar.xz dexon-8923325d5c9e14e33478261b6c191e8fb092e1c4.tar.zst dexon-8923325d5c9e14e33478261b6c191e8fb092e1c4.zip |
internal/ethapi: Fix bug in opCodeWrapper usage
Diffstat (limited to 'internal/ethapi/tracer_test.go')
-rw-r--r-- | internal/ethapi/tracer_test.go | 25 |
1 files changed, 20 insertions, 5 deletions
diff --git a/internal/ethapi/tracer_test.go b/internal/ethapi/tracer_test.go index dbc38bbbc..301ff4840 100644 --- a/internal/ethapi/tracer_test.go +++ b/internal/ethapi/tracer_test.go @@ -19,6 +19,7 @@ package ethapi import ( "errors" "math/big" + "reflect" "testing" "time" @@ -140,12 +141,26 @@ func TestStack(t *testing.T) { t.Fatal(err) } - value, ok := ret.([]int) - if !ok { - t.Errorf("Expected return value to be []int, was %T", ret) + expected := []int{0, 1, 2} + if !reflect.DeepEqual(ret, expected) { + t.Errorf("Expected return value to be %#v, got %#v", expected, ret) + } +} + +func TestOpcodes(t *testing.T) { + tracer, err := NewJavascriptTracer("{opcodes: [], step: function(log) { this.opcodes.push(log.op.toString()); }, result: function() { return this.opcodes; }}") + if err != nil { + t.Fatal(err) } - if len(value) != 3 || value[0] != 0 || value[1] != 1 || value[2] != 2 { - t.Errorf("Expected return value to be [0 1 2], got %v", value) + + ret, err := runTrace(tracer) + if err != nil { + t.Fatal(err) + } + + expected := []string{"PUSH1", "PUSH1", "STOP"} + if !reflect.DeepEqual(ret, expected) { + t.Errorf("Expected return value to be %#v, got %#v", expected, ret) } } |