2020-06-26 09:46:14 +02:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/ecdsa"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
|
|
|
gethbridge "github.com/status-im/status-go/eth-node/bridge/geth"
|
|
|
|
"github.com/status-im/status-go/eth-node/crypto"
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
|
|
"github.com/status-im/status-go/protocol/tt"
|
2020-07-21 17:41:10 +02:00
|
|
|
"github.com/status-im/status-go/waku"
|
2020-06-26 09:46:14 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestMessengerMuteSuite(t *testing.T) {
|
|
|
|
suite.Run(t, new(MessengerMuteSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type MessengerMuteSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
m *Messenger // main instance of Messenger
|
|
|
|
privateKey *ecdsa.PrivateKey // private key for the main instance of Messenger
|
|
|
|
|
|
|
|
// If one wants to send messages between different instances of Messenger,
|
2020-07-21 17:41:10 +02:00
|
|
|
// a single Waku service should be shared.
|
|
|
|
shh types.Waku
|
2020-06-26 09:46:14 +02:00
|
|
|
|
2020-10-08 16:05:49 +02:00
|
|
|
logger *zap.Logger
|
2020-06-26 09:46:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerMuteSuite) SetupTest() {
|
|
|
|
s.logger = tt.MustCreateTestLogger()
|
|
|
|
|
2020-07-21 17:41:10 +02:00
|
|
|
config := waku.DefaultConfig
|
|
|
|
config.MinimumAcceptedPoW = 0
|
|
|
|
shh := waku.New(&config, s.logger)
|
|
|
|
s.shh = gethbridge.NewGethWakuWrapper(shh)
|
2020-06-26 09:46:14 +02:00
|
|
|
s.Require().NoError(shh.Start(nil))
|
|
|
|
|
|
|
|
s.m = s.newMessenger(s.shh)
|
|
|
|
s.privateKey = s.m.identity
|
2021-01-14 23:15:13 +01:00
|
|
|
_, err := s.m.Start()
|
|
|
|
s.Require().NoError(err)
|
2020-07-31 11:46:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerMuteSuite) TearDownTest() {
|
|
|
|
s.Require().NoError(s.m.Shutdown())
|
2020-06-26 09:46:14 +02:00
|
|
|
}
|
|
|
|
|
2020-07-21 17:41:10 +02:00
|
|
|
func (s *MessengerMuteSuite) newMessenger(shh types.Waku) *Messenger {
|
2020-06-26 09:46:14 +02:00
|
|
|
privateKey, err := crypto.GenerateKey()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2020-12-21 12:57:47 +01:00
|
|
|
messenger, err := newMessengerWithKey(s.shh, privateKey, s.logger, nil)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
return messenger
|
2020-06-26 09:46:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerMuteSuite) TestSetMute() {
|
|
|
|
key, err := crypto.GenerateKey()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2020-12-21 12:57:47 +01:00
|
|
|
theirMessenger, err := newMessengerWithKey(s.shh, key, s.logger, nil)
|
|
|
|
s.Require().NoError(err)
|
2020-06-26 09:46:14 +02:00
|
|
|
|
|
|
|
chatID := "status"
|
|
|
|
|
|
|
|
chat := CreatePublicChat(chatID, s.m.transport)
|
|
|
|
|
2021-01-11 11:32:51 +01:00
|
|
|
err = s.m.SaveChat(chat)
|
2020-06-26 09:46:14 +02:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2021-01-11 11:32:51 +01:00
|
|
|
_, err = s.m.Join(chat)
|
2020-06-26 09:46:14 +02:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2021-01-11 11:32:51 +01:00
|
|
|
err = theirMessenger.SaveChat(chat)
|
2020-06-26 09:46:14 +02:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
s.Require().NoError(s.m.MuteChat(chatID))
|
|
|
|
|
2021-05-14 12:55:42 +02:00
|
|
|
allChats := s.m.Chats()
|
|
|
|
s.Require().Len(allChats, 3)
|
|
|
|
|
|
|
|
var actualChat *Chat
|
|
|
|
|
|
|
|
for idx := range allChats {
|
|
|
|
if chat.ID == allChats[idx].ID {
|
|
|
|
actualChat = allChats[idx]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
s.Require().NotNil(actualChat)
|
|
|
|
s.Require().True(actualChat.Muted)
|
2020-06-26 09:46:14 +02:00
|
|
|
|
|
|
|
s.Require().NoError(s.m.UnmuteChat(chatID))
|
2021-05-14 12:55:42 +02:00
|
|
|
|
|
|
|
allChats = s.m.Chats()
|
|
|
|
|
|
|
|
for idx := range allChats {
|
|
|
|
if chat.ID == allChats[idx].ID {
|
|
|
|
actualChat = allChats[idx]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
s.Require().False(actualChat.Muted)
|
2020-07-31 11:46:38 +02:00
|
|
|
s.Require().NoError(theirMessenger.Shutdown())
|
2020-06-26 09:46:14 +02:00
|
|
|
}
|