 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package tests implements execution of Ethereum JSON tests.
Index ¶
- Variables
- func BenchStateTest(ruleSet RuleSet, p string, conf bconf, b *testing.B) error
- func BenchVmTest(p string, conf bconf, b *testing.B) error
- func LoadBlockTests(file string) (map[string]*BlockTest, error)
- func RunBlockTest(homesteadBlock, daoForkBlock *big.Int, file string, skipTests []string) error
- func RunBlockTestWithReader(homesteadBlock, daoForkBlock *big.Int, r io.Reader, skipTests []string) error
- func RunRLPTest(file string, skip []string) error
- func RunRLPTestWithReader(r io.Reader, skip []string) error
- func RunState(ruleSet RuleSet, statedb *state.StateDB, env, tx map[string]string) ([]byte, vm.Logs, *big.Int, error)
- func RunStateTest(ruleSet RuleSet, p string, skipTests []string) error
- func RunStateTestWithReader(ruleSet RuleSet, r io.Reader, skipTests []string) error
- func RunTransactionTests(file string, skipTests []string) error
- func RunTransactionTestsWithReader(r io.Reader, skipTests []string) error
- func RunVm(state *state.StateDB, env, exec map[string]string) ([]byte, vm.Logs, *big.Int, error)
- func RunVmTest(p string, skipTests []string) error
- func RunVmTestWithReader(r io.Reader, skipTests []string) error
- func StateObjectFromAccount(db ethdb.Database, addr string, account Account) *state.StateObject
- type Account
- type BlockTest
- func (t *BlockTest) InsertPreState(db ethdb.Database) (*state.StateDB, error)
- func (t *BlockTest) TryBlocksInsert(blockchain *core.BlockChain) ([]btBlock, error)
- func (test *BlockTest) ValidateImportedHeaders(cm *core.BlockChain, validBlocks []btBlock) error
- func (t *BlockTest) ValidatePostState(statedb *state.StateDB) error
 
- type Env
- func (self *Env) AddLog(log *vm.Log)
- func (self *Env) AddStructLog(log vm.StructLog)
- func (self *Env) BlockNumber() *big.Int
- func (self *Env) Call(caller vm.ContractRef, addr common.Address, data []byte, ...) ([]byte, error)
- func (self *Env) CallCode(caller vm.ContractRef, addr common.Address, data []byte, ...) ([]byte, error)
- func (self *Env) CanTransfer(from common.Address, balance *big.Int) bool
- func (self *Env) Coinbase() common.Address
- func (self *Env) Create(caller vm.ContractRef, data []byte, gas, price, value *big.Int) ([]byte, common.Address, error)
- func (self *Env) Db() vm.Database
- func (self *Env) DelegateCall(caller vm.ContractRef, addr common.Address, data []byte, gas, price *big.Int) ([]byte, error)
- func (self *Env) Depth() int
- func (self *Env) Difficulty() *big.Int
- func (self *Env) GasLimit() *big.Int
- func (self *Env) GetHash(n uint64) common.Hash
- func (self *Env) MakeSnapshot() vm.Database
- func (self *Env) Origin() common.Address
- func (self *Env) RuleSet() vm.RuleSet
- func (self *Env) SetDepth(i int)
- func (self *Env) SetSnapshot(copy vm.Database)
- func (self *Env) StructLogs() []vm.StructLog
- func (self *Env) Time() *big.Int
- func (self *Env) Transfer(from, to vm.Account, amount *big.Int)
- func (self *Env) Vm() vm.Vm
- func (self *Env) VmType() vm.Type
 
- type Log
- type Message
- func (self Message) Data() []byte
- func (self Message) From() (common.Address, error)
- func (self Message) FromFrontier() (common.Address, error)
- func (self Message) Gas() *big.Int
- func (self Message) GasPrice() *big.Int
- func (self Message) Hash() []byte
- func (self Message) Nonce() uint64
- func (self Message) To() *common.Address
- func (self Message) Value() *big.Int
 
