bbc4ea4ae8
The run loop, which previously contained custom opcode executes have been removed and has been simplified to a few checks. Each operation consists of 4 elements: execution function, gas cost function, stack validation function and memory size function. The execution function implements the operation's runtime behaviour, the gas cost function implements the operation gas costs function and greatly depends on the memory and stack, the stack validation function validates the stack and makes sure that enough items can be popped off and pushed on and the memory size function calculates the memory required for the operation and returns it. This commit also allows the EVM to go unmetered. This is helpful for offline operations such as contract calls.
987 lines
26 KiB
Go
987 lines
26 KiB
Go
// Copyright 2015 The go-ethereum Authors
|
|
// This file is part of the go-ethereum library.
|
|
//
|
|
// The go-ethereum library is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Lesser General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// The go-ethereum library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
package tests
|
|
|
|
import (
|
|
"math/big"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/ethereum/go-ethereum/params"
|
|
)
|
|
|
|
func BenchmarkStateCall1024(b *testing.B) {
|
|
fn := filepath.Join(stateTestDir, "stCallCreateCallCodeTest.json")
|
|
if err := BenchVmTest(fn, bconf{"Call1024BalanceTooLow", true, os.Getenv("JITVM") == "true"}, b); err != nil {
|
|
b.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateSystemOperations(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stSystemOperationsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateExample(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stExample.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStatePreCompiledContracts(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stPreCompiledContracts.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateRecursiveCreate(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stRecursiveCreate.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateSpecial(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stSpecialTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateRefund(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stRefundTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateBlockHash(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stBlockHashTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateInitCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stInitCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateLog(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stLogTests.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateTransaction(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stTransactionTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateTransition(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stTransitionTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestCallCreateCallCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stCallCreateCallCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestCallCodes(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stCallCodes.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestMemory(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stMemoryTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestMemoryStress(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "stMemoryStressTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestQuadraticComplexity(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "stQuadraticComplexityTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestSolidity(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stSolidityTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestWallet(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "stWalletTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestStateTestsRandom(t *testing.T) {
|
|
t.Skip()
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fns, _ := filepath.Glob("./files/StateTests/RandomTests/*")
|
|
for _, fn := range fns {
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(fn, err)
|
|
}
|
|
}
|
|
}
|
|
|
|
// homestead tests
|
|
func TestHomesteadDelegateCall(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: big.NewInt(1150000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stDelegatecallTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadStateSystemOperations(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stSystemOperationsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadStatePreCompiledContracts(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stPreCompiledContracts.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadStateRecursiveCreate(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stSpecialTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadStateRefund(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stRefundTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadStateInitCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stInitCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadStateLog(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stLogTests.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadStateTransaction(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stTransactionTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadCallCreateCallCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stCallCreateCallCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadCallCodes(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stCallCodes.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadMemory(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stMemoryTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadMemoryStress(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stMemoryStressTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadQuadraticComplexity(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stQuadraticComplexityTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadWallet(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stWalletTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadDelegateCodes(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stCallDelegateCodes.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadDelegateCodesCallCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stCallDelegateCodesCallCode.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHomesteadBounds(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "Homestead", "stBoundsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
// EIP150 tests
|
|
func TestEIP150Specific(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "stEIPSpecificTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150SingleCodeGasPrice(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "stEIPSingleCodeGasPrices.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150MemExpandingCalls(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "stMemExpandingEIPCalls.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadStateSystemOperations(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stSystemOperationsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadStatePreCompiledContracts(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stPreCompiledContracts.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadStateRecursiveCreate(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stSpecialTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadStateRefund(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stRefundTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadStateInitCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stInitCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadStateLog(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stLogTests.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadStateTransaction(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stTransactionTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadCallCreateCallCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stCallCreateCallCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadCallCodes(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stCallCodes.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadMemory(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stMemoryTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadMemoryStress(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stMemoryStressTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadQuadraticComplexity(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stQuadraticComplexityTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadWallet(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stWalletTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadDelegateCodes(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stCallDelegateCodes.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadDelegateCodesCallCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stCallDelegateCodesCallCode.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP150HomesteadBounds(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP150", "Homestead", "stBoundsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
// EIP158 tests
|
|
func TestEIP158Create(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "stCreateTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158Specific(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "stEIP158SpecificTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158NonZeroCalls(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "stNonZeroCallsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158ZeroCalls(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "stZeroCallsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158_150Specific(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "EIP150", "stEIPSpecificTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158_150SingleCodeGasPrice(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "EIP150", "stEIPsingleCodeGasPrices.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158_150MemExpandingCalls(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "EIP150", "stMemExpandingEIPCalls.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadStateSystemOperations(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stSystemOperationsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadStatePreCompiledContracts(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stPreCompiledContracts.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadStateRecursiveCreate(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stSpecialTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadStateRefund(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stRefundTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadStateInitCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stInitCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadStateLog(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stLogTests.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadStateTransaction(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stTransactionTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadCallCreateCallCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stCallCreateCallCodeTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadCallCodes(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stCallCodes.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadMemory(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stMemoryTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadMemoryStress(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stMemoryStressTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadQuadraticComplexity(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
if os.Getenv("TEST_VM_COMPLEX") == "" {
|
|
t.Skip()
|
|
}
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stQuadraticComplexityTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadWallet(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stWalletTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadDelegateCodes(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stCallDelegateCodes.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadDelegateCodesCallCode(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stCallDelegateCodesCallCode.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestEIP158HomesteadBounds(t *testing.T) {
|
|
chainConfig := ¶ms.ChainConfig{
|
|
HomesteadBlock: new(big.Int),
|
|
EIP150Block: big.NewInt(2457000),
|
|
EIP158Block: params.MainNetSpuriousDragon,
|
|
}
|
|
|
|
fn := filepath.Join(stateTestDir, "EIP158", "Homestead", "stBoundsTest.json")
|
|
if err := RunStateTest(chainConfig, fn, StateSkipTests); err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|