2021-11-09 15:15:45 +01:00
|
|
|
package rpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2021-11-18 15:20:58 +01:00
|
|
|
"fmt"
|
2021-11-09 15:15:45 +01:00
|
|
|
"testing"
|
2021-11-18 15:20:58 +01:00
|
|
|
"time"
|
2021-11-09 15:15:45 +01:00
|
|
|
|
2021-11-18 15:20:58 +01:00
|
|
|
"github.com/multiformats/go-multiaddr"
|
2021-11-09 15:15:45 +01:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-11-09 15:53:01 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/node"
|
2023-02-13 08:52:53 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/pb"
|
2022-11-09 15:53:01 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/utils"
|
2021-11-09 15:15:45 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func makeRelayService(t *testing.T) *RelayService {
|
2021-12-06 09:43:00 +01:00
|
|
|
options := node.WithWakuRelayAndMinPeers(0)
|
2023-01-06 18:37:57 -04:00
|
|
|
n, err := node.New(options)
|
2021-11-09 15:15:45 +01:00
|
|
|
require.NoError(t, err)
|
2023-01-06 18:37:57 -04:00
|
|
|
err = n.Start(context.Background())
|
2021-11-09 15:15:45 +01:00
|
|
|
require.NoError(t, err)
|
2022-07-07 17:58:07 -04:00
|
|
|
|
2022-10-20 09:18:23 -04:00
|
|
|
return NewRelayService(n, 30, utils.Logger())
|
2021-11-09 15:15:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestPostV1Message(t *testing.T) {
|
|
|
|
var reply SuccessReply
|
|
|
|
|
|
|
|
d := makeRelayService(t)
|
|
|
|
|
2023-02-13 08:52:53 -04:00
|
|
|
msg := &pb.WakuMessage{
|
|
|
|
Payload: []byte{1, 2, 3},
|
|
|
|
ContentTopic: "abc",
|
|
|
|
Version: 0,
|
|
|
|
Timestamp: utils.GetUnixEpoch(),
|
|
|
|
}
|
|
|
|
|
2021-11-09 15:15:45 +01:00
|
|
|
err := d.PostV1Message(
|
|
|
|
makeRequest(t),
|
2023-02-13 08:52:53 -04:00
|
|
|
&RelayMessageArgs{
|
2023-02-16 23:35:22 -04:00
|
|
|
Message: ProtoToRPC(msg),
|
2023-02-13 08:52:53 -04:00
|
|
|
},
|
2021-11-09 15:15:45 +01:00
|
|
|
&reply,
|
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-14 11:36:34 -04:00
|
|
|
require.True(t, reply)
|
2021-11-09 15:15:45 +01:00
|
|
|
}
|
|
|
|
|
2021-11-17 17:04:54 +01:00
|
|
|
func TestRelaySubscription(t *testing.T) {
|
2021-11-09 15:15:45 +01:00
|
|
|
var reply SuccessReply
|
|
|
|
|
|
|
|
d := makeRelayService(t)
|
|
|
|
args := &TopicsArgs{Topics: []string{"test"}}
|
|
|
|
|
|
|
|
err := d.PostV1Subscription(
|
|
|
|
makeRequest(t),
|
|
|
|
args,
|
|
|
|
&reply,
|
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-14 11:36:34 -04:00
|
|
|
require.True(t, reply)
|
2021-11-09 15:15:45 +01:00
|
|
|
|
|
|
|
err = d.DeleteV1Subscription(
|
|
|
|
makeRequest(t),
|
|
|
|
args,
|
|
|
|
&reply,
|
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-14 11:36:34 -04:00
|
|
|
require.True(t, reply)
|
2021-11-09 15:15:45 +01:00
|
|
|
}
|
2021-11-18 15:20:58 +01:00
|
|
|
|
|
|
|
func TestRelayGetV1Messages(t *testing.T) {
|
|
|
|
serviceA := makeRelayService(t)
|
2023-01-06 18:37:57 -04:00
|
|
|
go serviceA.Start()
|
|
|
|
defer serviceA.Stop()
|
|
|
|
|
2021-11-18 15:20:58 +01:00
|
|
|
var reply SuccessReply
|
|
|
|
|
|
|
|
serviceB := makeRelayService(t)
|
|
|
|
go serviceB.Start()
|
|
|
|
defer serviceB.Stop()
|
|
|
|
|
|
|
|
hostInfo, err := multiaddr.NewMultiaddr(fmt.Sprintf("/p2p/%s", serviceB.node.Host().ID().Pretty()))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
var addr multiaddr.Multiaddr
|
|
|
|
for _, a := range serviceB.node.Host().Addrs() {
|
|
|
|
addr = a.Encapsulate(hostInfo)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
err = serviceA.node.DialPeerWithMultiAddress(context.Background(), addr)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Wait for the dial to complete
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
|
|
|
|
args := &TopicsArgs{Topics: []string{"test"}}
|
|
|
|
err = serviceB.PostV1Subscription(
|
|
|
|
makeRequest(t),
|
|
|
|
args,
|
|
|
|
&reply,
|
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-14 11:36:34 -04:00
|
|
|
require.True(t, reply)
|
2021-11-18 15:20:58 +01:00
|
|
|
|
|
|
|
// Wait for the subscription to be started
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
|
|
|
|
err = serviceA.PostV1Message(
|
|
|
|
makeRequest(t),
|
|
|
|
&RelayMessageArgs{
|
|
|
|
Topic: "test",
|
2023-02-16 23:35:22 -04:00
|
|
|
Message: ProtoToRPC(&pb.WakuMessage{
|
2021-11-18 15:20:58 +01:00
|
|
|
Payload: []byte("test"),
|
2023-02-16 23:35:22 -04:00
|
|
|
}),
|
2021-11-18 15:20:58 +01:00
|
|
|
},
|
|
|
|
&reply,
|
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-14 11:36:34 -04:00
|
|
|
require.True(t, reply)
|
2021-11-18 15:20:58 +01:00
|
|
|
|
|
|
|
// Wait for the message to be received
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
|
2023-02-16 23:35:22 -04:00
|
|
|
var messagesReply1 MessagesReply
|
2021-11-18 15:20:58 +01:00
|
|
|
err = serviceB.GetV1Messages(
|
|
|
|
makeRequest(t),
|
|
|
|
&TopicArgs{"test"},
|
2022-06-13 14:30:35 -04:00
|
|
|
&messagesReply1,
|
2021-11-18 15:20:58 +01:00
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-13 14:30:35 -04:00
|
|
|
require.Len(t, messagesReply1, 1)
|
2021-11-18 15:20:58 +01:00
|
|
|
|
2023-02-16 23:35:22 -04:00
|
|
|
var messagesReply2 MessagesReply
|
2021-11-18 15:20:58 +01:00
|
|
|
err = serviceB.GetV1Messages(
|
|
|
|
makeRequest(t),
|
|
|
|
&TopicArgs{"test"},
|
2022-06-13 14:30:35 -04:00
|
|
|
&messagesReply2,
|
2021-11-18 15:20:58 +01:00
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-13 14:30:35 -04:00
|
|
|
require.Len(t, messagesReply2, 0)
|
2021-11-18 15:20:58 +01:00
|
|
|
}
|