github.com/bamzi/go-ethereum@v1.6.7-0.20170704111104-138f26c93af1/core/vm/instructions_test.go (about)

     1  package vm
     2  
     3  import (
     4  	"fmt"
     5  	"math/big"
     6  	"testing"
     7  
     8  	"github.com/ethereum/go-ethereum/common"
     9  	"github.com/ethereum/go-ethereum/params"
    10  )
    11  
    12  func TestByteOp(t *testing.T) {
    13  	var (
    14  		env   = NewEVM(Context{}, nil, params.TestChainConfig, Config{EnableJit: false, ForceJit: false})
    15  		stack = newstack()
    16  	)
    17  	tests := []struct {
    18  		v        string
    19  		th       uint64
    20  		expected *big.Int
    21  	}{
    22  		{"ABCDEF0908070605040302010000000000000000000000000000000000000000", 0, big.NewInt(0xAB)},
    23  		{"ABCDEF0908070605040302010000000000000000000000000000000000000000", 1, big.NewInt(0xCD)},
    24  		{"00CDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff", 0, big.NewInt(0x00)},
    25  		{"00CDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff", 1, big.NewInt(0xCD)},
    26  		{"0000000000000000000000000000000000000000000000000000000000102030", 31, big.NewInt(0x30)},
    27  		{"0000000000000000000000000000000000000000000000000000000000102030", 30, big.NewInt(0x20)},
    28  		{"ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff", 32, big.NewInt(0x0)},
    29  		{"ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff", 0xFFFFFFFFFFFFFFFF, big.NewInt(0x0)},
    30  	}
    31  	pc := uint64(0)
    32  	for _, test := range tests {
    33  		val := new(big.Int).SetBytes(common.Hex2Bytes(test.v))
    34  		th := new(big.Int).SetUint64(test.th)
    35  		stack.push(val)
    36  		stack.push(th)
    37  		opByte(&pc, env, nil, nil, stack)
    38  		actual := stack.pop()
    39  		if actual.Cmp(test.expected) != 0 {
    40  			t.Fatalf("Expected  [%v] %v:th byte to be %v, was %v.", test.v, test.th, test.expected, actual)
    41  		}
    42  	}
    43  }
    44  
    45  func opBenchmark(bench *testing.B, op func(pc *uint64, evm *EVM, contract *Contract, memory *Memory, stack *Stack) ([]byte, error), args ...string) {
    46  	var (
    47  		env   = NewEVM(Context{}, nil, params.TestChainConfig, Config{EnableJit: false, ForceJit: false})
    48  		stack = newstack()
    49  	)
    50  	// convert args
    51  	byteArgs := make([][]byte, len(args))
    52  	for i, arg := range args {
    53  		byteArgs[i] = common.Hex2Bytes(arg)
    54  	}
    55  	pc := uint64(0)
    56  	bench.ResetTimer()
    57  	for i := 0; i < bench.N; i++ {
    58  		for _, arg := range byteArgs {
    59  			a := new(big.Int).SetBytes(arg)
    60  			stack.push(a)
    61  		}
    62  		op(&pc, env, nil, nil, stack)
    63  		stack.pop()
    64  	}
    65  }
    66  
    67  func precompiledBenchmark(addr, input, expected string, gas uint64, bench *testing.B) {
    68  
    69  	contract := NewContract(AccountRef(common.HexToAddress("1337")),
    70  		nil, new(big.Int), gas)
    71  
    72  	p := PrecompiledContracts[common.HexToAddress(addr)]
    73  	in := common.Hex2Bytes(input)
    74  	var (
    75  		res []byte
    76  		err error
    77  	)
    78  	data := make([]byte, len(in))
    79  	bench.ResetTimer()
    80  	for i := 0; i < bench.N; i++ {
    81  		contract.Gas = gas
    82  		copy(data, in)
    83  		res, err = RunPrecompiledContract(p, data, contract)
    84  	}
    85  	bench.StopTimer()
    86  	//Check if it is correct
    87  	if err != nil {
    88  		bench.Error(err)
    89  		return
    90  	}
    91  	if common.Bytes2Hex(res) != expected {
    92  		bench.Error(fmt.Sprintf("Expected %v, got %v", expected, common.Bytes2Hex(res)))
    93  		return
    94  	}
    95  }
    96  
    97  func BenchmarkPrecompiledEcdsa(bench *testing.B) {
    98  	var (
    99  		addr = "01"
   100  		inp  = "38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e000000000000000000000000000000000000000000000000000000000000001b38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e789d1dd423d25f0772d2748d60f7e4b81bb14d086eba8e8e8efb6dcff8a4ae02"
   101  		exp  = "000000000000000000000000ceaccac640adf55b2028469bd36ba501f28b699d"
   102  		gas  = uint64(4000000)
   103  	)
   104  	precompiledBenchmark(addr, inp, exp, gas, bench)
   105  }
   106  func BenchmarkPrecompiledSha256(bench *testing.B) {
   107  	var (
   108  		addr = "02"
   109  		inp  = "38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e000000000000000000000000000000000000000000000000000000000000001b38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e789d1dd423d25f0772d2748d60f7e4b81bb14d086eba8e8e8efb6dcff8a4ae02"
   110  		exp  = "811c7003375852fabd0d362e40e68607a12bdabae61a7d068fe5fdd1dbbf2a5d"
   111  		gas  = uint64(4000000)
   112  	)
   113  	precompiledBenchmark(addr, inp, exp, gas, bench)
   114  }
   115  func BenchmarkPrecompiledRipeMD(bench *testing.B) {
   116  	var (
   117  		addr = "03"
   118  		inp  = "38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e000000000000000000000000000000000000000000000000000000000000001b38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e789d1dd423d25f0772d2748d60f7e4b81bb14d086eba8e8e8efb6dcff8a4ae02"
   119  		exp  = "0000000000000000000000009215b8d9882ff46f0dfde6684d78e831467f65e6"
   120  		gas  = uint64(4000000)
   121  	)
   122  	precompiledBenchmark(addr, inp, exp, gas, bench)
   123  }
   124  func BenchmarkPrecompiledIdentity(bench *testing.B) {
   125  	var (
   126  		addr = "04"
   127  		inp  = "38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e000000000000000000000000000000000000000000000000000000000000001b38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e789d1dd423d25f0772d2748d60f7e4b81bb14d086eba8e8e8efb6dcff8a4ae02"
   128  		exp  = "38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e000000000000000000000000000000000000000000000000000000000000001b38d18acb67d25c8bb9942764b62f18e17054f66a817bd4295423adf9ed98873e789d1dd423d25f0772d2748d60f7e4b81bb14d086eba8e8e8efb6dcff8a4ae02"
   129  		gas  = uint64(4000000)
   130  	)
   131  	precompiledBenchmark(addr, inp, exp, gas, bench)
   132  }
   133  func BenchmarkOpAdd(b *testing.B) {
   134  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   135  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   136  
   137  	opBenchmark(b, opAdd, x, y)
   138  
   139  }
   140  func BenchmarkOpSub(b *testing.B) {
   141  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   142  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   143  
   144  	opBenchmark(b, opSub, x, y)
   145  
   146  }
   147  func BenchmarkOpMul(b *testing.B) {
   148  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   149  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   150  
   151  	opBenchmark(b, opMul, x, y)
   152  
   153  }
   154  func BenchmarkOpDiv(b *testing.B) {
   155  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   156  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   157  
   158  	opBenchmark(b, opDiv, x, y)
   159  
   160  }
   161  func BenchmarkOpSdiv(b *testing.B) {
   162  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   163  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   164  
   165  	opBenchmark(b, opSdiv, x, y)
   166  
   167  }
   168  func BenchmarkOpMod(b *testing.B) {
   169  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   170  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   171  
   172  	opBenchmark(b, opMod, x, y)
   173  
   174  }
   175  func BenchmarkOpSmod(b *testing.B) {
   176  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   177  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   178  
   179  	opBenchmark(b, opSmod, x, y)
   180  
   181  }
   182  func BenchmarkOpExp(b *testing.B) {
   183  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   184  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   185  
   186  	opBenchmark(b, opExp, x, y)
   187  
   188  }
   189  func BenchmarkOpSignExtend(b *testing.B) {
   190  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   191  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   192  
   193  	opBenchmark(b, opSignExtend, x, y)
   194  
   195  }
   196  func BenchmarkOpLt(b *testing.B) {
   197  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   198  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   199  
   200  	opBenchmark(b, opLt, x, y)
   201  
   202  }
   203  func BenchmarkOpGt(b *testing.B) {
   204  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   205  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   206  
   207  	opBenchmark(b, opGt, x, y)
   208  
   209  }
   210  func BenchmarkOpSlt(b *testing.B) {
   211  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   212  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   213  
   214  	opBenchmark(b, opSlt, x, y)
   215  
   216  }
   217  func BenchmarkOpSgt(b *testing.B) {
   218  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   219  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   220  
   221  	opBenchmark(b, opSgt, x, y)
   222  
   223  }
   224  func BenchmarkOpEq(b *testing.B) {
   225  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   226  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   227  
   228  	opBenchmark(b, opEq, x, y)
   229  
   230  }
   231  func BenchmarkOpAnd(b *testing.B) {
   232  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   233  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   234  
   235  	opBenchmark(b, opAnd, x, y)
   236  
   237  }
   238  func BenchmarkOpOr(b *testing.B) {
   239  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   240  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   241  
   242  	opBenchmark(b, opOr, x, y)
   243  
   244  }
   245  func BenchmarkOpXor(b *testing.B) {
   246  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   247  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   248  
   249  	opBenchmark(b, opXor, x, y)
   250  
   251  }
   252  func BenchmarkOpByte(b *testing.B) {
   253  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   254  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   255  
   256  	opBenchmark(b, opByte, x, y)
   257  
   258  }
   259  
   260  func BenchmarkOpAddmod(b *testing.B) {
   261  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   262  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   263  	z := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   264  
   265  	opBenchmark(b, opAddmod, x, y, z)
   266  
   267  }
   268  func BenchmarkOpMulmod(b *testing.B) {
   269  	x := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   270  	y := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   271  	z := "ABCDEF090807060504030201ffffffffffffffffffffffffffffffffffffffff"
   272  
   273  	opBenchmark(b, opMulmod, x, y, z)
   274  
   275  }
   276  
   277  //func BenchmarkOpSha3(b *testing.B) {
   278  //	x := "0"
   279  //	y := "32"
   280  //
   281  //	opBenchmark(b,opSha3, x, y)
   282  //
   283  //
   284  //}