mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-16 06:58:20 +00:00
94 lines
1.7 KiB
Go
94 lines
1.7 KiB
Go
|
package syncquerier
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"fmt"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/golang/protobuf/proto"
|
||
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
||
|
"github.com/prysmaticlabs/prysm/shared/event"
|
||
|
"github.com/prysmaticlabs/prysm/shared/p2p"
|
||
|
"github.com/prysmaticlabs/prysm/shared/testutil"
|
||
|
logTest "github.com/sirupsen/logrus/hooks/test"
|
||
|
)
|
||
|
|
||
|
type mockP2P struct {
|
||
|
}
|
||
|
|
||
|
func (mp *mockP2P) Subscribe(msg proto.Message, channel chan p2p.Message) event.Subscription {
|
||
|
return new(event.Feed).Subscribe(channel)
|
||
|
}
|
||
|
|
||
|
func (mp *mockP2P) Broadcast(msg proto.Message) {}
|
||
|
|
||
|
func (mp *mockP2P) Send(msg proto.Message, peer p2p.Peer) {
|
||
|
}
|
||
|
|
||
|
func TestStartStop(t *testing.T) {
|
||
|
hook := logTest.NewGlobal()
|
||
|
cfg := &Config{
|
||
|
P2P: &mockP2P{},
|
||
|
ResponseBufferSize: 100,
|
||
|
}
|
||
|
sq := NewSyncQuerierService(context.Background(), cfg)
|
||
|
|
||
|
exitRoutine := make(chan bool)
|
||
|
|
||
|
defer func() {
|
||
|
close(exitRoutine)
|
||
|
}()
|
||
|
|
||
|
go func() {
|
||
|
sq.Start()
|
||
|
exitRoutine <- true
|
||
|
}()
|
||
|
|
||
|
sq.Stop()
|
||
|
<-exitRoutine
|
||
|
|
||
|
testutil.AssertLogsContain(t, hook, "Stopping service")
|
||
|
|
||
|
hook.Reset()
|
||
|
}
|
||
|
|
||
|
func TestChainReqResponse(t *testing.T) {
|
||
|
hook := logTest.NewGlobal()
|
||
|
cfg := &Config{
|
||
|
P2P: &mockP2P{},
|
||
|
ResponseBufferSize: 100,
|
||
|
}
|
||
|
sq := NewSyncQuerierService(context.Background(), cfg)
|
||
|
|
||
|
exitRoutine := make(chan bool)
|
||
|
|
||
|
defer func() {
|
||
|
close(exitRoutine)
|
||
|
}()
|
||
|
|
||
|
go func() {
|
||
|
sq.run()
|
||
|
exitRoutine <- true
|
||
|
}()
|
||
|
|
||
|
response := &pb.ChainHeadResponse{
|
||
|
Slot: 0,
|
||
|
Hash: []byte{'a', 'b'},
|
||
|
}
|
||
|
|
||
|
msg := p2p.Message{
|
||
|
Data: response,
|
||
|
}
|
||
|
|
||
|
sq.responseBuf <- msg
|
||
|
|
||
|
expMsg := fmt.Sprintf("Latest Chain head is at slot: %d and hash %#x", response.Slot, response.Hash)
|
||
|
|
||
|
testutil.WaitForLog(t, hook, expMsg)
|
||
|
|
||
|
sq.cancel()
|
||
|
<-exitRoutine
|
||
|
|
||
|
hook.Reset()
|
||
|
}
|