516972119c
* evm: unit tests * Add unit tests for DynamicFeeTx.Validate() * Start get and set signature values tests * get set values * Add tests for GetTo() * Add GetNonce test * Add GetValue test * Start copy test * Add WIP newDynamicFeeTx test * Add WIP legacy_tx_test * pair programming session * Add TestLegacyTxValidate * Add TestLegacyTxSetSignatureValues & GetSignatureValues * Add legacyTx tests * Merge main, forgot to save one file * Add AccessList tests * Add chain Config (fork order) * Add invalid genesis account test * Add params tests * Add WIP tracer test * tracer tests * Add FormatLogs tests * Add NewNoOpTracer test * Refactor to test suite * Refactor Tx Test suits to only use TxDataTestSuite * Update link to geth interpreter * Update x/evm/types/params.go * Refactor accessListTx Test suits to use TxDataTestSuite Co-authored-by: Daniel Burckhardt <daniel.m.burckhardt@gmail.com>
135 lines
3.5 KiB
Go
135 lines
3.5 KiB
Go
package types
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
paramtypes "github.com/cosmos/cosmos-sdk/x/params/types"
|
|
"github.com/ethereum/go-ethereum/core/vm"
|
|
"github.com/tharsis/ethermint/types"
|
|
)
|
|
|
|
var _ paramtypes.ParamSet = &Params{}
|
|
|
|
const (
|
|
DefaultEVMDenom = types.AttoPhoton
|
|
)
|
|
|
|
// Parameter keys
|
|
var (
|
|
ParamStoreKeyEVMDenom = []byte("EVMDenom")
|
|
ParamStoreKeyEnableCreate = []byte("EnableCreate")
|
|
ParamStoreKeyEnableCall = []byte("EnableCall")
|
|
ParamStoreKeyExtraEIPs = []byte("EnableExtraEIPs")
|
|
ParamStoreKeyChainConfig = []byte("ChainConfig")
|
|
|
|
// AvailableExtraEIPs define the list of all EIPs that can be enabled by the
|
|
// EVM interpreter. These EIPs are applied in order and can override the
|
|
// instruction sets from the latest hard fork enabled by the ChainConfig. For
|
|
// more info check:
|
|
// https://github.com/ethereum/go-ethereum/blob/master/core/vm/interpreter.go#L97
|
|
AvailableExtraEIPs = []int64{1344, 1884, 2200, 2929, 3198, 3529}
|
|
)
|
|
|
|
// ParamKeyTable returns the parameter key table.
|
|
func ParamKeyTable() paramtypes.KeyTable {
|
|
return paramtypes.NewKeyTable().RegisterParamSet(&Params{})
|
|
}
|
|
|
|
// NewParams creates a new Params instance
|
|
func NewParams(evmDenom string, enableCreate, enableCall bool, config ChainConfig, extraEIPs ...int64) Params {
|
|
return Params{
|
|
EvmDenom: evmDenom,
|
|
EnableCreate: enableCreate,
|
|
EnableCall: enableCall,
|
|
ExtraEIPs: extraEIPs,
|
|
ChainConfig: config,
|
|
}
|
|
}
|
|
|
|
// DefaultParams returns default evm parameters
|
|
// ExtraEIPs is empty to prevent overriding the latest hard fork instruction set
|
|
func DefaultParams() Params {
|
|
return Params{
|
|
EvmDenom: DefaultEVMDenom,
|
|
EnableCreate: true,
|
|
EnableCall: true,
|
|
ChainConfig: DefaultChainConfig(),
|
|
ExtraEIPs: nil,
|
|
}
|
|
}
|
|
|
|
// ParamSetPairs returns the parameter set pairs.
|
|
func (p *Params) ParamSetPairs() paramtypes.ParamSetPairs {
|
|
return paramtypes.ParamSetPairs{
|
|
paramtypes.NewParamSetPair(ParamStoreKeyEVMDenom, &p.EvmDenom, validateEVMDenom),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyEnableCreate, &p.EnableCreate, validateBool),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyEnableCall, &p.EnableCall, validateBool),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyExtraEIPs, &p.ExtraEIPs, validateEIPs),
|
|
paramtypes.NewParamSetPair(ParamStoreKeyChainConfig, &p.ChainConfig, validateChainConfig),
|
|
}
|
|
}
|
|
|
|
// Validate performs basic validation on evm parameters.
|
|
func (p Params) Validate() error {
|
|
if err := sdk.ValidateDenom(p.EvmDenom); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := validateEIPs(p.ExtraEIPs); err != nil {
|
|
return err
|
|
}
|
|
|
|
return p.ChainConfig.Validate()
|
|
}
|
|
|
|
// EIPs returns the ExtraEips as a int slice
|
|
func (p Params) EIPs() []int {
|
|
eips := make([]int, len(p.ExtraEIPs))
|
|
for i, eip := range p.ExtraEIPs {
|
|
eips[i] = int(eip)
|
|
}
|
|
return eips
|
|
}
|
|
|
|
func validateEVMDenom(i interface{}) error {
|
|
denom, ok := i.(string)
|
|
if !ok {
|
|
return fmt.Errorf("invalid parameter EVM denom type: %T", i)
|
|
}
|
|
|
|
return sdk.ValidateDenom(denom)
|
|
}
|
|
|
|
func validateBool(i interface{}) error {
|
|
_, ok := i.(bool)
|
|
if !ok {
|
|
return fmt.Errorf("invalid parameter type: %T", i)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func validateEIPs(i interface{}) error {
|
|
eips, ok := i.([]int64)
|
|
if !ok {
|
|
return fmt.Errorf("invalid EIP slice type: %T", i)
|
|
}
|
|
|
|
for _, eip := range eips {
|
|
if !vm.ValidEip(int(eip)) {
|
|
return fmt.Errorf("EIP %d is not activateable, valid EIPS are: %s", eip, vm.ActivateableEips())
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func validateChainConfig(i interface{}) error {
|
|
cfg, ok := i.(ChainConfig)
|
|
if !ok {
|
|
return fmt.Errorf("invalid chain config type: %T", i)
|
|
}
|
|
|
|
return cfg.Validate()
|
|
}
|