2023-11-25 23:24:20 +00:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
|
|
"github.com/status-im/status-go/appdatabase"
|
|
|
|
gethbridge "github.com/status-im/status-go/eth-node/bridge/geth"
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
|
|
"github.com/status-im/status-go/params"
|
|
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
|
|
|
"github.com/status-im/status-go/protocol/requests"
|
|
|
|
"github.com/status-im/status-go/protocol/tt"
|
|
|
|
"github.com/status-im/status-go/t/helpers"
|
|
|
|
|
|
|
|
mailserversDB "github.com/status-im/status-go/services/mailservers"
|
|
|
|
waku2 "github.com/status-im/status-go/wakuv2"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
localFleet = "local-test-fleet-1"
|
|
|
|
localMailserverID = "local-test-mailserver"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestMessengerStoreNodeRequestSuite(t *testing.T) {
|
|
|
|
suite.Run(t, new(MessengerStoreNodeRequestSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type MessengerStoreNodeRequestSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
|
|
|
|
owner *Messenger
|
|
|
|
bob *Messenger
|
|
|
|
|
|
|
|
wakuStoreNode *waku2.Waku
|
|
|
|
ownerWaku types.Waku
|
|
|
|
bobWaku types.Waku
|
|
|
|
|
|
|
|
logger *zap.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerStoreNodeRequestSuite) newMessenger(shh types.Waku, logger *zap.Logger, mailserverAddress string) *Messenger {
|
|
|
|
privateKey, err := crypto.GenerateKey()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
mailserversSQLDb, err := helpers.SetupTestMemorySQLDB(appdatabase.DbInitializer{})
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
mailserversDatabase := mailserversDB.NewDB(mailserversSQLDb)
|
|
|
|
err = mailserversDatabase.Add(mailserversDB.Mailserver{
|
|
|
|
ID: localMailserverID,
|
|
|
|
Name: localMailserverID,
|
|
|
|
Address: mailserverAddress,
|
|
|
|
Fleet: localFleet,
|
|
|
|
})
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
options := []Option{
|
|
|
|
WithMailserversDatabase(mailserversDatabase),
|
|
|
|
WithClusterConfig(params.ClusterConfig{
|
|
|
|
Fleet: localFleet,
|
|
|
|
}),
|
|
|
|
}
|
|
|
|
|
|
|
|
messenger, err := newMessengerWithKey(shh, privateKey, logger, options)
|
|
|
|
|
|
|
|
s.Require().NoError(err)
|
|
|
|
return messenger
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerStoreNodeRequestSuite) SetupTest() {
|
|
|
|
s.logger = tt.MustCreateTestLogger()
|
|
|
|
|
|
|
|
// Create store node
|
|
|
|
|
|
|
|
storeNodeLogger := s.logger.With(zap.String("name", "store-node-waku"))
|
|
|
|
s.wakuStoreNode = NewWakuV2(&s.Suite, storeNodeLogger, true, true)
|
|
|
|
|
|
|
|
storeNodeListenAddresses := s.wakuStoreNode.ListenAddresses()
|
|
|
|
s.Require().LessOrEqual(1, len(storeNodeListenAddresses))
|
|
|
|
|
|
|
|
storeNodeAddress := storeNodeListenAddresses[0]
|
|
|
|
s.logger.Info("store node ready", zap.String("address", storeNodeAddress))
|
|
|
|
|
|
|
|
// Create community owner
|
|
|
|
|
|
|
|
ownerWakuLogger := s.logger.With(zap.String("name", "owner-waku"))
|
|
|
|
s.ownerWaku = gethbridge.NewGethWakuV2Wrapper(NewWakuV2(&s.Suite, ownerWakuLogger, true, false))
|
|
|
|
|
|
|
|
ownerLogger := s.logger.With(zap.String("name", "owner"))
|
|
|
|
s.owner = s.newMessenger(s.ownerWaku, ownerLogger, storeNodeAddress)
|
|
|
|
|
|
|
|
// Create an independent user
|
|
|
|
|
|
|
|
bobWakuLogger := s.logger.With(zap.String("name", "owner-waku"))
|
|
|
|
s.bobWaku = gethbridge.NewGethWakuV2Wrapper(NewWakuV2(&s.Suite, bobWakuLogger, true, false))
|
|
|
|
|
|
|
|
bobLogger := s.logger.With(zap.String("name", "bob"))
|
|
|
|
s.bob = s.newMessenger(s.bobWaku, bobLogger, storeNodeAddress)
|
|
|
|
s.bob.StartRetrieveMessagesLoop(time.Second, nil)
|
2023-11-24 20:32:02 +00:00
|
|
|
|
|
|
|
// Connect owner to storenode so message is stored
|
|
|
|
err := s.ownerWaku.DialPeer(storeNodeAddress)
|
|
|
|
s.Require().NoError(err)
|
2023-11-25 23:24:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerStoreNodeRequestSuite) TestRequestCommunityInfo() {
|
|
|
|
WaitForAvailableStoreNode(&s.Suite, s.owner, time.Second)
|
|
|
|
|
|
|
|
createCommunityRequest := &requests.CreateCommunity{
|
|
|
|
Name: "panda-lovers",
|
|
|
|
Description: "we love pandas",
|
|
|
|
Membership: protobuf.CommunityPermissions_AUTO_ACCEPT,
|
|
|
|
Color: "#ff0000",
|
|
|
|
Tags: []string{"Web3"},
|
|
|
|
}
|
|
|
|
|
|
|
|
response, err := s.owner.CreateCommunity(createCommunityRequest, true)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().NotNil(response)
|
|
|
|
s.Require().Len(response.Communities(), 1)
|
|
|
|
|
|
|
|
community := response.Communities()[0]
|
|
|
|
communityID := community.IDString()
|
|
|
|
|
|
|
|
WaitForAvailableStoreNode(&s.Suite, s.bob, time.Second)
|
|
|
|
|
|
|
|
request := FetchCommunityRequest{
|
|
|
|
CommunityKey: communityID,
|
|
|
|
Shard: nil,
|
|
|
|
TryDatabase: false,
|
|
|
|
WaitForResponse: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
fetchedCommunity, err := s.bob.FetchCommunity(&request)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().NotNil(fetchedCommunity)
|
|
|
|
s.Require().Equal(communityID, fetchedCommunity.IDString())
|
|
|
|
}
|