2022-12-02 11:34:02 +00:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
|
|
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/protocol/common"
|
|
|
|
"github.com/status-im/status-go/protocol/communities"
|
|
|
|
"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/waku"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestMessengerDeleteMessageForEveryoneSuite(t *testing.T) {
|
|
|
|
suite.Run(t, new(MessengerDeleteMessageForEveryoneSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type MessengerDeleteMessageForEveryoneSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
admin *Messenger
|
|
|
|
moderator *Messenger
|
|
|
|
bob *Messenger
|
|
|
|
shh types.Waku
|
|
|
|
logger *zap.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerDeleteMessageForEveryoneSuite) SetupTest() {
|
|
|
|
s.logger = tt.MustCreateTestLogger()
|
|
|
|
|
|
|
|
config := waku.DefaultConfig
|
|
|
|
config.MinimumAcceptedPoW = 0
|
|
|
|
shh := waku.New(&config, s.logger)
|
|
|
|
s.shh = gethbridge.NewGethWakuWrapper(shh)
|
|
|
|
s.Require().NoError(shh.Start())
|
|
|
|
|
|
|
|
s.admin = s.newMessenger()
|
|
|
|
s.bob = s.newMessenger()
|
|
|
|
s.moderator = s.newMessenger()
|
|
|
|
_, err := s.admin.Start()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
_, err = s.bob.Start()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
_, err = s.moderator.Start()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerDeleteMessageForEveryoneSuite) TearDownTest() {
|
|
|
|
s.Require().NoError(s.admin.Shutdown())
|
|
|
|
s.Require().NoError(s.bob.Shutdown())
|
2023-06-22 12:16:21 +00:00
|
|
|
s.Require().NoError(s.moderator.Shutdown())
|
2022-12-02 11:34:02 +00:00
|
|
|
_ = s.logger.Sync()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerDeleteMessageForEveryoneSuite) newMessenger() *Messenger {
|
|
|
|
privateKey, err := crypto.GenerateKey()
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
messenger, err := newMessengerWithKey(s.shh, privateKey, s.logger, nil)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
return messenger
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerDeleteMessageForEveryoneSuite) TestDeleteMessageForEveryone() {
|
|
|
|
community := s.createCommunity()
|
|
|
|
communityChat := s.createCommunityChat(community)
|
2023-08-03 19:23:38 +00:00
|
|
|
|
|
|
|
request := &requests.RequestToJoinCommunity{CommunityID: community.ID()}
|
|
|
|
|
|
|
|
advertiseCommunityTo(&s.Suite, community, s.admin, s.moderator)
|
|
|
|
joinCommunity(&s.Suite, community, s.admin, s.moderator, request)
|
|
|
|
|
|
|
|
advertiseCommunityTo(&s.Suite, community, s.admin, s.bob)
|
|
|
|
joinCommunity(&s.Suite, community, s.admin, s.bob, request)
|
2022-12-02 11:34:02 +00:00
|
|
|
|
|
|
|
response, err := s.admin.AddRoleToMember(&requests.AddRoleToMember{
|
|
|
|
CommunityID: community.ID(),
|
|
|
|
User: common.PubkeyToHexBytes(s.moderator.IdentityPublicKey()),
|
2023-08-16 10:14:53 +00:00
|
|
|
Role: protobuf.CommunityMember_ROLE_ADMIN,
|
2022-12-02 11:34:02 +00:00
|
|
|
})
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().Len(response.Communities(), 1)
|
|
|
|
|
2022-12-13 08:06:01 +00:00
|
|
|
_, err = WaitOnMessengerResponse(s.moderator, func(response *MessengerResponse) bool {
|
|
|
|
return len(response.Communities()) > 0
|
|
|
|
}, "community description changed message not received")
|
|
|
|
s.Require().NoError(err)
|
|
|
|
_, err = WaitOnMessengerResponse(s.bob, func(response *MessengerResponse) bool {
|
|
|
|
return len(response.Communities()) > 0
|
|
|
|
}, "community description changed message not received")
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2022-12-02 11:34:02 +00:00
|
|
|
ctx := context.Background()
|
2023-08-18 11:39:59 +00:00
|
|
|
inputMessage := common.NewMessage()
|
2022-12-02 11:34:02 +00:00
|
|
|
inputMessage.ChatId = communityChat.ID
|
|
|
|
inputMessage.ContentType = protobuf.ChatMessage_TEXT_PLAIN
|
|
|
|
inputMessage.Text = "some text"
|
|
|
|
_, err = s.bob.SendChatMessage(ctx, inputMessage)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
response, err = WaitOnMessengerResponse(s.moderator, func(response *MessengerResponse) bool {
|
|
|
|
return len(response.Messages()) > 0
|
|
|
|
}, "messages not received")
|
|
|
|
s.Require().NoError(err)
|
|
|
|
message := response.Messages()[0]
|
|
|
|
s.Require().Equal(inputMessage.Text, message.Text)
|
2022-12-13 08:06:01 +00:00
|
|
|
|
2023-02-01 00:57:35 +00:00
|
|
|
deleteMessageResponse, err := s.moderator.DeleteMessageAndSend(ctx, message.ID)
|
2022-12-02 11:34:02 +00:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
2023-03-16 18:41:53 +00:00
|
|
|
response, err = WaitOnMessengerResponse(s.bob, func(response *MessengerResponse) bool {
|
2022-12-13 08:06:01 +00:00
|
|
|
return len(response.RemovedMessages()) > 0
|
|
|
|
}, "removed messages not received")
|
2023-02-01 00:57:35 +00:00
|
|
|
s.Require().Equal(deleteMessageResponse.RemovedMessages()[0].DeletedBy, contactIDFromPublicKey(s.moderator.IdentityPublicKey()))
|
2023-03-16 18:41:53 +00:00
|
|
|
|
2022-12-13 08:06:01 +00:00
|
|
|
s.Require().NoError(err)
|
2023-03-16 18:41:53 +00:00
|
|
|
s.Require().Len(response.ActivityCenterNotifications(), 1)
|
|
|
|
s.Require().True(response.ActivityCenterNotifications()[0].Deleted)
|
|
|
|
|
2022-12-13 08:06:01 +00:00
|
|
|
message, err = s.bob.MessageByID(message.ID)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().True(message.Deleted)
|
2022-12-02 11:34:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerDeleteMessageForEveryoneSuite) createCommunity() *communities.Community {
|
|
|
|
description := &requests.CreateCommunity{
|
2023-10-25 13:03:26 +00:00
|
|
|
Membership: protobuf.CommunityPermissions_AUTO_ACCEPT,
|
2022-12-02 11:34:02 +00:00
|
|
|
Name: "status",
|
|
|
|
Color: "#ffffff",
|
|
|
|
Description: "status community description",
|
|
|
|
}
|
|
|
|
response, err := s.admin.CreateCommunity(description, false)
|
|
|
|
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().NotNil(response)
|
|
|
|
s.Require().Len(response.Communities(), 1)
|
|
|
|
s.Require().Len(response.Chats(), 0)
|
|
|
|
|
|
|
|
return response.Communities()[0]
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *MessengerDeleteMessageForEveryoneSuite) createCommunityChat(community *communities.Community) *Chat {
|
|
|
|
orgChat := &protobuf.CommunityChat{
|
|
|
|
Permissions: &protobuf.CommunityPermissions{
|
2023-10-25 13:03:26 +00:00
|
|
|
Access: protobuf.CommunityPermissions_AUTO_ACCEPT,
|
2022-12-02 11:34:02 +00:00
|
|
|
},
|
|
|
|
Identity: &protobuf.ChatIdentity{
|
|
|
|
DisplayName: "status-core",
|
|
|
|
Emoji: "",
|
|
|
|
Description: "status-core community chatToModerator",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
response, err := s.admin.CreateCommunityChat(community.ID(), orgChat)
|
|
|
|
s.Require().NoError(err)
|
|
|
|
s.Require().NotNil(response)
|
|
|
|
s.Require().Len(response.Communities(), 1)
|
|
|
|
s.Require().Len(response.Chats(), 1)
|
|
|
|
return response.Chats()[0]
|
|
|
|
}
|