package messagehandler_test import ( "context" "testing" "github.com/gogo/protobuf/proto" ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1" "github.com/prysmaticlabs/prysm/shared/messagehandler" "github.com/prysmaticlabs/prysm/shared/testutil/require" logTest "github.com/sirupsen/logrus/hooks/test" ) func TestSafelyHandleMessage(t *testing.T) { hook := logTest.NewGlobal() messagehandler.SafelyHandleMessage(nil, func(_ context.Context, _ proto.Message) error { panic("bad!") return nil }, ðpb.BeaconBlock{}) require.LogsContain(t, hook, "Panicked when handling p2p message!") } func TestSafelyHandleMessage_NoData(t *testing.T) { hook := logTest.NewGlobal() messagehandler.SafelyHandleMessage(nil, func(_ context.Context, _ proto.Message) error { panic("bad!") return nil }, nil) entry := hook.LastEntry() if entry.Data["msg"] != "message contains no data" { t.Errorf("Message logged was not what was expected: %s", entry.Data["msg"]) } }