2023-08-30 18:57:22 +07:00
|
|
|
package peermanager
|
|
|
|
|
|
|
|
import (
|
2024-05-22 11:45:53 +05:30
|
|
|
"testing"
|
|
|
|
|
2023-08-30 18:57:22 +07:00
|
|
|
"github.com/libp2p/go-libp2p/core/peer"
|
|
|
|
libp2pProtocol "github.com/libp2p/go-libp2p/core/protocol"
|
|
|
|
"github.com/stretchr/testify/require"
|
2024-01-26 14:15:15 +05:30
|
|
|
"golang.org/x/exp/maps"
|
2023-08-30 18:57:22 +07:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestServiceSlot(t *testing.T) {
|
|
|
|
slots := NewServiceSlot()
|
|
|
|
|
2024-03-18 20:12:36 +08:00
|
|
|
protocol := libp2pProtocol.ID("/vac/waku/test/2.0.0")
|
2023-08-30 18:57:22 +07:00
|
|
|
|
2023-09-11 10:24:05 -04:00
|
|
|
peerID := peer.ID("peerId")
|
2023-08-30 18:57:22 +07:00
|
|
|
|
|
|
|
//
|
2023-09-11 10:24:05 -04:00
|
|
|
slots.getPeers(protocol).add(peerID)
|
2023-08-30 18:57:22 +07:00
|
|
|
//
|
2024-05-22 11:45:53 +05:30
|
|
|
fetchedPeers, err := slots.getPeers(protocol).getRandom(1, nil)
|
2023-08-30 18:57:22 +07:00
|
|
|
require.NoError(t, err)
|
2024-01-26 14:15:15 +05:30
|
|
|
require.Equal(t, peerID, maps.Keys(fetchedPeers)[0])
|
2023-08-30 18:57:22 +07:00
|
|
|
//
|
2023-09-11 10:24:05 -04:00
|
|
|
slots.getPeers(protocol).remove(peerID)
|
2023-08-30 18:57:22 +07:00
|
|
|
//
|
2024-05-22 11:45:53 +05:30
|
|
|
_, err = slots.getPeers(protocol).getRandom(1, nil)
|
2023-10-16 22:12:01 +05:30
|
|
|
require.Equal(t, err, ErrNoPeersAvailable)
|
2024-03-18 16:22:20 +08:00
|
|
|
|
|
|
|
// Test with more peers
|
|
|
|
peerID2 := peer.ID("peerId2")
|
|
|
|
peerID3 := peer.ID("peerId3")
|
|
|
|
|
|
|
|
//
|
|
|
|
slots.getPeers(protocol).add(peerID2)
|
|
|
|
slots.getPeers(protocol).add(peerID3)
|
|
|
|
//
|
|
|
|
|
2024-05-22 11:45:53 +05:30
|
|
|
fetchedPeers, err = slots.getPeers(protocol).getRandom(2, nil)
|
2024-03-18 16:22:20 +08:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 2, len(maps.Keys(fetchedPeers)))
|
|
|
|
|
2024-03-20 12:11:06 +08:00
|
|
|
fetchedPeersSerialized := maps.Keys(fetchedPeers)
|
|
|
|
|
2024-03-18 16:22:20 +08:00
|
|
|
// Check for uniqueness
|
2024-03-20 12:11:06 +08:00
|
|
|
require.NotEqual(t, fetchedPeersSerialized[0], fetchedPeersSerialized[1])
|
2024-03-18 16:22:20 +08:00
|
|
|
|
|
|
|
slots.getPeers(protocol).remove(peerID2)
|
|
|
|
|
2024-05-22 11:45:53 +05:30
|
|
|
fetchedPeers, err = slots.getPeers(protocol).getRandom(10, nil)
|
2024-03-18 16:22:20 +08:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, peerID3, maps.Keys(fetchedPeers)[0])
|
|
|
|
|
2023-08-30 18:57:22 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestServiceSlotRemovePeerFromAll(t *testing.T) {
|
|
|
|
slots := NewServiceSlot()
|
|
|
|
|
2024-03-18 20:12:36 +08:00
|
|
|
protocol := libp2pProtocol.ID("/vac/waku/test/2.0.0")
|
|
|
|
protocol1 := libp2pProtocol.ID("/vac/waku/test/2.0.2")
|
2023-08-30 18:57:22 +07:00
|
|
|
|
2023-09-11 10:24:05 -04:00
|
|
|
peerID := peer.ID("peerId")
|
2023-08-30 18:57:22 +07:00
|
|
|
|
|
|
|
//
|
2023-09-11 10:24:05 -04:00
|
|
|
slots.getPeers(protocol).add(peerID)
|
|
|
|
slots.getPeers(protocol1).add(peerID)
|
2023-08-30 18:57:22 +07:00
|
|
|
//
|
2024-05-22 11:45:53 +05:30
|
|
|
fetchedPeers, err := slots.getPeers(protocol1).getRandom(1, nil)
|
2023-08-30 18:57:22 +07:00
|
|
|
require.NoError(t, err)
|
2024-01-26 14:15:15 +05:30
|
|
|
require.Equal(t, peerID, maps.Keys(fetchedPeers)[0])
|
2023-08-30 18:57:22 +07:00
|
|
|
|
|
|
|
//
|
2023-09-11 10:24:05 -04:00
|
|
|
slots.removePeer(peerID)
|
2023-08-30 18:57:22 +07:00
|
|
|
//
|
2024-05-22 11:45:53 +05:30
|
|
|
_, err = slots.getPeers(protocol).getRandom(1, nil)
|
2023-10-16 22:12:01 +05:30
|
|
|
require.Equal(t, err, ErrNoPeersAvailable)
|
2024-05-22 11:45:53 +05:30
|
|
|
_, err = slots.getPeers(protocol1).getRandom(1, nil)
|
2023-10-16 22:12:01 +05:30
|
|
|
require.Equal(t, err, ErrNoPeersAvailable)
|
2023-08-30 18:57:22 +07:00
|
|
|
}
|