2018-12-12 11:39:00 +02:00
|
|
|
package mailservers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-01-02 10:10:19 +01:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2018-12-12 11:39:00 +02:00
|
|
|
"github.com/ethereum/go-ethereum/p2p"
|
|
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
2020-01-02 10:10:19 +01:00
|
|
|
|
2019-11-23 18:57:05 +01:00
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
2018-12-12 11:39:00 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestGetFirstConnected(t *testing.T) {
|
|
|
|
numPeers := 3
|
|
|
|
nodes := make([]*enode.Node, numPeers)
|
|
|
|
peers := make([]*p2p.Peer, numPeers)
|
|
|
|
nodesMap := getMapWithRandomNodes(t, numPeers)
|
|
|
|
i := 0
|
|
|
|
for _, node := range nodesMap {
|
|
|
|
nodes[i] = node
|
|
|
|
peers[i] = p2p.NewPeer(node.ID(), node.ID().String(), nil)
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
store := NewPeerStore(newInMemCache(t))
|
|
|
|
provider := fakePeerProvider{peers}
|
|
|
|
_, err := GetFirstConnected(provider, store)
|
|
|
|
require.EqualError(t, ErrNoConnected, err.Error())
|
|
|
|
require.NoError(t, store.Update(nodes))
|
|
|
|
node, err := GetFirstConnected(provider, store)
|
|
|
|
require.NoError(t, err)
|
2019-11-23 18:57:05 +01:00
|
|
|
require.Contains(t, nodesMap, types.EnodeID(node.ID()))
|
2018-12-12 11:39:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type trackingNodeNotifee struct {
|
|
|
|
calls [][]*enode.Node
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *trackingNodeNotifee) Notify(nodes []*enode.Node) {
|
|
|
|
t.calls = append(t.calls, nodes)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestEnsureNewRecordsAddedFirst(t *testing.T) {
|
|
|
|
notifee := new(trackingNodeNotifee)
|
|
|
|
store := NewPeerStore(newInMemCache(t))
|
|
|
|
nodes := make([]*enode.Node, 3)
|
|
|
|
fillWithRandomNodes(t, nodes)
|
|
|
|
require.NoError(t, store.Update(nodes))
|
|
|
|
record := NewPeerRecord(nodes[0])
|
|
|
|
record.LastUsed = time.Now()
|
|
|
|
require.NoError(t, store.cache.UpdateRecord(record))
|
|
|
|
require.NoError(t, EnsureUsedRecordsAddedFirst(store, notifee))
|
|
|
|
require.Len(t, notifee.calls, 2)
|
|
|
|
require.Len(t, notifee.calls[0], 1)
|
|
|
|
require.Equal(t, nodes[0].ID(), notifee.calls[0][0].ID())
|
|
|
|
require.Len(t, notifee.calls[1], 3)
|
|
|
|
}
|