erigon-pulse/cl/sentinel/sentinel_gossip_test.go
Giulio rebuffo cdb4731ae8
Added Validators endpoint to Beacon API (#9080)
* Added /validators retrieval to beacon api
* fixed race in sentinel
* fixed possible UB in gossip management
2023-12-26 00:34:38 +01:00

106 lines
2.6 KiB
Go

package sentinel
import (
"context"
"math"
"testing"
"time"
"github.com/ledgerwatch/erigon/cl/clparams"
"github.com/ledgerwatch/erigon/cl/persistence"
"github.com/ledgerwatch/log/v3"
"github.com/libp2p/go-libp2p/core/peer"
"github.com/stretchr/testify/require"
)
func TestSentinelGossipOnHardFork(t *testing.T) {
listenAddrHost := "127.0.0.1"
ctx := context.Background()
db, _, f, _, _ := loadChain(t)
raw := persistence.NewAferoRawBlockSaver(f, &clparams.MainnetBeaconConfig)
genesisConfig, networkConfig, beaconConfig := clparams.GetConfigsByNetwork(clparams.MainnetNetwork)
bcfg := *beaconConfig
bcfg.AltairForkEpoch = math.MaxUint64
bcfg.BellatrixForkEpoch = math.MaxUint64
bcfg.CapellaForkEpoch = math.MaxUint64
bcfg.DenebForkEpoch = math.MaxUint64
bcfg.InitializeForkSchedule()
sentinel1, err := New(ctx, &SentinelConfig{
NetworkConfig: networkConfig,
BeaconConfig: &bcfg,
GenesisConfig: genesisConfig,
IpAddr: listenAddrHost,
Port: 7070,
EnableBlocks: true,
}, raw, db, log.New())
require.NoError(t, err)
defer sentinel1.Stop()
require.NoError(t, sentinel1.Start())
h := sentinel1.host
sentinel2, err := New(ctx, &SentinelConfig{
NetworkConfig: networkConfig,
BeaconConfig: &bcfg,
GenesisConfig: genesisConfig,
IpAddr: listenAddrHost,
Port: 7077,
EnableBlocks: true,
TCPPort: 9123,
}, raw, db, log.New())
require.NoError(t, err)
defer sentinel2.Stop()
require.NoError(t, sentinel2.Start())
h2 := sentinel2.host
sub1, err := sentinel1.SubscribeGossip(BeaconBlockSsz)
require.NoError(t, err)
defer sub1.Close()
require.NoError(t, sub1.Listen())
sub2, err := sentinel2.SubscribeGossip(BeaconBlockSsz)
require.NoError(t, err)
defer sub2.Close()
require.NoError(t, sub2.Listen())
err = h.Connect(ctx, peer.AddrInfo{
ID: h2.ID(),
Addrs: h2.Addrs(),
})
require.NoError(t, err)
time.Sleep(5 * time.Second)
ch := sentinel2.RecvGossip()
msg := []byte("hello")
go func() {
// delay to make sure that the connection is established
sub1.Publish(msg)
}()
previousTopic := ""
ans := <-ch
require.Equal(t, ans.Data, msg)
previousTopic = string(ans.Topic)
bcfg.AltairForkEpoch = clparams.MainnetBeaconConfig.AltairForkEpoch
bcfg.InitializeForkSchedule()
time.Sleep(5 * time.Second)
msg = []byte("hello1")
go func() {
// delay to make sure that the connection is established
sub1 = sentinel1.subManager.GetMatchingSubscription(string(BeaconBlockSsz.Name))
sub1.Publish(msg)
}()
ans = <-ch
require.Equal(t, ans.Data, msg)
require.NotEqual(t, previousTopic, ans.Topic)
}