From bf5dcacdeb6bdb4e78ce09a8ac1512d6f5524424 Mon Sep 17 00:00:00 2001 From: Patryk Osmaczko Date: Fri, 19 Jan 2024 16:58:51 +0100 Subject: [PATCH] refactor: introduce `newTestMessenger` This avoids duplication and enables better configuration possibilities for clients. Next step is to cleanup all `newMessenger` derivatives in tests. --- cmd/statusd/main.go | 2 +- multiaccounts/settings/database.go | 4 +- .../communities_messenger_helpers_test.go | 70 +++---------- protocol/messenger.go | 5 +- protocol/messenger_base_test.go | 51 +--------- protocol/messenger_builder_test.go | 99 +++++++++++++++++++ protocol/messenger_config.go | 9 ++ protocol/messenger_sync_settings_test.go | 56 +---------- services/ext/service.go | 5 +- 9 files changed, 136 insertions(+), 165 deletions(-) create mode 100644 protocol/messenger_builder_test.go diff --git a/cmd/statusd/main.go b/cmd/statusd/main.go index d0f7ddac464..c3cae3b449a 100644 --- a/cmd/statusd/main.go +++ b/cmd/statusd/main.go @@ -232,6 +232,7 @@ func main() { protocol.WithTorrentConfig(&config.TorrentConfig), protocol.WithWalletConfig(&config.WalletConfig), protocol.WithRPCClient(backend.StatusNode().RPCClient()), + protocol.WithAccountManager(backend.AccountManager()), } messenger, err := protocol.NewMessenger( @@ -240,7 +241,6 @@ func main() { gethbridge.NewNodeBridge(backend.StatusNode().GethNode(), backend.StatusNode().WakuService(), backend.StatusNode().WakuV2Service()), installationID.String(), nil, - backend.AccountManager(), options..., ) if err != nil { diff --git a/multiaccounts/settings/database.go b/multiaccounts/settings/database.go index ae57d583c8d..cecac073f05 100644 --- a/multiaccounts/settings/database.go +++ b/multiaccounts/settings/database.go @@ -119,6 +119,7 @@ INSERT INTO settings ( current_network, dapps_address, device_name, + preferred_name, display_name, bio, eip1581_address, @@ -150,13 +151,14 @@ INSERT INTO settings ( wallet_collectible_preferences_group_by_collection, wallet_collectible_preferences_group_by_community ) VALUES ( -?,?,?,?,?,?,?,?,?,?,?,?,?, +?,?,?,?,?,?,?,?,?,?,?,?,?,?, ?,?,?,?,?,?,?,?,?,'id',?,?,?,?,?,?,?,?,?,?,?,?)`, s.Address, s.Currency, s.CurrentNetwork, s.DappsAddress, s.DeviceName, + s.PreferredName, s.DisplayName, s.Bio, s.EIP1581Address, diff --git a/protocol/communities_messenger_helpers_test.go b/protocol/communities_messenger_helpers_test.go index d629175b041..5af10aed880 100644 --- a/protocol/communities_messenger_helpers_test.go +++ b/protocol/communities_messenger_helpers_test.go @@ -8,7 +8,6 @@ import ( "sync" "time" - "github.com/google/uuid" "github.com/stretchr/testify/suite" "go.uber.org/zap" @@ -16,12 +15,8 @@ import ( hexutil "github.com/ethereum/go-ethereum/common/hexutil" "github.com/status-im/status-go/account" - "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" "github.com/status-im/status-go/multiaccounts/accounts" "github.com/status-im/status-go/multiaccounts/settings" "github.com/status-im/status-go/params" @@ -32,9 +27,7 @@ import ( "github.com/status-im/status-go/protocol/requests" "github.com/status-im/status-go/services/communitytokens" walletToken "github.com/status-im/status-go/services/wallet/token" - "github.com/status-im/status-go/t/helpers" "github.com/status-im/status-go/transactions" - "github.com/status-im/status-go/walletdatabase" ) type AccountManagerMock struct { @@ -201,56 +194,6 @@ func newMessenger(s *suite.Suite, shh types.Waku, logger *zap.Logger, password s func newCommunitiesTestMessenger(shh types.Waku, privateKey *ecdsa.PrivateKey, logger *zap.Logger, accountsManager account.Manager, tokenManager communities.TokenManager, collectiblesService communitytokens.ServiceInterface) (*Messenger, error) { - madb, err := multiaccounts.InitializeDB(dbsetup.InMemoryPath) - if err != nil { - return nil, err - } - - acc := generator.NewAccount(privateKey, nil) - iai := acc.ToIdentifiedAccountInfo("") - - 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(logger), - WithDatabase(appDb), - WithWalletDatabase(walletDb), - WithMultiAccounts(madb), - WithAccount(iai.ToMultiAccount()), - WithDatasync(), - WithResendParams(3, 3), - WithTokenManager(tokenManager), - } - - if collectiblesService != nil { - options = append(options, WithCommunityTokensService(collectiblesService)) - } - - m, err := NewMessenger( - "Test", - privateKey, - &testNode{shh: shh}, - uuid.New().String(), - nil, - accountsManager, - options..., - ) - if err != nil { - return nil, err - } - - err = m.Init() - if err != nil { - return nil, err - } - config := params.NodeConfig{ NetworkID: 10, DataDir: "test", @@ -279,9 +222,18 @@ func newCommunitiesTestMessenger(shh types.Waku, privateKey *ecdsa.PrivateKey, l SendStatusUpdates: true, WalletRootAddress: types.HexToAddress("0x1122334455667788990011223344556677889900")} - _ = m.settings.CreateSettings(setting, config) + options := []Option{ + WithResendParams(3, 3), + WithAccountManager(accountsManager), + WithTokenManager(tokenManager), + WithCommunityTokensService(collectiblesService), + WithAppSettings(setting, config), + } - return m, nil + return newTestMessenger(shh, testMessengerConfig{ + privateKey: privateKey, + logger: logger, + }, options) } func createCommunity(s *suite.Suite, owner *Messenger) (*communities.Community, *Chat) { diff --git a/protocol/messenger.go b/protocol/messenger.go index 9cc53e94c83..e4406988ff5 100644 --- a/protocol/messenger.go +++ b/protocol/messenger.go @@ -279,7 +279,6 @@ func NewMessenger( node types.Node, installationID string, peerStore *mailservers.PeerStore, - accountsManager account.Manager, opts ...Option, ) (*Messenger, error) { var messenger *Messenger @@ -446,7 +445,7 @@ func NewMessenger( } managerOptions := []communities.ManagerOption{ - communities.WithAccountManager(accountsManager), + communities.WithAccountManager(c.accountsManager), } if walletAPI != nil { @@ -508,7 +507,7 @@ func NewMessenger( pushNotificationServer: pushNotificationServer, communitiesManager: communitiesManager, communitiesKeyDistributor: communitiesKeyDistributor, - accountsManager: accountsManager, + accountsManager: c.accountsManager, ensVerifier: ensVerifier, featureFlags: c.featureFlags, systemMessagesTranslations: c.systemMessagesTranslations, diff --git a/protocol/messenger_base_test.go b/protocol/messenger_base_test.go index b33dc464b35..6b42cfcb7ea 100644 --- a/protocol/messenger_base_test.go +++ b/protocol/messenger_base_test.go @@ -6,22 +6,15 @@ import ( "github.com/stretchr/testify/suite" - "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" 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/multiaccounts" "github.com/status-im/status-go/multiaccounts/settings" "github.com/status-im/status-go/params" "github.com/status-im/status-go/protocol/tt" - "github.com/status-im/status-go/t/helpers" "github.com/status-im/status-go/waku" - "github.com/status-im/status-go/walletdatabase" ) const DefaultProfileDisplayName = "" @@ -68,56 +61,20 @@ type MessengerBaseTestSuite struct { } func newMessengerWithKey(shh types.Waku, privateKey *ecdsa.PrivateKey, logger *zap.Logger, extraOptions []Option) (*Messenger, error) { - madb, err := multiaccounts.InitializeDB(dbsetup.InMemoryPath) - if err != nil { - return nil, err - } - - acc := generator.NewAccount(privateKey, nil) - iai := acc.ToIdentifiedAccountInfo("") - - 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(logger), - WithDatabase(appDb), - WithWalletDatabase(walletDb), - WithMultiAccounts(madb), - WithAccount(iai.ToMultiAccount()), - WithDatasync(), - WithToplevelDatabaseMigrations(), WithAppSettings(settings.Settings{ DisplayName: DefaultProfileDisplayName, ProfilePicturesShowTo: 1, ProfilePicturesVisibility: 1, URLUnfurlingMode: settings.URLUnfurlingAlwaysAsk, }, params.NodeConfig{}), - WithBrowserDatabase(nil), } - options = append(options, extraOptions...) - m, err := NewMessenger( - "Test", - privateKey, - &testNode{shh: shh}, - uuid.New().String(), - nil, - nil, - options..., - ) - if err != nil { - return nil, err - } - - err = m.Init() + m, err := newTestMessenger(shh, testMessengerConfig{ + privateKey: privateKey, + logger: logger, + }, options) if err != nil { return nil, err } diff --git a/protocol/messenger_builder_test.go b/protocol/messenger_builder_test.go new file mode 100644 index 00000000000..570628ee2fd --- /dev/null +++ b/protocol/messenger_builder_test.go @@ -0,0 +1,99 @@ +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" + "github.com/status-im/status-go/protocol/tt" + "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 +} + +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() + tmc.logger = logger.With(zap.String("name", tmc.name)) + } + + return nil +} + +func newTestMessenger(waku types.Waku, config testMessengerConfig, extraOptions []Option) (*Messenger, error) { + 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), + } + options = append(options, extraOptions...) + + m, err := NewMessenger( + config.name, + config.privateKey, + &testNode{shh: waku}, + uuid.New().String(), + nil, + options..., + ) + if err != nil { + return nil, err + } + + err = m.Init() + if err != nil { + return nil, err + } + + return m, nil +} diff --git a/protocol/messenger_config.go b/protocol/messenger_config.go index e1e17eca971..6512ae39bce 100644 --- a/protocol/messenger_config.go +++ b/protocol/messenger_config.go @@ -4,6 +4,7 @@ import ( "database/sql" "encoding/json" + "github.com/status-im/status-go/account" "github.com/status-im/status-go/rpc" "github.com/status-im/status-go/server" "github.com/status-im/status-go/services/browsers" @@ -90,6 +91,7 @@ type config struct { httpServer *server.MediaServer rpcClient *rpc.Client tokenManager communities.TokenManager + accountsManager account.Manager verifyTransactionClient EthClient verifyENSURL string @@ -380,3 +382,10 @@ func WithTokenManager(tokenManager communities.TokenManager) Option { return nil } } + +func WithAccountManager(accountManager account.Manager) Option { + return func(c *config) error { + c.accountsManager = accountManager + return nil + } +} diff --git a/protocol/messenger_sync_settings_test.go b/protocol/messenger_sync_settings_test.go index 521f6ff2728..f1dd9551bf3 100644 --- a/protocol/messenger_sync_settings_test.go +++ b/protocol/messenger_sync_settings_test.go @@ -1,27 +1,21 @@ package protocol import ( - "crypto/ecdsa" "encoding/json" "errors" "testing" - "github.com/google/uuid" "github.com/stretchr/testify/suite" "go.uber.org/zap" - "github.com/status-im/status-go/appdatabase" 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/multiaccounts/settings" "github.com/status-im/status-go/params" "github.com/status-im/status-go/protocol/encryption/multidevice" "github.com/status-im/status-go/protocol/tt" "github.com/status-im/status-go/services/stickers" - "github.com/status-im/status-go/t/helpers" "github.com/status-im/status-go/waku" - "github.com/status-im/status-go/walletdatabase" ) var ( @@ -106,21 +100,7 @@ func (s *MessengerSyncSettingsSuite) TearDownTest() { _ = s.logger.Sync() } -func (s *MessengerSyncSettingsSuite) newMessengerWithOptions(shh types.Waku, privateKey *ecdsa.PrivateKey, options []Option) *Messenger { - m, err := NewMessenger( - "Test", - privateKey, - &testNode{shh: shh}, - uuid.New().String(), - nil, - nil, - options..., - ) - s.Require().NoError(err) - - err = m.Init() - s.Require().NoError(err) - +func (s *MessengerSyncSettingsSuite) newMessenger() *Messenger { config := params.NodeConfig{ NetworkID: 10, DataDir: "test", @@ -150,43 +130,15 @@ func (s *MessengerSyncSettingsSuite) newMessengerWithOptions(shh types.Waku, pri SendStatusUpdates: true, WalletRootAddress: types.HexToAddress("0x1122334455667788990011223344556677889900"), URLUnfurlingMode: settings.URLUnfurlingAlwaysAsk, + PreferredName: &pf, + Currency: "eth", } - err = m.settings.CreateSettings(setting, config) + m, err := newTestMessenger(s.shh, testMessengerConfig{}, []Option{WithAppSettings(setting, config)}) s.Require().NoError(err) - - err = m.settings.SaveSettingField(settings.PreferredName, &pf) - s.Require().NoError(err) - - err = m.settings.SaveSettingField(settings.Currency, "eth") - s.Require().NoError(err) - return m } -func (s *MessengerSyncSettingsSuite) newMessengerWithKey(shh types.Waku, privateKey *ecdsa.PrivateKey) *Messenger { - walletDb, err := helpers.SetupTestMemorySQLDB(walletdatabase.DbInitializer{}) - s.Require().NoError(err) - - appDb, err := helpers.SetupTestMemorySQLDB(appdatabase.DbInitializer{}) - s.Require().NoError(err) - - options := []Option{ - WithCustomLogger(s.logger), - WithDatabase(appDb), - WithWalletDatabase(walletDb), - WithDatasync(), - } - return s.newMessengerWithOptions(shh, privateKey, options) -} - -func (s *MessengerSyncSettingsSuite) newMessenger() *Messenger { - privateKey, err := crypto.GenerateKey() - s.Require().NoError(err) - - return s.newMessengerWithKey(s.shh, privateKey) -} - func prepAliceMessengersForPairing(s *suite.Suite, alice1, alice2 *Messenger) { // Set Alice's installation metadata aim := &multidevice.InstallationMetadata{ diff --git a/services/ext/service.go b/services/ext/service.go index 4db3e24a02a..3858ca8be4c 100644 --- a/services/ext/service.go +++ b/services/ext/service.go @@ -162,7 +162,7 @@ func (s *Service) InitProtocol(nodeName string, identity *ecdsa.PrivateKey, appD s.multiAccountsDB = multiAccountDb s.account = acc - options, err := buildMessengerOptions(s.config, identity, appDb, walletDb, httpServer, s.rpcClient, s.multiAccountsDB, acc, envelopesMonitorConfig, s.accountsDB, walletService, communityTokensService, wakuService, logger, &MessengerSignalsHandler{}) + options, err := buildMessengerOptions(s.config, identity, appDb, walletDb, httpServer, s.rpcClient, s.multiAccountsDB, acc, envelopesMonitorConfig, s.accountsDB, walletService, communityTokensService, wakuService, logger, &MessengerSignalsHandler{}, accountManager) if err != nil { return err } @@ -173,7 +173,6 @@ func (s *Service) InitProtocol(nodeName string, identity *ecdsa.PrivateKey, appD s.n, s.config.ShhextConfig.InstallationID, s.peerStore, - accountManager, options..., ) if err != nil { @@ -391,6 +390,7 @@ func buildMessengerOptions( wakuService *wakuv2.Waku, logger *zap.Logger, messengerSignalsHandler protocol.MessengerSignalsHandler, + accountManager account.Manager, ) ([]protocol.Option, error) { options := []protocol.Option{ protocol.WithCustomLogger(logger), @@ -413,6 +413,7 @@ func buildMessengerOptions( protocol.WithWalletService(walletService), protocol.WithCommunityTokensService(communityTokensService), protocol.WithWakuService(wakuService), + protocol.WithAccountManager(accountManager), } if config.ShhextConfig.DataSyncEnabled {