mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-05 09:14:28 +00:00
943eb93a57
* do not lookup genesis state from disk * make sure genesis state is saved * fix tests Co-authored-by: kasey <489222+kasey@users.noreply.github.com>
97 lines
3.0 KiB
Go
97 lines
3.0 KiB
Go
package blockchain
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
testDB "github.com/prysmaticlabs/prysm/v3/beacon-chain/db/testing"
|
|
doublylinkedtree "github.com/prysmaticlabs/prysm/v3/beacon-chain/forkchoice/doubly-linked-tree"
|
|
"github.com/prysmaticlabs/prysm/v3/beacon-chain/state/stategen"
|
|
"github.com/prysmaticlabs/prysm/v3/consensus-types/blocks"
|
|
"github.com/prysmaticlabs/prysm/v3/encoding/bytesutil"
|
|
ethpb "github.com/prysmaticlabs/prysm/v3/proto/prysm/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/require"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/util"
|
|
)
|
|
|
|
func TestHeadSlot_DataRace(t *testing.T) {
|
|
beaconDB := testDB.SetupDB(t)
|
|
s := &Service{
|
|
cfg: &config{BeaconDB: beaconDB},
|
|
}
|
|
b, err := blocks.NewSignedBeaconBlock(util.NewBeaconBlock())
|
|
require.NoError(t, err)
|
|
st, _ := util.DeterministicGenesisState(t, 1)
|
|
wait := make(chan struct{})
|
|
go func() {
|
|
defer close(wait)
|
|
require.NoError(t, s.saveHead(context.Background(), [32]byte{}, b, st))
|
|
}()
|
|
s.HeadSlot()
|
|
<-wait
|
|
}
|
|
|
|
func TestHeadRoot_DataRace(t *testing.T) {
|
|
beaconDB := testDB.SetupDB(t)
|
|
s := &Service{
|
|
cfg: &config{BeaconDB: beaconDB, StateGen: stategen.New(beaconDB, doublylinkedtree.New())},
|
|
head: &head{root: [32]byte{'A'}},
|
|
}
|
|
b, err := blocks.NewSignedBeaconBlock(util.NewBeaconBlock())
|
|
require.NoError(t, err)
|
|
wait := make(chan struct{})
|
|
st, _ := util.DeterministicGenesisState(t, 1)
|
|
go func() {
|
|
defer close(wait)
|
|
require.NoError(t, s.saveHead(context.Background(), [32]byte{}, b, st))
|
|
|
|
}()
|
|
_, err = s.HeadRoot(context.Background())
|
|
require.NoError(t, err)
|
|
<-wait
|
|
}
|
|
|
|
func TestHeadBlock_DataRace(t *testing.T) {
|
|
beaconDB := testDB.SetupDB(t)
|
|
wsb, err := blocks.NewSignedBeaconBlock(ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Body: ðpb.BeaconBlockBody{}}})
|
|
require.NoError(t, err)
|
|
s := &Service{
|
|
cfg: &config{BeaconDB: beaconDB, StateGen: stategen.New(beaconDB, doublylinkedtree.New())},
|
|
head: &head{block: wsb},
|
|
}
|
|
b, err := blocks.NewSignedBeaconBlock(util.NewBeaconBlock())
|
|
require.NoError(t, err)
|
|
wait := make(chan struct{})
|
|
st, _ := util.DeterministicGenesisState(t, 1)
|
|
go func() {
|
|
defer close(wait)
|
|
require.NoError(t, s.saveHead(context.Background(), [32]byte{}, b, st))
|
|
|
|
}()
|
|
_, err = s.HeadBlock(context.Background())
|
|
require.NoError(t, err)
|
|
<-wait
|
|
}
|
|
|
|
func TestHeadState_DataRace(t *testing.T) {
|
|
beaconDB := testDB.SetupDB(t)
|
|
s := &Service{
|
|
cfg: &config{BeaconDB: beaconDB, StateGen: stategen.New(beaconDB, doublylinkedtree.New())},
|
|
}
|
|
b, err := blocks.NewSignedBeaconBlock(util.NewBeaconBlock())
|
|
require.NoError(t, err)
|
|
wait := make(chan struct{})
|
|
st, _ := util.DeterministicGenesisState(t, 1)
|
|
root := bytesutil.ToBytes32(bytesutil.PadTo([]byte{'s'}, 32))
|
|
require.NoError(t, beaconDB.SaveGenesisBlockRoot(context.Background(), root))
|
|
require.NoError(t, beaconDB.SaveState(context.Background(), st, root))
|
|
go func() {
|
|
defer close(wait)
|
|
require.NoError(t, s.saveHead(context.Background(), [32]byte{}, b, st))
|
|
|
|
}()
|
|
_, err = s.HeadState(context.Background())
|
|
require.NoError(t, err)
|
|
<-wait
|
|
}
|