prysm-pulse/beacon-chain/sync/context_test.go
kasey 918129cf36
Replace statefeed Initialize (#12285)
* refactor initialization to blocking startup method

* require genesisSetter in blockchain, fix tests

* work-around gazelle weirdness

* fix dep gazelle ignores

* only call SetGenesis once

* fix typo

* validator test setup and fix to return right error

* move waitForChainStart to Start

* wire up sync Service.genesisWaiter

* fix p2p genesisWaiter plumbing

* remove extra clock type, integrate into genesis

and rename

* use time.Now when no Nower is specified

* remove unused ClockSetter

* simplify rpc context checking

* fix typo

* use clock everywhere in sync; [32]byte val root

* don't use DeepEqual to compare [32]byte and []byte

* don't use clock in init sync, not wired up yet

* use clock waiter in blockchain as well

* use cancelable contexts in tests with goroutines

* missed a reference to WithClockSetter

* Update beacon-chain/startup/genesis.go

Co-authored-by: Radosław Kapka <rkapka@wp.pl>

* Update beacon-chain/blockchain/service_test.go

Co-authored-by: Radosław Kapka <rkapka@wp.pl>

* more clear docs

* doc for NewClock

* move clock typedef to more logical file name

* adding documentation

* gaz

* fixes for capella

* reducing test raciness

* fix races in committee cache tests

* lint

* add tests on Duration slot math helper

* startup package test coverage

* fix bad merge

* set non-zero genesis time in tests that call Start

* happy deepsource, happy me-epsource

* replace Synced event with channel

* remove unused error

* remove accidental wip commit

* gaz!

* remove unused event constants

* remove sync statefeed subscription to fix deadlock

* remove state notifier

* fix build

---------

Co-authored-by: Kasey Kirkham <kasey@users.noreply.github.com>
Co-authored-by: Radosław Kapka <rkapka@wp.pl>
Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
Co-authored-by: nisdas <nishdas93@gmail.com>
2023-05-03 04:34:01 +00:00

128 lines
3.2 KiB
Go

package sync
import (
"context"
"sync"
"testing"
"time"
core "github.com/libp2p/go-libp2p/core"
"github.com/libp2p/go-libp2p/core/network"
"github.com/libp2p/go-libp2p/core/protocol"
"github.com/prysmaticlabs/prysm/v4/beacon-chain/p2p"
p2ptest "github.com/prysmaticlabs/prysm/v4/beacon-chain/p2p/testing"
"github.com/prysmaticlabs/prysm/v4/testing/assert"
"github.com/prysmaticlabs/prysm/v4/testing/util"
)
func TestContextWrite_NoWrites(t *testing.T) {
p1 := p2ptest.NewTestP2P(t)
nPeer := p2ptest.NewTestP2P(t)
p1.Connect(nPeer)
wg := new(sync.WaitGroup)
prID := p2p.RPCPingTopicV1
wg.Add(1)
nPeer.BHost.SetStreamHandler(core.ProtocolID(prID), func(stream network.Stream) {
wg.Done()
// no-op
})
strm, err := p1.BHost.NewStream(context.Background(), nPeer.PeerID(), p2p.RPCPingTopicV1)
assert.NoError(t, err)
// Nothing will be written to the stream
assert.NoError(t, writeContextToStream([]byte{}, strm))
if util.WaitTimeout(wg, 1*time.Second) {
t.Fatal("Did not receive stream within 1 sec")
}
}
func TestContextRead_NoReads(t *testing.T) {
p1 := p2ptest.NewTestP2P(t)
nPeer := p2ptest.NewTestP2P(t)
p1.Connect(nPeer)
wg := new(sync.WaitGroup)
prID := p2p.RPCPingTopicV1
wg.Add(1)
wantedData := []byte{'A', 'B', 'C', 'D'}
nPeer.BHost.SetStreamHandler(core.ProtocolID(prID), func(stream network.Stream) {
// No Context will be read from it
dt, err := readContextFromStream(stream)
assert.NoError(t, err)
assert.Equal(t, 0, len(dt))
// Ensure sent over data hasn't been modified.
buf := make([]byte, len(wantedData))
n, err := stream.Read(buf)
assert.NoError(t, err)
assert.Equal(t, len(wantedData), n)
assert.DeepEqual(t, wantedData, buf)
wg.Done()
})
strm, err := p1.BHost.NewStream(context.Background(), nPeer.PeerID(), p2p.RPCPingTopicV1)
assert.NoError(t, err)
n, err := strm.Write(wantedData)
assert.NoError(t, err)
assert.Equal(t, len(wantedData), n)
if util.WaitTimeout(wg, 1*time.Second) {
t.Fatal("Did not receive stream within 1 sec")
}
}
var _ = withProtocol(&fakeStream{})
type fakeStream struct {
protocol protocol.ID
}
func (fs *fakeStream) Protocol() protocol.ID {
return fs.protocol
}
func TestValidateVersion(t *testing.T) {
tests := []struct {
name string
version string
protocol string
error string
wantErr bool
}{
{
name: "bad topic",
version: p2p.SchemaVersionV1,
protocol: "random",
error: "unable to find a valid protocol prefix",
wantErr: true,
},
{
name: "valid topic with incorrect version",
version: p2p.SchemaVersionV1,
protocol: p2p.RPCBlocksByRootTopicV2,
error: "doesn't match provided version",
wantErr: true,
},
{
name: "valid topic with correct version",
version: p2p.SchemaVersionV2,
protocol: p2p.RPCBlocksByRootTopicV2,
error: "",
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
stream := &fakeStream{protocol: protocol.ID(tt.protocol)}
err := validateVersion(tt.version, stream)
if (err != nil) != tt.wantErr {
t.Errorf("validateVersion() error = %v, wantErr %v", err, tt.wantErr)
}
if err != nil {
assert.ErrorContains(t, tt.error, err)
}
})
}
}