mirror of
https://github.com/status-im/status-go.git
synced 2025-01-15 09:19:26 +00:00
baa0767c26
This commit does a few things: 1) Handle membership updates using protobuf and adds the relevant endpoints. 2) Store in memory a map of chats + contacts for faster lookups, which are then flushed to disk on each update 3) Validate incoming messages Sorry for the large pr, but you know, v1 :)
261 lines
5.8 KiB
Go
261 lines
5.8 KiB
Go
package protocol
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
|
"github.com/stretchr/testify/suite"
|
|
)
|
|
|
|
type MessageValidatorSuite struct {
|
|
suite.Suite
|
|
}
|
|
|
|
func TestMessageValidatorSuite(t *testing.T) {
|
|
suite.Run(t, new(MessageValidatorSuite))
|
|
}
|
|
|
|
func (s *MessageValidatorSuite) TestValidatePlainTextMessage() {
|
|
testCases := []struct {
|
|
Name string
|
|
Valid bool
|
|
Message protobuf.ChatMessage
|
|
}{
|
|
{
|
|
Name: "A valid message",
|
|
Valid: true,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Clock: 1,
|
|
Timestamp: 2,
|
|
Text: "some-text",
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Missing chatId",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
Clock: 1,
|
|
Timestamp: 2,
|
|
Text: "some-text",
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Missing clock",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Timestamp: 2,
|
|
Text: "some-text",
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Missing timestamp",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Clock: 2,
|
|
Text: "some-text",
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Missing text",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Blank text",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: " \n \t \n ",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Unknown MessageType",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: "valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_UNKNOWN_MESSAGE_TYPE,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Unknown ContentType",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: "valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_UNKNOWN_CONTENT_TYPE,
|
|
},
|
|
},
|
|
{
|
|
Name: "System message MessageType",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: "valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_SYSTEM_MESSAGE_PRIVATE_GROUP,
|
|
ContentType: protobuf.ChatMessage_TEXT_PLAIN,
|
|
},
|
|
},
|
|
{
|
|
Name: "Valid emoji only emssage",
|
|
Valid: true,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: ":+1:",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_EMOJI,
|
|
},
|
|
},
|
|
// TODO: FIX ME
|
|
/* {
|
|
Name: "Invalid emoji only emssage",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: ":+1: not valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_EMOJI,
|
|
},
|
|
}
|
|
,*/
|
|
{
|
|
Name: "Valid sticker message",
|
|
Valid: true,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: "valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
Payload: &protobuf.ChatMessage_Sticker{
|
|
Sticker: &protobuf.StickerMessage{
|
|
Pack: 1,
|
|
Hash: "some-hash",
|
|
},
|
|
},
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_STICKER,
|
|
},
|
|
},
|
|
{
|
|
Name: "Invalid sticker message without Pack",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: "valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
Payload: &protobuf.ChatMessage_Sticker{
|
|
Sticker: &protobuf.StickerMessage{
|
|
Hash: "some-hash",
|
|
},
|
|
},
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_STICKER,
|
|
},
|
|
},
|
|
{
|
|
Name: "Invalid sticker message without Hash",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: "valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
Payload: &protobuf.ChatMessage_Sticker{
|
|
Sticker: &protobuf.StickerMessage{
|
|
Pack: 1,
|
|
},
|
|
},
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_STICKER,
|
|
},
|
|
},
|
|
{
|
|
Name: "Invalid sticker message without any content",
|
|
Valid: false,
|
|
Message: protobuf.ChatMessage{
|
|
ChatId: "a",
|
|
Text: "valid",
|
|
Clock: 2,
|
|
Timestamp: 3,
|
|
ResponseTo: "",
|
|
EnsName: "",
|
|
MessageType: protobuf.ChatMessage_ONE_TO_ONE,
|
|
ContentType: protobuf.ChatMessage_STICKER,
|
|
},
|
|
},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
s.Run(tc.Name, func() {
|
|
err := ValidateReceivedChatMessage(&tc.Message)
|
|
if tc.Valid {
|
|
s.Nil(err)
|
|
} else {
|
|
s.NotNil(err)
|
|
}
|
|
})
|
|
}
|
|
}
|