Ver Fonte

internal/ethapi: Fix bug in opCodeWrapper usage

Nick Johnson há 9 anos atrás
pai
commit
8923325d5c
2 ficheiros alterados com 23 adições e 6 exclusões
  1. 3 1
      internal/ethapi/tracer.go
  2. 20 5
      internal/ethapi/tracer_test.go

+ 3 - 1
internal/ethapi/tracer.go

@@ -284,8 +284,10 @@ func (jst *JavascriptTracer) CaptureState(env vm.Environment, pc uint64, op vm.O
 		jst.stack.stack = stack
 		jst.db.db = env.Db()
 
+		ocw := &opCodeWrapper{op}
+
 		jst.log["pc"] = pc
-		jst.log["op"] = &opCodeWrapper{op}
+		jst.log["op"] = ocw.toValue(jst.vm)
 		jst.log["gas"] = gas.Int64()
 		jst.log["gasPrice"] = cost.Int64()
 		jst.log["memory"] = jst.memvalue

+ 20 - 5
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)
 	}
 }