a5ff5016c9
* port changes * Merge remote-tracking branch 'upstream/master' * Merge remote-tracking branch 'upstream/master' * Merge remote-tracking branch 'upstream/master' * files created * Merge remote-tracking branch 'upstream/master' into coyle/kad-tests * wip * Merge remote-tracking branch 'upstream/master' into coyle/kad-tests * wip * remove bkad dependencie from tests * wip * wip * wip * wip * wip * updated coyle/kademlia * wip * cleanup * ports * overlay upgraded * linter fixes * piecestore kademlia newID * add changes from kad demo * PR comments addresses * go func * force travis build * fixed merge conflicts * fixed merge conflicts * Merge branch 'coyle/kad-tests' of https://github.com/coyle/storj into coyle/kad-tests * linter issues * linting issues * fixed merge conflicts * linter is stupid
53 lines
1.1 KiB
Go
53 lines
1.1 KiB
Go
// Copyright (C) 2018 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package overlay
|
|
|
|
import (
|
|
"testing"
|
|
|
|
protob "github.com/gogo/protobuf/proto"
|
|
"github.com/stretchr/testify/assert"
|
|
"go.uber.org/zap"
|
|
"google.golang.org/grpc"
|
|
monkit "gopkg.in/spacemonkeygo/monkit.v2"
|
|
|
|
"storj.io/storj/internal/test"
|
|
"storj.io/storj/pkg/kademlia"
|
|
proto "storj.io/storj/protos/overlay"
|
|
"storj.io/storj/storage"
|
|
)
|
|
|
|
// NewMockServer provides a mock grpc server for testing
|
|
func NewMockServer(kv test.KvStore) *grpc.Server {
|
|
grpcServer := grpc.NewServer()
|
|
|
|
registry := monkit.Default
|
|
|
|
k := kademlia.NewMockKademlia()
|
|
|
|
c := &Cache{
|
|
DB: test.NewMockKeyValueStore(kv),
|
|
DHT: k,
|
|
}
|
|
|
|
s := Server{
|
|
dht: k,
|
|
cache: c,
|
|
logger: zap.NewNop(),
|
|
metrics: registry,
|
|
}
|
|
proto.RegisterOverlayServer(grpcServer, &s)
|
|
|
|
return grpcServer
|
|
}
|
|
|
|
// NewNodeAddressValue provides a convient way to create a storage.Value for testing purposes
|
|
func NewNodeAddressValue(t *testing.T, address string) storage.Value {
|
|
na := &proto.NodeAddress{Transport: proto.NodeTransport_TCP, Address: address}
|
|
d, err := protob.Marshal(na)
|
|
assert.NoError(t, err)
|
|
|
|
return d
|
|
}
|