2020-06-26 09:46:14 +02:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
2023-04-16 17:06:00 +02:00
|
|
|
"time"
|
2020-06-26 09:46:14 +02:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
2023-08-03 17:16:11 +03:00
|
|
|
"github.com/status-im/status-go/deprecation"
|
2020-06-26 09:46:14 +02:00
|
|
|
"github.com/status-im/status-go/eth-node/crypto"
|
2023-04-16 17:06:00 +02:00
|
|
|
"github.com/status-im/status-go/protocol/requests"
|
2020-06-26 09:46:14 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestMessengerMuteSuite(t *testing.T) {
|
|
|
|
suite.Run(t, new(MessengerMuteSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type MessengerMuteSuite struct {
|
2023-07-13 11:28:34 +01:00
|
|
|
MessengerBaseTestSuite
|
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
|
|
|
|
2023-04-16 17:06:00 +02:00
|
|
|
chatID := publicChatName
|
2020-06-26 09:46:14 +02:00
|
|
|
|
|
|
|
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)
|
|
|
|
|
2023-04-16 17:06:00 +02:00
|
|
|
_, error := s.m.MuteChat(&requests.MuteChat{ChatID: chatID, MutedType: 5})
|
|
|
|
s.NoError(error)
|
2020-06-26 09:46:14 +02:00
|
|
|
|
2021-05-14 12:55:42 +02:00
|
|
|
allChats := s.m.Chats()
|
2023-08-03 17:16:11 +03:00
|
|
|
s.Require().Len(allChats, deprecation.AddChatsCount(1))
|
2021-05-14 12:55:42 +02:00
|
|
|
|
|
|
|
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
|
|
|
}
|
2023-04-16 17:06:00 +02:00
|
|
|
|
|
|
|
func (s *MessengerMuteSuite) TestSetMuteForDuration() {
|
|
|
|
key, err := crypto.GenerateKey()
|
|
|
|
mockTimeOneMinuteAgo := time.Now().Add(-time.Minute)
|
|
|
|
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
theirMessenger, err := newMessengerWithKey(s.shh, key, s.logger, nil)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
chatID := publicChatName
|
|
|
|
|
|
|
|
chat := CreatePublicChat(chatID, s.m.transport)
|
|
|
|
|
|
|
|
err = s.m.SaveChat(chat)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
_, err = s.m.Join(chat)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
err = theirMessenger.SaveChat(chat)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
allChats := s.m.Chats()
|
2023-08-03 17:16:11 +03:00
|
|
|
s.Require().Len(allChats, deprecation.AddChatsCount(1))
|
2023-04-16 17:06:00 +02:00
|
|
|
|
|
|
|
var actualChat *Chat
|
|
|
|
|
|
|
|
for idx := range allChats {
|
|
|
|
if chat.ID == allChats[idx].ID {
|
|
|
|
actualChat = allChats[idx]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var contact *Contact
|
|
|
|
if actualChat.OneToOne() {
|
|
|
|
contact, _ = s.m.allContacts.Load(chatID)
|
|
|
|
}
|
|
|
|
|
|
|
|
_, error := s.m.muteChat(actualChat, contact, mockTimeOneMinuteAgo)
|
|
|
|
s.NoError(error)
|
|
|
|
// Mock Routine
|
|
|
|
for _, chat := range allChats {
|
|
|
|
chatMuteTill, chatMuteTillErr := time.Parse(time.RFC3339, chat.MuteTill.Format(time.RFC3339))
|
|
|
|
currTime, currTimeErr := time.Parse(time.RFC3339, time.Now().Format(time.RFC3339))
|
|
|
|
|
|
|
|
if chatMuteTillErr != nil {
|
|
|
|
s.logger.Info("err", zap.Any("Couldn't parse muteTill", err))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if currTimeErr != nil {
|
|
|
|
s.logger.Info("err", zap.Any("Couldn't parse current time", err))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if currTime.After(chatMuteTill) && !chatMuteTill.Equal(time.Time{}) && chat.Muted {
|
|
|
|
_ = s.m.UnmuteChat(chat.ID)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
s.Require().NotNil(actualChat)
|
|
|
|
s.Require().False(actualChat.Muted)
|
|
|
|
|
|
|
|
s.Require().NoError(theirMessenger.Shutdown())
|
|
|
|
}
|