1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
package p2p
import (
"testing"
"time"
"github.com/stretchr/testify/assert"
"go.uber.org/zap"
)
// TestPeerToPeerCommunication tests if two peers can communicate.
func TestPeerToPeerCommunication(t *testing.T) {
// Create a mock of the first peer (peer-1)
peer1Opts := TCPNetworkOpts{
ListenAddr: ":9001",
HandshakeFn: func() error { return nil },
RetryDelay: time.Second * 2,
Logger: zap.L(),
}
peer1 := NewTCPNetwork("peer-1", peer1Opts)
peer1.RegisterHandler(func(msg Message) {
assert.Equal(t, "Hey from peer-2!", string(msg.Payload))
})
// Create a mock of the second peer (peer-2)
peer2Opts := TCPNetworkOpts{
ListenAddr: ":9002",
HandshakeFn: func() error { return nil },
RetryDelay: time.Second * 2,
Logger: zap.L(),
OnReceiveFn: func(msg Message) {
assert.Equal(t, "Hey from peer-1!", string(msg.Payload))
},
}
peer2 := NewTCPNetwork("peer-2", peer2Opts)
// Start the first peer and add the second peer
go peer1.AddPeer("peer-2", peer2.ListenAddr)
go peer2.AddPeer("peer-1", peer1.ListenAddr)
// Wait for the connections to be established
// You might need a little more time based on network delay and retry logic
time.Sleep(5 * time.Second)
// Send a message from peer-1 to peer-2
err := peer1.Send("peer-2", []byte("Hey from peer-1!"))
assert.NoError(t, err)
err = peer2.Send("peer-1", []byte("Hey from peer-2!"))
assert.NoError(t, err)
// Allow some time for the message to be received and handled
time.Sleep(2 * time.Second)
}
// TestSendFailure tests if sending a message fails when no connection exists.
func TestSendFailure(t *testing.T) {
peer1Opts := TCPNetworkOpts{
ListenAddr: ":9001",
HandshakeFn: DefaultHandshake,
RetryDelay: time.Second * 2,
Logger: zap.L(),
}
peer1 := NewTCPNetwork("peer-1", peer1Opts)
// Create a mock of the second peer (peer-2)
peer2Opts := TCPNetworkOpts{
ListenAddr: ":9002",
HandshakeFn: DefaultHandshake,
RetryDelay: time.Second * 2,
Logger: zap.L(),
}
_ = NewTCPNetwork("peer-2", peer2Opts)
// Attempt to send a message without establishing a connection first
err := peer1.Send("peer-2", []byte("Message without connection"))
assert.Error(t, err, "Expected error when sending to a non-connected peer")
}
|