mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-12 14:54:19 +00:00
11d1f8fb0d
* feat: result aggregation in resume and enforce max page size * feat: add WithLogger option to wakunode (#184) * fix: rebase issues
143 lines
3.3 KiB
Go
143 lines
3.3 KiB
Go
package rpc
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/status-im/go-waku/tests"
|
|
"github.com/status-im/go-waku/waku/v2/node"
|
|
"github.com/status-im/go-waku/waku/v2/protocol/pb"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func makePrivateService(t *testing.T) *PrivateService {
|
|
n, err := node.New(context.Background(), node.WithWakuRelayAndMinPeers(0))
|
|
require.NoError(t, err)
|
|
err = n.Start()
|
|
require.NoError(t, err)
|
|
|
|
return NewPrivateService(n, tests.Logger())
|
|
}
|
|
|
|
func TestGetV1SymmetricKey(t *testing.T) {
|
|
d := makePrivateService(t)
|
|
defer d.node.Stop()
|
|
|
|
var reply SymmetricKeyReply
|
|
err := d.GetV1SymmetricKey(
|
|
makeRequest(t),
|
|
&Empty{},
|
|
&reply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.NotEmpty(t, reply.Key)
|
|
}
|
|
|
|
func TestGetV1AsymmetricKey(t *testing.T) {
|
|
d := makePrivateService(t)
|
|
defer d.node.Stop()
|
|
|
|
var reply KeyPairReply
|
|
err := d.GetV1AsymmetricKeypair(
|
|
makeRequest(t),
|
|
&Empty{},
|
|
&reply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.NotEmpty(t, reply.PulicKey)
|
|
require.NotEmpty(t, reply.PrivateKey)
|
|
}
|
|
|
|
func TestPostV1SymmetricMessage(t *testing.T) {
|
|
d := makePrivateService(t)
|
|
defer d.node.Stop()
|
|
|
|
var reply SuccessReply
|
|
err := d.PostV1SymmetricMessage(
|
|
makeRequest(t),
|
|
&SymmetricMessageArgs{
|
|
Topic: "test",
|
|
Message: pb.WakuMessage{Payload: []byte("test")},
|
|
SymKey: "abc",
|
|
},
|
|
&reply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.True(t, reply.Success)
|
|
}
|
|
|
|
func TestPostV1AsymmetricMessage(t *testing.T) {
|
|
d := makePrivateService(t)
|
|
defer d.node.Stop()
|
|
|
|
var reply SuccessReply
|
|
err := d.PostV1AsymmetricMessage(
|
|
makeRequest(t),
|
|
&AsymmetricMessageArgs{
|
|
Topic: "test",
|
|
Message: pb.WakuMessage{Payload: []byte("test")},
|
|
PublicKey: "045ded6a56c88173e87a88c55b96956964b1bd3351b5fcb70950a4902fbc1bc0ceabb0ac846c3a4b8f2f6024c0e19f0a7f6a4865035187de5463f34012304fc7c5",
|
|
},
|
|
&reply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.True(t, reply.Success)
|
|
}
|
|
|
|
func TestGetV1SymmetricMessages(t *testing.T) {
|
|
d := makePrivateService(t)
|
|
defer d.node.Stop()
|
|
|
|
var reply SuccessReply
|
|
err := d.PostV1SymmetricMessage(
|
|
makeRequest(t),
|
|
&SymmetricMessageArgs{
|
|
Topic: "test",
|
|
Message: pb.WakuMessage{Payload: []byte("test")},
|
|
SymKey: "abc",
|
|
},
|
|
&reply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.True(t, reply.Success)
|
|
|
|
var getReply MessagesReply
|
|
err = d.GetV1SymmetricMessages(
|
|
makeRequest(t),
|
|
&SymmetricMessagesArgs{Topic: "test", SymKey: "abc"},
|
|
&getReply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.Len(t, getReply.Messages, 1)
|
|
}
|
|
|
|
func TestGetV1AsymmetricMessages(t *testing.T) {
|
|
d := makePrivateService(t)
|
|
defer d.node.Stop()
|
|
|
|
var reply SuccessReply
|
|
err := d.PostV1AsymmetricMessage(
|
|
makeRequest(t),
|
|
&AsymmetricMessageArgs{
|
|
Topic: "test",
|
|
Message: pb.WakuMessage{Payload: []byte("test")},
|
|
PublicKey: "045ded6a56c88173e87a88c55b96956964b1bd3351b5fcb70950a4902fbc1bc0ceabb0ac846c3a4b8f2f6024c0e19f0a7f6a4865035187de5463f34012304fc7c5",
|
|
},
|
|
&reply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.True(t, reply.Success)
|
|
|
|
var getReply MessagesReply
|
|
err = d.GetV1AsymmetricMessages(
|
|
makeRequest(t),
|
|
&AsymmetricMessagesArgs{
|
|
Topic: "test",
|
|
PrivateKey: "045ded6a56c88173e87a88c55b96956964b1bd3351b5fcb70950a4902fbc1bc0ceabb0ac846c3a4b8f2f6024c0e19f0a7f6a4865035187de5463f34012304fc7c5",
|
|
},
|
|
&getReply,
|
|
)
|
|
require.NoError(t, err)
|
|
require.Len(t, getReply.Messages, 1)
|
|
}
|