mirror of
https://github.com/status-im/status-go.git
synced 2025-01-09 22:26:30 +00:00
c1dd9397f7
* fix_: gitignore generated files * chore_: delete generated files * fix_: update go generate instructions * feat(Makefile)_: clean-generated-files target * feat(Makefile)_: `generate` target * fix(Makefile)_: dependent generate target * ci_: run generate, update docker file deps * fix(Makefile)_: remove `clean-generated-files` target * fix(Makefile)_: simpler GO_GENERATE_CMD arg * fix_: temp workspace GO_GENERATE_FAST_DIR
129 lines
2.6 KiB
Go
129 lines
2.6 KiB
Go
package peer
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
"go.uber.org/mock/gomock"
|
|
|
|
mock_peer "github.com/status-im/status-go/services/peer/mock"
|
|
)
|
|
|
|
func TestPeerSuite(t *testing.T) {
|
|
suite.Run(t, new(PeerSuite))
|
|
}
|
|
|
|
type PeerSuite struct {
|
|
suite.Suite
|
|
api *PublicAPI
|
|
s *Service
|
|
d *mock_peer.MockDiscoverer
|
|
}
|
|
|
|
func (s *PeerSuite) SetupTest() {
|
|
ctrl := gomock.NewController(s.T())
|
|
s.d = mock_peer.NewMockDiscoverer(ctrl)
|
|
s.s = New()
|
|
s.api = NewAPI(s.s)
|
|
}
|
|
|
|
var discovertests = []struct {
|
|
name string
|
|
expectedError error
|
|
prepareExpectations func(*PeerSuite)
|
|
request DiscoverRequest
|
|
}{
|
|
{
|
|
name: "success discover",
|
|
expectedError: nil,
|
|
prepareExpectations: func(s *PeerSuite) {
|
|
s.d.EXPECT().Discover("topic", 10, 1).Return(nil)
|
|
},
|
|
request: DiscoverRequest{
|
|
Topic: "topic",
|
|
Max: 10,
|
|
Min: 1,
|
|
},
|
|
},
|
|
{
|
|
name: "range 0",
|
|
expectedError: nil,
|
|
prepareExpectations: func(s *PeerSuite) {
|
|
s.d.EXPECT().Discover("topic", 10, 10).Return(nil)
|
|
},
|
|
request: DiscoverRequest{
|
|
Topic: "topic",
|
|
Max: 10,
|
|
Min: 10,
|
|
},
|
|
},
|
|
{
|
|
name: "invalid topic",
|
|
expectedError: ErrInvalidTopic,
|
|
prepareExpectations: func(s *PeerSuite) {},
|
|
request: DiscoverRequest{
|
|
Topic: "",
|
|
Max: 10,
|
|
Min: 1,
|
|
},
|
|
},
|
|
{
|
|
name: "invalid range",
|
|
expectedError: ErrInvalidRange,
|
|
prepareExpectations: func(s *PeerSuite) {},
|
|
request: DiscoverRequest{
|
|
Topic: "topic",
|
|
Max: 1,
|
|
Min: 10,
|
|
},
|
|
},
|
|
{
|
|
name: "success discover",
|
|
expectedError: nil,
|
|
prepareExpectations: func(s *PeerSuite) {
|
|
s.d.EXPECT().Discover("topic", 10, 1).Return(nil)
|
|
},
|
|
request: DiscoverRequest{
|
|
Topic: "topic",
|
|
Max: 10,
|
|
Min: 1,
|
|
},
|
|
},
|
|
{
|
|
name: "errored discover",
|
|
expectedError: errors.New("could not create the specified account : foo"),
|
|
prepareExpectations: func(s *PeerSuite) {
|
|
s.d.EXPECT().Discover("topic", 10, 1).Return(errors.New("could not create the specified account : foo"))
|
|
},
|
|
request: DiscoverRequest{
|
|
Topic: "topic",
|
|
Max: 10,
|
|
Min: 1,
|
|
},
|
|
},
|
|
}
|
|
|
|
func (s *PeerSuite) TestDiscover() {
|
|
for _, tc := range discovertests {
|
|
s.T().Run(tc.name, func(t *testing.T) {
|
|
s.s.SetDiscoverer(s.d)
|
|
tc.prepareExpectations(s)
|
|
|
|
var ctx context.Context
|
|
err := s.api.Discover(ctx, tc.request)
|
|
s.Equal(tc.expectedError, err, "failed scenario : "+tc.name)
|
|
})
|
|
}
|
|
}
|
|
|
|
func (s *PeerSuite) TestDiscoverWihEmptyDiscoverer() {
|
|
var ctx context.Context
|
|
s.Equal(ErrDiscovererNotProvided, s.api.Discover(ctx, DiscoverRequest{
|
|
Topic: "topic",
|
|
Max: 10,
|
|
Min: 1,
|
|
}))
|
|
}
|