2024-01-19 16:58:51 +01:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/ecdsa"
|
|
|
|
|
|
|
|
"github.com/google/uuid"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
|
|
|
"github.com/status-im/status-go/account/generator"
|
|
|
|
"github.com/status-im/status-go/appdatabase"
|
|
|
|
"github.com/status-im/status-go/common/dbsetup"
|
|
|
|
"github.com/status-im/status-go/eth-node/crypto"
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
|
|
"github.com/status-im/status-go/multiaccounts"
|
2024-01-29 12:24:20 +01:00
|
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
2024-01-19 16:58:51 +01:00
|
|
|
"github.com/status-im/status-go/protocol/tt"
|
2024-01-29 12:24:20 +01:00
|
|
|
v1protocol "github.com/status-im/status-go/protocol/v1"
|
2024-01-19 16:58:51 +01:00
|
|
|
"github.com/status-im/status-go/t/helpers"
|
|
|
|
"github.com/status-im/status-go/walletdatabase"
|
|
|
|
)
|
|
|
|
|
|
|
|
type testMessengerConfig struct {
|
|
|
|
name string
|
|
|
|
privateKey *ecdsa.PrivateKey
|
|
|
|
logger *zap.Logger
|
2024-01-29 12:24:20 +01:00
|
|
|
|
|
|
|
unhandledMessagesTracker *unhandledMessagesTracker
|
2024-02-06 21:23:43 +01:00
|
|
|
messagesOrderController *MessagesOrderController
|
|
|
|
|
|
|
|
extraOptions []Option
|
2024-01-19 16:58:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (tmc *testMessengerConfig) complete() error {
|
|
|
|
if len(tmc.name) == 0 {
|
|
|
|
tmc.name = uuid.NewString()
|
|
|
|
}
|
|
|
|
|
|
|
|
if tmc.privateKey == nil {
|
|
|
|
privateKey, err := crypto.GenerateKey()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
tmc.privateKey = privateKey
|
|
|
|
}
|
|
|
|
|
|
|
|
if tmc.logger == nil {
|
|
|
|
logger := tt.MustCreateTestLogger()
|
2024-01-30 13:43:34 +00:00
|
|
|
tmc.logger = logger.Named(tmc.name)
|
2024-01-19 16:58:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-01-30 13:43:34 +00:00
|
|
|
func newTestMessenger(waku types.Waku, config testMessengerConfig) (*Messenger, error) {
|
2024-01-19 16:58:51 +01:00
|
|
|
err := config.complete()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
acc := generator.NewAccount(config.privateKey, nil)
|
|
|
|
iai := acc.ToIdentifiedAccountInfo("")
|
|
|
|
|
|
|
|
madb, err := multiaccounts.InitializeDB(dbsetup.InMemoryPath)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
walletDb, err := helpers.SetupTestMemorySQLDB(walletdatabase.DbInitializer{})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
appDb, err := helpers.SetupTestMemorySQLDB(appdatabase.DbInitializer{})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
options := []Option{
|
|
|
|
WithCustomLogger(config.logger),
|
|
|
|
WithDatabase(appDb),
|
|
|
|
WithWalletDatabase(walletDb),
|
|
|
|
WithMultiAccounts(madb),
|
|
|
|
WithAccount(iai.ToMultiAccount()),
|
|
|
|
WithDatasync(),
|
|
|
|
WithToplevelDatabaseMigrations(),
|
|
|
|
WithBrowserDatabase(nil),
|
|
|
|
}
|
2024-01-30 13:43:34 +00:00
|
|
|
options = append(options, config.extraOptions...)
|
2024-01-19 16:58:51 +01:00
|
|
|
|
|
|
|
m, err := NewMessenger(
|
|
|
|
config.name,
|
|
|
|
config.privateKey,
|
|
|
|
&testNode{shh: waku},
|
|
|
|
uuid.New().String(),
|
|
|
|
nil,
|
|
|
|
options...,
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2024-01-29 12:24:20 +01:00
|
|
|
if config.unhandledMessagesTracker != nil {
|
|
|
|
m.unhandledMessagesTracker = config.unhandledMessagesTracker.addMessage
|
|
|
|
}
|
|
|
|
|
2024-02-06 21:23:43 +01:00
|
|
|
if config.messagesOrderController != nil {
|
|
|
|
m.retrievedMessagesIteratorFactory = config.messagesOrderController.newMessagesIterator
|
|
|
|
}
|
|
|
|
|
2024-01-19 16:58:51 +01:00
|
|
|
err = m.Init()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return m, nil
|
|
|
|
}
|
2024-01-29 12:24:20 +01:00
|
|
|
|
|
|
|
type unhandedMessage struct {
|
|
|
|
*v1protocol.StatusMessage
|
|
|
|
err error
|
|
|
|
}
|
|
|
|
|
|
|
|
type unhandledMessagesTracker struct {
|
|
|
|
messages map[protobuf.ApplicationMetadataMessage_Type][]*unhandedMessage
|
|
|
|
}
|
|
|
|
|
|
|
|
func (u *unhandledMessagesTracker) addMessage(msg *v1protocol.StatusMessage, err error) {
|
|
|
|
msgType := msg.ApplicationLayer.Type
|
|
|
|
|
|
|
|
if _, exists := u.messages[msgType]; !exists {
|
|
|
|
u.messages[msgType] = []*unhandedMessage{}
|
|
|
|
}
|
|
|
|
|
|
|
|
newMessage := &unhandedMessage{
|
|
|
|
StatusMessage: msg,
|
|
|
|
err: err,
|
|
|
|
}
|
|
|
|
u.messages[msgType] = append(u.messages[msgType], newMessage)
|
|
|
|
}
|