2018-02-19 17:32:58 +02:00
|
|
|
package e2e
|
2017-10-11 16:20:51 +02:00
|
|
|
|
|
|
|
import (
|
2019-12-27 10:58:25 +01:00
|
|
|
"encoding/json"
|
2018-03-20 14:35:28 -04:00
|
|
|
|
2019-12-27 10:58:25 +01:00
|
|
|
"github.com/stretchr/testify/suite"
|
2018-03-20 14:35:28 -04:00
|
|
|
|
2020-01-02 10:10:19 +01:00
|
|
|
"github.com/ethereum/go-ethereum/log"
|
|
|
|
|
2018-06-08 13:29:50 +02:00
|
|
|
"github.com/status-im/status-go/api"
|
2019-12-27 10:58:25 +01:00
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
2019-08-29 11:06:22 +03:00
|
|
|
"github.com/status-im/status-go/multiaccounts"
|
|
|
|
"github.com/status-im/status-go/multiaccounts/accounts"
|
2018-06-08 13:29:50 +02:00
|
|
|
"github.com/status-im/status-go/node"
|
2018-05-03 09:35:58 +02:00
|
|
|
"github.com/status-im/status-go/signal"
|
2019-10-04 17:21:24 +02:00
|
|
|
"github.com/status-im/status-go/t/utils"
|
2018-06-08 13:29:50 +02:00
|
|
|
"github.com/status-im/status-go/transactions"
|
2019-12-27 10:58:25 +01:00
|
|
|
"github.com/status-im/status-go/whisper/v6"
|
2017-10-11 16:20:51 +02:00
|
|
|
)
|
|
|
|
|
2018-04-05 11:45:26 +02:00
|
|
|
// StatusNodeTestSuite defines a test suite with StatusNode.
|
|
|
|
type StatusNodeTestSuite struct {
|
2017-10-11 16:20:51 +02:00
|
|
|
suite.Suite
|
2018-04-05 11:45:26 +02:00
|
|
|
StatusNode *node.StatusNode
|
2017-10-16 23:36:36 +01:00
|
|
|
}
|
|
|
|
|
2019-12-27 10:58:25 +01:00
|
|
|
var (
|
|
|
|
// All general log messages in this package should be routed through this logger.
|
|
|
|
logger = log.New("package", "status-go/t/e2e")
|
|
|
|
|
|
|
|
// Settings for testing
|
|
|
|
networks = json.RawMessage("{}")
|
|
|
|
settings = accounts.Settings{
|
|
|
|
Address: types.HexToAddress("0xaC540f3745Ff2964AFC1171a5A0DD726d1F6B472"),
|
|
|
|
CurrentNetwork: "mainnet_rpc",
|
|
|
|
DappsAddress: types.HexToAddress("0xa1300f99fDF7346986CbC766903245087394ecd0"),
|
|
|
|
EIP1581Address: types.HexToAddress("0xa1DDDE9235a541d1344550d969715CF43982de9f"),
|
|
|
|
InstallationID: "d3efcff6-cffa-560e-a547-21d3858cbc51",
|
|
|
|
KeyUID: "0x4e8129f3edfc004875be17bf468a784098a9f69b53c095be1f52deff286935ab",
|
|
|
|
LatestDerivedPath: 0,
|
|
|
|
Name: "Jittery Cornflowerblue Kingbird",
|
|
|
|
Networks: &networks,
|
|
|
|
PhotoPath: "",
|
|
|
|
PreviewPrivacy: false,
|
|
|
|
PublicKey: "0x04211fe0f69772ecf7eb0b5bfc7678672508a9fb01f2d699096f0d59ef7fe1a0cb1e648a80190db1c0f5f088872444d846f2956d0bd84069f3f9f69335af852ac0",
|
|
|
|
SigningPhrase: "yurt joey vibe",
|
|
|
|
WalletRootAddress: types.HexToAddress("0xaB591fd819F86D0A6a2EF2Bcb94f77807a7De1a6")}
|
|
|
|
)
|
2018-03-20 14:35:28 -04:00
|
|
|
|
2019-10-04 17:21:24 +02:00
|
|
|
func Init() {
|
|
|
|
utils.Init()
|
|
|
|
for id := range utils.TestNetworkNames {
|
|
|
|
nodeConfig, err := utils.MakeTestNodeConfig(id)
|
2017-11-07 20:46:11 +03:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2018-02-18 17:14:27 +01:00
|
|
|
err = importTestAccounts(nodeConfig.KeyStoreDir)
|
2017-11-07 20:46:11 +03:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-05 11:45:26 +02:00
|
|
|
// StartTestNode initiazes a StatusNode instances with configuration retrieved
|
2017-10-11 16:20:51 +02:00
|
|
|
// from the test config.
|
2018-04-05 11:45:26 +02:00
|
|
|
func (s *StatusNodeTestSuite) StartTestNode(opts ...TestNodeOption) {
|
2019-10-04 17:21:24 +02:00
|
|
|
nodeConfig, err := utils.MakeTestNodeConfig(utils.GetNetworkID())
|
2017-10-11 16:20:51 +02:00
|
|
|
s.NoError(err)
|
|
|
|
|
|
|
|
// Apply any options altering node config.
|
|
|
|
for i := range opts {
|
|
|
|
opts[i](nodeConfig)
|
|
|
|
}
|
|
|
|
|
|
|
|
// import account keys
|
2018-02-18 17:14:27 +01:00
|
|
|
s.NoError(importTestAccounts(nodeConfig.KeyStoreDir))
|
2017-10-11 16:20:51 +02:00
|
|
|
|
2018-04-05 11:45:26 +02:00
|
|
|
s.False(s.StatusNode.IsRunning())
|
2019-08-20 18:38:40 +03:00
|
|
|
s.NoError(s.StatusNode.Start(nodeConfig, nil))
|
2018-04-05 11:45:26 +02:00
|
|
|
s.True(s.StatusNode.IsRunning())
|
2017-10-11 16:20:51 +02:00
|
|
|
}
|
|
|
|
|
2018-04-05 11:45:26 +02:00
|
|
|
// StopTestNode attempts to stop initialized StatusNode.
|
|
|
|
func (s *StatusNodeTestSuite) StopTestNode() {
|
|
|
|
s.NotNil(s.StatusNode)
|
|
|
|
s.True(s.StatusNode.IsRunning())
|
|
|
|
s.NoError(s.StatusNode.Stop())
|
|
|
|
s.False(s.StatusNode.IsRunning())
|
2017-10-11 16:20:51 +02:00
|
|
|
}
|
|
|
|
|
2019-11-23 18:57:05 +01:00
|
|
|
// BackendTestSuite is a test suite with api.GethStatusBackend initialized
|
2017-10-11 16:20:51 +02:00
|
|
|
// and a few utility methods to start and stop node or get various services.
|
|
|
|
type BackendTestSuite struct {
|
|
|
|
suite.Suite
|
2019-11-23 18:57:05 +01:00
|
|
|
Backend *api.GethStatusBackend
|
2017-10-11 16:20:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// SetupTest initializes Backend.
|
|
|
|
func (s *BackendTestSuite) SetupTest() {
|
2019-11-23 18:57:05 +01:00
|
|
|
s.Backend = api.NewGethStatusBackend()
|
2017-10-11 16:20:51 +02:00
|
|
|
s.NotNil(s.Backend)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TearDownTest cleans up the packages state.
|
|
|
|
func (s *BackendTestSuite) TearDownTest() {
|
|
|
|
signal.ResetDefaultNodeNotificationHandler()
|
|
|
|
}
|
|
|
|
|
|
|
|
// StartTestBackend imports some keys and starts a node.
|
2017-10-23 17:03:07 +01:00
|
|
|
func (s *BackendTestSuite) StartTestBackend(opts ...TestNodeOption) {
|
2019-10-04 17:21:24 +02:00
|
|
|
nodeConfig, err := utils.MakeTestNodeConfig(utils.GetNetworkID())
|
2018-09-13 18:31:29 +02:00
|
|
|
s.Require().NoError(err)
|
2017-10-11 16:20:51 +02:00
|
|
|
|
|
|
|
// Apply any options altering node config.
|
|
|
|
for i := range opts {
|
|
|
|
opts[i](nodeConfig)
|
|
|
|
}
|
2019-08-20 18:38:40 +03:00
|
|
|
s.NoError(s.Backend.AccountManager().InitKeystore(nodeConfig.KeyStoreDir))
|
2017-10-11 16:20:51 +02:00
|
|
|
// import account keys
|
2018-02-18 17:14:27 +01:00
|
|
|
s.NoError(importTestAccounts(nodeConfig.KeyStoreDir))
|
2017-10-11 16:20:51 +02:00
|
|
|
|
|
|
|
// start node
|
|
|
|
s.False(s.Backend.IsNodeRunning())
|
2018-09-13 18:31:29 +02:00
|
|
|
s.Require().NoError(s.Backend.StartNode(nodeConfig))
|
2017-10-11 16:20:51 +02:00
|
|
|
s.True(s.Backend.IsNodeRunning())
|
|
|
|
}
|
|
|
|
|
2019-08-29 11:06:22 +03:00
|
|
|
func (s *BackendTestSuite) StartTestBackendWithAccount(account multiaccounts.Account, password string, subaccs []accounts.Account, opts ...TestNodeOption) {
|
2019-10-04 17:21:24 +02:00
|
|
|
nodeConfig, err := utils.MakeTestNodeConfig(utils.GetNetworkID())
|
2019-08-29 11:06:22 +03:00
|
|
|
s.Require().NoError(err)
|
|
|
|
|
|
|
|
// Apply any options altering node config.
|
|
|
|
for i := range opts {
|
|
|
|
opts[i](nodeConfig)
|
|
|
|
}
|
2020-02-03 11:20:04 +02:00
|
|
|
|
|
|
|
keystoreDir := nodeConfig.KeyStoreDir
|
|
|
|
dataDir := nodeConfig.DataDir
|
|
|
|
nodeConfig.KeyStoreDir = "keystore"
|
|
|
|
nodeConfig.DataDir = "/"
|
2019-08-29 11:06:22 +03:00
|
|
|
// accounts must be imported before keystore is initialized
|
2020-02-03 11:20:04 +02:00
|
|
|
s.NoError(importTestAccounts(keystoreDir))
|
|
|
|
s.Backend.UpdateRootDataDir(dataDir)
|
2019-08-29 11:06:22 +03:00
|
|
|
s.NoError(s.Backend.OpenAccounts())
|
2020-02-03 11:20:04 +02:00
|
|
|
s.NoError(s.Backend.AccountManager().InitKeystore(keystoreDir))
|
2019-08-29 11:06:22 +03:00
|
|
|
|
2019-12-27 10:58:25 +01:00
|
|
|
s.Require().NoError(s.Backend.StartNodeWithAccountAndConfig(account, password, settings, nodeConfig, subaccs))
|
2019-08-29 11:06:22 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *BackendTestSuite) LogoutAndStop() {
|
|
|
|
s.NoError(s.Backend.Logout())
|
|
|
|
s.StopTestBackend()
|
|
|
|
}
|
|
|
|
|
2017-10-11 16:20:51 +02:00
|
|
|
// StopTestBackend stops the node.
|
|
|
|
func (s *BackendTestSuite) StopTestBackend() {
|
|
|
|
s.True(s.Backend.IsNodeRunning())
|
2018-02-09 15:37:56 +02:00
|
|
|
s.NoError(s.Backend.StopNode())
|
2017-10-11 16:20:51 +02:00
|
|
|
s.False(s.Backend.IsNodeRunning())
|
|
|
|
}
|
|
|
|
|
|
|
|
// RestartTestNode restarts a currently running node.
|
|
|
|
func (s *BackendTestSuite) RestartTestNode() {
|
|
|
|
s.True(s.Backend.IsNodeRunning())
|
2018-09-13 18:31:29 +02:00
|
|
|
s.Require().NoError(s.Backend.RestartNode())
|
2017-10-11 16:20:51 +02:00
|
|
|
s.True(s.Backend.IsNodeRunning())
|
|
|
|
}
|
|
|
|
|
|
|
|
// WhisperService returns a reference to the Whisper service.
|
|
|
|
func (s *BackendTestSuite) WhisperService() *whisper.Whisper {
|
2018-04-05 11:45:26 +02:00
|
|
|
whisperService, err := s.Backend.StatusNode().WhisperService()
|
2017-10-11 16:20:51 +02:00
|
|
|
s.NoError(err)
|
|
|
|
s.NotNil(whisperService)
|
|
|
|
|
|
|
|
return whisperService
|
|
|
|
}
|
|
|
|
|
2018-04-09 10:18:22 +02:00
|
|
|
// Transactor returns a reference to the Transactor.
|
|
|
|
func (s *BackendTestSuite) Transactor() *transactions.Transactor {
|
|
|
|
return s.Backend.Transactor()
|
|
|
|
}
|
|
|
|
|
2018-02-18 17:14:27 +01:00
|
|
|
func importTestAccounts(keyStoreDir string) (err error) {
|
2018-03-20 14:35:28 -04:00
|
|
|
logger.Debug("Import accounts to", "dir", keyStoreDir)
|
2017-11-07 20:46:11 +03:00
|
|
|
|
2019-10-04 17:21:24 +02:00
|
|
|
err = utils.ImportTestAccount(keyStoreDir, utils.GetAccount1PKFile())
|
2017-10-11 16:20:51 +02:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2019-10-04 17:21:24 +02:00
|
|
|
return utils.ImportTestAccount(keyStoreDir, utils.GetAccount2PKFile())
|
2017-10-11 16:20:51 +02:00
|
|
|
}
|