mirror of
https://github.com/status-im/status-go.git
synced 2025-01-21 20:20:29 +00:00
f2c6fef64c
This change allows to connect to the mail server that we were using before the app was restarted. Separate loop is listening for whisper events, and when we receive event that request was completed we will update time on a peer record. Records are stored in leveldb. Body of the record is marshaled using json. At this point the only field is a timestamp when record was used. This loop doesn't control connections, it only tracks what mail server we ended up using. It works asynchronously to connection management loop. Which tracks events that are related to connection state and expiry of the requests. When app starts we look into the database and select the most recently used record. This record is added to connection management loop first. So if this server is available we will stick to using it. If we weren't able to connect to the same server in configured timeout (5s) we will try to connect to any other server from list of active servers. closes: #1285
81 lines
2.3 KiB
Go
81 lines
2.3 KiB
Go
package mailservers
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
|
"github.com/stretchr/testify/require"
|
|
"github.com/syndtr/goleveldb/leveldb"
|
|
"github.com/syndtr/goleveldb/leveldb/storage"
|
|
)
|
|
|
|
func newInMemCache(t *testing.T) *Cache {
|
|
db, err := leveldb.Open(storage.NewMemStorage(), nil)
|
|
require.NoError(t, err)
|
|
return NewCache(db)
|
|
}
|
|
|
|
func containsNode(nodes []*enode.Node, node *enode.Node) error {
|
|
for _, n := range nodes {
|
|
if n.ID() == node.ID() {
|
|
return nil
|
|
}
|
|
}
|
|
return fmt.Errorf("nodes %+s do not contain %s", nodes, node)
|
|
}
|
|
|
|
func TestReplaceRecords(t *testing.T) {
|
|
nodesNumber := 3
|
|
cache := newInMemCache(t)
|
|
nodes := make([]*enode.Node, nodesNumber)
|
|
// First round is a sanity check that records were written.
|
|
fillWithRandomNodes(t, nodes)
|
|
require.NoError(t, cache.Replace(nodes))
|
|
records, err := cache.LoadAll()
|
|
require.NoError(t, err)
|
|
require.Len(t, records, nodesNumber)
|
|
for i := range records {
|
|
require.NoError(t, containsNode(nodes, records[i].Node()))
|
|
}
|
|
// Replace all nodes and verify that length is the same and loaded records are found.
|
|
fillWithRandomNodes(t, nodes)
|
|
require.NoError(t, cache.Replace(nodes))
|
|
records, err = cache.LoadAll()
|
|
require.NoError(t, err)
|
|
require.Len(t, records, nodesNumber)
|
|
for i := range records {
|
|
require.NoError(t, containsNode(nodes, records[i].Node()))
|
|
}
|
|
}
|
|
|
|
func TestUsedRecord(t *testing.T) {
|
|
cache := newInMemCache(t)
|
|
node, err := RandomNode()
|
|
require.NoError(t, err)
|
|
record := PeerRecord{node: node}
|
|
require.NoError(t, cache.UpdateRecord(record))
|
|
record.LastUsed = time.Now()
|
|
require.NoError(t, cache.UpdateRecord(record))
|
|
records, err := cache.LoadAll()
|
|
require.NoError(t, err)
|
|
require.Len(t, records, 1)
|
|
require.True(t, record.LastUsed.Equal(records[0].LastUsed))
|
|
}
|
|
|
|
func TestTimestampPreservedOnReplace(t *testing.T) {
|
|
cache := newInMemCache(t)
|
|
node, err := RandomNode()
|
|
require.NoError(t, err)
|
|
record := PeerRecord{node: node, LastUsed: time.Now()}
|
|
require.NoError(t, cache.UpdateRecord(record))
|
|
require.NoError(t, cache.Replace([]*enode.Node{node}))
|
|
records, err := cache.LoadAll()
|
|
require.NoError(t, err)
|
|
require.Len(t, records, 1)
|
|
require.Equal(t, node.ID(), records[0].Node().ID())
|
|
require.False(t, records[0].LastUsed.IsZero(), "timestamp should be preserved and not equal to zero")
|
|
|
|
}
|