mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-11 21:40:05 +00:00
e14664d53b
- allow store non-canonical blocks/senders - optimize re-org: don't update/delete most of data - allow mark chain as `Bad` - will be not visible by eth_getBlockByHash, but can read if have hash+num
152 lines
5.1 KiB
Go
152 lines
5.1 KiB
Go
package core_test
|
|
|
|
import (
|
|
"context"
|
|
"math/big"
|
|
"testing"
|
|
|
|
"github.com/holiman/uint256"
|
|
libcommon "github.com/ledgerwatch/erigon-lib/common"
|
|
"github.com/ledgerwatch/erigon-lib/common/datadir"
|
|
"github.com/ledgerwatch/erigon-lib/kv"
|
|
"github.com/ledgerwatch/erigon-lib/kv/kvcfg"
|
|
"github.com/ledgerwatch/erigon/core"
|
|
"github.com/ledgerwatch/erigon/core/rawdb/blockio"
|
|
"github.com/ledgerwatch/erigon/core/state/temporal"
|
|
"github.com/ledgerwatch/erigon/turbo/rpchelper"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/ledgerwatch/erigon/common"
|
|
"github.com/ledgerwatch/erigon/core/state"
|
|
"github.com/ledgerwatch/erigon/core/types"
|
|
"github.com/ledgerwatch/erigon/params"
|
|
"github.com/ledgerwatch/erigon/params/networkname"
|
|
"github.com/ledgerwatch/log/v3"
|
|
)
|
|
|
|
func TestGenesisBlockHashes(t *testing.T) {
|
|
logger := log.New()
|
|
_, db, _ := temporal.NewTestDB(t, context.Background(), datadir.New(t.TempDir()), nil, logger)
|
|
check := func(network string) {
|
|
genesis := core.GenesisBlockByChainName(network)
|
|
tx, err := db.BeginRw(context.Background())
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer tx.Rollback()
|
|
histV3, err := kvcfg.HistoryV3.Enabled(tx)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
blockWriter := blockio.NewBlockWriter(histV3)
|
|
_, block, err := core.WriteGenesisBlock(tx, genesis, nil, "", logger, blockWriter)
|
|
require.NoError(t, err)
|
|
expect := params.GenesisHashByChainName(network)
|
|
require.NotNil(t, expect, network)
|
|
require.Equal(t, block.Hash().Bytes(), expect.Bytes(), network)
|
|
}
|
|
for _, network := range networkname.All {
|
|
check(network)
|
|
}
|
|
}
|
|
|
|
func TestGenesisBlockRoots(t *testing.T) {
|
|
require := require.New(t)
|
|
var err error
|
|
|
|
block, _, _ := core.GenesisToBlock(core.MainnetGenesisBlock(), "")
|
|
if block.Hash() != params.MainnetGenesisHash {
|
|
t.Errorf("wrong mainnet genesis hash, got %v, want %v", block.Hash(), params.MainnetGenesisHash)
|
|
}
|
|
|
|
block, _, err = core.GenesisToBlock(core.GnosisGenesisBlock(), "")
|
|
require.NoError(err)
|
|
if block.Root() != params.GnosisGenesisStateRoot {
|
|
t.Errorf("wrong Gnosis Chain genesis state root, got %v, want %v", block.Root(), params.GnosisGenesisStateRoot)
|
|
}
|
|
if block.Hash() != params.GnosisGenesisHash {
|
|
t.Errorf("wrong Gnosis Chain genesis hash, got %v, want %v", block.Hash(), params.GnosisGenesisHash)
|
|
}
|
|
|
|
block, _, err = core.GenesisToBlock(core.ChiadoGenesisBlock(), "")
|
|
require.NoError(err)
|
|
if block.Root() != params.ChiadoGenesisStateRoot {
|
|
t.Errorf("wrong Chiado genesis state root, got %v, want %v", block.Root(), params.ChiadoGenesisStateRoot)
|
|
}
|
|
if block.Hash() != params.ChiadoGenesisHash {
|
|
t.Errorf("wrong Chiado genesis hash, got %v, want %v", block.Hash(), params.ChiadoGenesisHash)
|
|
}
|
|
}
|
|
|
|
func TestCommitGenesisIdempotency(t *testing.T) {
|
|
logger := log.New()
|
|
_, db, _ := temporal.NewTestDB(t, context.Background(), datadir.New(t.TempDir()), nil, logger)
|
|
tx, err := db.BeginRw(context.Background())
|
|
require.NoError(t, err)
|
|
defer tx.Rollback()
|
|
|
|
histV3, err := kvcfg.HistoryV3.Enabled(tx)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
blockWriter := blockio.NewBlockWriter(histV3)
|
|
genesis := core.GenesisBlockByChainName(networkname.MainnetChainName)
|
|
_, _, err = core.WriteGenesisBlock(tx, genesis, nil, "", logger, blockWriter)
|
|
require.NoError(t, err)
|
|
seq, err := tx.ReadSequence(kv.EthTx)
|
|
require.NoError(t, err)
|
|
require.Equal(t, uint64(2), seq)
|
|
|
|
_, _, err = core.WriteGenesisBlock(tx, genesis, nil, "", logger, blockWriter)
|
|
require.NoError(t, err)
|
|
seq, err = tx.ReadSequence(kv.EthTx)
|
|
require.NoError(t, err)
|
|
require.Equal(t, uint64(2), seq)
|
|
}
|
|
|
|
func TestAllocConstructor(t *testing.T) {
|
|
require := require.New(t)
|
|
assert := assert.New(t)
|
|
|
|
logger := log.New()
|
|
// This deployment code initially sets contract's 0th storage to 0x2a
|
|
// and its 1st storage to 0x01c9.
|
|
deploymentCode := common.FromHex("602a5f556101c960015560048060135f395ff35f355f55")
|
|
|
|
funds := big.NewInt(1000000000)
|
|
address := libcommon.HexToAddress("0x1000000000000000000000000000000000000001")
|
|
genSpec := &types.Genesis{
|
|
Config: params.AllProtocolChanges,
|
|
Alloc: types.GenesisAlloc{
|
|
address: {Constructor: deploymentCode, Balance: funds},
|
|
},
|
|
}
|
|
|
|
historyV3, db, _ := temporal.NewTestDB(t, context.Background(), datadir.New(t.TempDir()), nil, logger)
|
|
_, _, err := core.CommitGenesisBlock(db, genSpec, "", logger)
|
|
require.NoError(err)
|
|
|
|
tx, err := db.BeginRo(context.Background())
|
|
require.NoError(err)
|
|
defer tx.Rollback()
|
|
|
|
//TODO: support historyV3
|
|
reader, err := rpchelper.CreateHistoryStateReader(tx, 1, 0, historyV3, genSpec.Config.ChainName)
|
|
require.NoError(err)
|
|
state := state.New(reader)
|
|
balance := state.GetBalance(address)
|
|
assert.Equal(funds, balance.ToBig())
|
|
code := state.GetCode(address)
|
|
assert.Equal(common.FromHex("5f355f55"), code)
|
|
|
|
key0 := libcommon.HexToHash("0000000000000000000000000000000000000000000000000000000000000000")
|
|
storage0 := &uint256.Int{}
|
|
state.GetState(address, &key0, storage0)
|
|
assert.Equal(uint256.NewInt(0x2a), storage0)
|
|
key1 := libcommon.HexToHash("0000000000000000000000000000000000000000000000000000000000000001")
|
|
storage1 := &uint256.Int{}
|
|
state.GetState(address, &key1, storage1)
|
|
assert.Equal(uint256.NewInt(0x01c9), storage1)
|
|
}
|