prysm-pulse/shared/p2p/feed_test.go
Preston Van Loon 3c264be1c1
Clean up some p2p related TODOs (#521)
* Remove error checking for type assertions on p2p messages. The code should fail earlier in the p2p layer. Also fixed format on some TODOs

* format TODO again

* Add a bit more tests for p2p stuff

* goimports on feed_mock

* remove unused import
2018-09-16 14:02:53 -04:00

48 lines
973 B
Go

package p2p
import (
"reflect"
"sync"
"testing"
"github.com/golang/protobuf/proto"
testpb "github.com/prysmaticlabs/prysm/proto/testing"
)
func TestFeed_ReturnsSameFeed(t *testing.T) {
tests := []struct {
a proto.Message
b proto.Message
want bool
}{
// Equality tests
{a: &testpb.TestMessage{}, b: &testpb.TestMessage{}, want: true},
{a: &testpb.Puzzle{}, b: &testpb.Puzzle{}, want: true},
// Inequality tests
{a: &testpb.TestMessage{}, b: &testpb.Puzzle{}, want: false},
{a: &testpb.Puzzle{}, b: &testpb.TestMessage{}, want: false},
}
s, _ := NewServer()
for _, tt := range tests {
feed1 := s.Feed(tt.a)
feed2 := s.Feed(tt.b)
if (feed1 == feed2) != tt.want {
t.Errorf("Expected %v == %v to be %t", feed1, feed2, tt.want)
}
}
}
func TestFeed_ConcurrentWrite(t *testing.T) {
s := Server{
feeds: make(map[reflect.Type]Feed),
mutex: &sync.Mutex{},
}
for i := 0; i < 5; i++ {
go s.Feed(&testpb.TestMessage{})
}
}