- type RLPTest
- type RuleSet
- type TransactionTest
- type TtTransaction
- type VmEnv
- type VmTest
Constants ¶
This section is empty.
Variables ¶
      View Source
      
  
    var ( BlockSkipTests = []string{ "BLOCK__RandomByteAtTheEnd", "TRANSCT__RandomByteAtTheEnd", "BLOCK__ZeroByteAtTheEnd", "TRANSCT__ZeroByteAtTheEnd", "ChainAtoChainB_blockorder2", "ChainAtoChainB_blockorder1", } /* Go client does not support transaction (account) nonces above 2^64. This technically breaks consensus but is regarded as "reasonable engineering constraint" as accounts cannot easily reach such high nonce values in practice */ TransSkipTests = []string{"TransactionWithHihghNonce256"} StateSkipTests = []string{} VmSkipTests = []string{} )
      View Source
      
  
var ( ForceJit bool EnableJit bool )
Functions ¶
func BenchStateTest ¶ added in v1.1.0
func RunBlockTest ¶ added in v0.9.32
func RunBlockTestWithReader ¶ added in v0.9.32
func RunRLPTest ¶ added in v0.9.39
RunRLPTest runs the tests in the given file, skipping tests by name.
func RunRLPTestWithReader ¶ added in v0.9.39
RunRLPTest runs the tests encoded in r, skipping tests by name.
func RunStateTest ¶ added in v0.9.32
func RunStateTestWithReader ¶ added in v0.9.32
func RunTransactionTests ¶
func RunTransactionTestsWithReader ¶ added in v0.9.32
func RunVmTestWithReader ¶ added in v0.9.32
func StateObjectFromAccount ¶ added in v0.9.32
Types ¶
type BlockTest ¶
type BlockTest struct {
	Genesis *types.Block
	Json *btJSON
	// contains filtered or unexported fields
}
    Block Test JSON Format
func (*BlockTest) InsertPreState ¶
InsertPreState populates the given database with the genesis accounts defined by the test.
func (*BlockTest) TryBlocksInsert ¶
func (t *BlockTest) TryBlocksInsert(blockchain *core.BlockChain) ([]btBlock, error)
See https://github.com/ethereum/tests/wiki/Blockchain-Tests-II
Whether a block is valid or not is a bit subtle, it's defined by presence of blockHeader, transactions and uncleHeaders fields. If they are missing, the block is invalid and we must verify that we do not accept it. Since some tests mix valid and invalid blocks we need to check this for every block. If a block is invalid it does not necessarily fail the test, if it's invalidness is expected we are expected to ignore it and continue processing and then validate the post state.
func (*BlockTest) ValidateImportedHeaders ¶ added in v1.2.2
func (test *BlockTest) ValidateImportedHeaders(cm *core.BlockChain, validBlocks []btBlock) error
type Env ¶ added in v0.9.32
func NewEnvFromMap ¶ added in v0.9.32
func (*Env) AddStructLog ¶ added in v0.9.32
func (*Env) BlockNumber ¶ added in v0.9.32
func (*Env) CanTransfer ¶ added in v1.1.0
func (*Env) DelegateCall ¶ added in v1.3.4
func (*Env) Difficulty ¶ added in v0.9.32
func (*Env) MakeSnapshot ¶ added in v1.3.1
func (*Env) SetSnapshot ¶ added in v1.3.1
func (*Env) StructLogs ¶ added in v0.9.32
type Log ¶ added in v0.9.32
type Message ¶ added in v0.9.32
type Message struct {
	// contains filtered or unexported fields
}
    func NewMessage ¶ added in v0.9.32
func (Message) FromFrontier ¶ added in v1.3.4
type RLPTest ¶ added in v0.9.39
type RLPTest struct {
	// If the value of In is "INVALID" or "VALID", the test
	// checks whether Out can be decoded into a value of
	// type interface{}.
	//
	// For other JSON values, In is treated as a driver for
	// calls to rlp.Stream. The test also verifies that encoding
	// In produces the bytes in Out.
	In interface{}
	// Out is a hex-encoded RLP value.
	Out string
}
    RLPTest is the JSON structure of a single RLP test.
type TransactionTest ¶
type TransactionTest struct {
	Blocknumber string
	Rlp         string
	Sender      string
	Transaction TtTransaction
}
    type TtTransaction ¶
type TtTransaction struct {
	Data     string
	GasLimit string
	GasPrice string
	Nonce    string
	R        string
	S        string
	To       string
	V        string
	Value    string
}
    Transaction Test JSON Format
 Click to show internal directories. 
   Click to hide internal directories.