package rpc import ( "context" "errors" "io" "testing" "time" "github.com/gorilla/mux" mock "github.com/prysmaticlabs/prysm/v5/beacon-chain/blockchain/testing" mockExecution "github.com/prysmaticlabs/prysm/v5/beacon-chain/execution/testing" "github.com/prysmaticlabs/prysm/v5/beacon-chain/startup" mockSync "github.com/prysmaticlabs/prysm/v5/beacon-chain/sync/initial-sync/testing" "github.com/prysmaticlabs/prysm/v5/testing/assert" "github.com/prysmaticlabs/prysm/v5/testing/require" "github.com/sirupsen/logrus" logTest "github.com/sirupsen/logrus/hooks/test" ) func init() { logrus.SetLevel(logrus.DebugLevel) logrus.SetOutput(io.Discard) } func combineMaps(maps ...map[string][]string) map[string][]string { combinedMap := make(map[string][]string) for _, m := range maps { for k, v := range m { combinedMap[k] = v } } return combinedMap } func TestLifecycle_OK(t *testing.T) { hook := logTest.NewGlobal() chainService := &mock.ChainService{ Genesis: time.Now(), } rpcService := NewService(context.Background(), &Config{ Port: "7348", SyncService: &mockSync.Sync{IsSyncing: false}, BlockReceiver: chainService, AttestationReceiver: chainService, HeadFetcher: chainService, GenesisTimeFetcher: chainService, ExecutionChainService: &mockExecution.Chain{}, StateNotifier: chainService.StateNotifier(), Router: mux.NewRouter(), ClockWaiter: startup.NewClockSynchronizer(), }) rpcService.Start() require.LogsContain(t, hook, "listening on port") assert.NoError(t, rpcService.Stop()) } func TestStatus_CredentialError(t *testing.T) { credentialErr := errors.New("credentialError") s := &Service{ cfg: &Config{SyncService: &mockSync.Sync{IsSyncing: false}, OptimisticModeFetcher: &mock.ChainService{Optimistic: false}}, credentialError: credentialErr, } assert.ErrorContains(t, s.credentialError.Error(), s.Status()) } func TestStatus_Optimistic(t *testing.T) { s := &Service{ cfg: &Config{SyncService: &mockSync.Sync{IsSyncing: false}, OptimisticModeFetcher: &mock.ChainService{Optimistic: true}}, } assert.ErrorContains(t, "service is optimistic", s.Status()) } func TestRPC_InsecureEndpoint(t *testing.T) { hook := logTest.NewGlobal() chainService := &mock.ChainService{Genesis: time.Now()} rpcService := NewService(context.Background(), &Config{ Port: "7777", SyncService: &mockSync.Sync{IsSyncing: false}, BlockReceiver: chainService, GenesisTimeFetcher: chainService, AttestationReceiver: chainService, HeadFetcher: chainService, ExecutionChainService: &mockExecution.Chain{}, StateNotifier: chainService.StateNotifier(), Router: mux.NewRouter(), ClockWaiter: startup.NewClockSynchronizer(), }) rpcService.Start() require.LogsContain(t, hook, "listening on port") require.LogsContain(t, hook, "You are using an insecure gRPC server") assert.NoError(t, rpcService.Stop()) }