Update readme and update code for testing
This commit is contained in:
parent
a257d1c201
commit
a1668add06
|
@ -15,18 +15,18 @@ for running all test. It by default uses the `StatusChain` network.
|
||||||
|
|
||||||
#### Usage
|
#### Usage
|
||||||
|
|
||||||
To use the `mainnet` network for testing using network name:
|
To use the `ropsten` network for testing using network name:
|
||||||
|
|
||||||
```bash
|
|
||||||
go test -v ./e2e/... -network=mainnet
|
|
||||||
```
|
|
||||||
|
|
||||||
To use the `ropsten` network for testing using network id:
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
go test -v ./e2e/... -network=3
|
go test -v ./e2e/... -network=3
|
||||||
```
|
```
|
||||||
|
|
||||||
|
To use the `rinkeby` network for testing using network id:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
go test -v ./e2e/... -network=4
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
## Run
|
## Run
|
||||||
|
|
||||||
|
|
|
@ -56,10 +56,10 @@ func (s *APITestSuite) TestRaceConditions() {
|
||||||
progress := make(chan struct{}, cnt)
|
progress := make(chan struct{}, cnt)
|
||||||
rnd := rand.New(rand.NewSource(time.Now().UnixNano()))
|
rnd := rand.New(rand.NewSource(time.Now().UnixNano()))
|
||||||
|
|
||||||
nodeConfig1, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig1, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(err)
|
s.NoError(err)
|
||||||
|
|
||||||
nodeConfig2, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig2, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(err)
|
s.NoError(err)
|
||||||
|
|
||||||
nodeConfigs := []*params.NodeConfig{nodeConfig1, nodeConfig2}
|
nodeConfigs := []*params.NodeConfig{nodeConfig1, nodeConfig2}
|
||||||
|
@ -129,7 +129,7 @@ func (s *APITestSuite) TestCellsRemovedAfterSwitchAccount() {
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
config, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
config, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
err = s.api.StartNode(config)
|
err = s.api.StartNode(config)
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
|
@ -166,7 +166,7 @@ func (s *APITestSuite) TestLogoutRemovesCells() {
|
||||||
require = s.Require()
|
require = s.Require()
|
||||||
)
|
)
|
||||||
|
|
||||||
config, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
config, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
err = s.api.StartNode(config)
|
err = s.api.StartNode(config)
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
|
|
|
@ -34,10 +34,10 @@ func (s *APIBackendTestSuite) TestRaceConditions() {
|
||||||
progress := make(chan struct{}, cnt)
|
progress := make(chan struct{}, cnt)
|
||||||
rnd := rand.New(rand.NewSource(time.Now().UnixNano()))
|
rnd := rand.New(rand.NewSource(time.Now().UnixNano()))
|
||||||
|
|
||||||
nodeConfig1, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig1, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
|
|
||||||
nodeConfig2, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig2, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
require.NoError(err)
|
require.NoError(err)
|
||||||
|
|
||||||
nodeConfigs := []*params.NodeConfig{nodeConfig1, nodeConfig2}
|
nodeConfigs := []*params.NodeConfig{nodeConfig1, nodeConfig2}
|
||||||
|
|
|
@ -11,6 +11,7 @@ import (
|
||||||
"github.com/status-im/status-go/geth/jail"
|
"github.com/status-im/status-go/geth/jail"
|
||||||
"github.com/status-im/status-go/geth/signal"
|
"github.com/status-im/status-go/geth/signal"
|
||||||
"github.com/status-im/status-go/static"
|
"github.com/status-im/status-go/static"
|
||||||
|
. "github.com/status-im/status-go/testing" //nolint: golint
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -194,7 +194,7 @@ func (s *ManagerTestSuite) TestReferencesWithStartedNode() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *ManagerTestSuite) TestNodeStartStop() {
|
func (s *ManagerTestSuite) TestNodeStartStop() {
|
||||||
nodeConfig, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(err)
|
s.NoError(err)
|
||||||
|
|
||||||
// try stopping non-started node
|
// try stopping non-started node
|
||||||
|
@ -274,7 +274,7 @@ func (s *ManagerTestSuite) TestNetworkSwitching() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *ManagerTestSuite) TestStartNodeWithUpstreamEnabled() {
|
func (s *ManagerTestSuite) TestStartNodeWithUpstreamEnabled() {
|
||||||
nodeConfig, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(err)
|
s.NoError(err)
|
||||||
|
|
||||||
nodeConfig.UpstreamConfig.Enabled = true
|
nodeConfig.UpstreamConfig.Enabled = true
|
||||||
|
@ -335,10 +335,10 @@ func (s *ManagerTestSuite) TestRaceConditions() {
|
||||||
progress := make(chan struct{}, cnt)
|
progress := make(chan struct{}, cnt)
|
||||||
rnd := rand.New(rand.NewSource(time.Now().UnixNano()))
|
rnd := rand.New(rand.NewSource(time.Now().UnixNano()))
|
||||||
|
|
||||||
nodeConfig1, e := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig1, e := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(e)
|
s.NoError(e)
|
||||||
|
|
||||||
nodeConfig2, e := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig2, e := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(e)
|
s.NoError(e)
|
||||||
|
|
||||||
nodeConfigs := []*params.NodeConfig{nodeConfig1, nodeConfig2}
|
nodeConfigs := []*params.NodeConfig{nodeConfig1, nodeConfig2}
|
||||||
|
@ -466,7 +466,7 @@ func (s *ManagerTestSuite) TestNodeStartCrash() {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
nodeConfig, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(err)
|
s.NoError(err)
|
||||||
|
|
||||||
// start node outside the manager (on the same port), so that manager node.Start() method fails
|
// start node outside the manager (on the same port), so that manager node.Start() method fails
|
||||||
|
|
|
@ -6,6 +6,7 @@ import (
|
||||||
"github.com/status-im/status-go/e2e"
|
"github.com/status-im/status-go/e2e"
|
||||||
"github.com/status-im/status-go/geth/node"
|
"github.com/status-im/status-go/geth/node"
|
||||||
"github.com/status-im/status-go/geth/rpc"
|
"github.com/status-im/status-go/geth/rpc"
|
||||||
|
. "github.com/status-im/status-go/testing" //nolint: golint
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -23,7 +24,7 @@ func (s *RPCClientTestSuite) SetupTest() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *RPCClientTestSuite) TestNewClient() {
|
func (s *RPCClientTestSuite) TestNewClient() {
|
||||||
config, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
config, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(err)
|
s.NoError(err)
|
||||||
|
|
||||||
nodeStarted, err := s.NodeManager.StartNode(config)
|
nodeStarted, err := s.NodeManager.StartNode(config)
|
||||||
|
|
|
@ -122,7 +122,7 @@ func (s *RPCTestSuite) TestCallRPC() {
|
||||||
|
|
||||||
// TestCallRawResult checks if returned response is a valid JSON-RPC response.
|
// TestCallRawResult checks if returned response is a valid JSON-RPC response.
|
||||||
func (s *RPCTestSuite) TestCallRawResult() {
|
func (s *RPCTestSuite) TestCallRawResult() {
|
||||||
nodeConfig, err := e2e.MakeTestNodeConfig(e2e.GetNetworkID())
|
nodeConfig, err := e2e.MakeTestNodeConfig(GetNetworkID())
|
||||||
s.NoError(err)
|
s.NoError(err)
|
||||||
|
|
||||||
nodeStarted, err := s.NodeManager.StartNode(nodeConfig)
|
nodeStarted, err := s.NodeManager.StartNode(nodeConfig)
|
||||||
|
|
|
@ -2,12 +2,9 @@ package e2e
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"flag"
|
|
||||||
"fmt"
|
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"runtime"
|
"runtime"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
gethcommon "github.com/ethereum/go-ethereum/common"
|
gethcommon "github.com/ethereum/go-ethereum/common"
|
||||||
|
@ -16,10 +13,6 @@ import (
|
||||||
. "github.com/status-im/status-go/testing" //nolint: golint
|
. "github.com/status-im/status-go/testing" //nolint: golint
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
|
||||||
networkSelected = flag.String("network", "statuschain", "-network=NETWORKNAME or -network=NETWORKID to select network used for tests")
|
|
||||||
)
|
|
||||||
|
|
||||||
// TestNodeOption is a callback passed to StartTestNode which alters its config.
|
// TestNodeOption is a callback passed to StartTestNode which alters its config.
|
||||||
type TestNodeOption func(config *params.NodeConfig)
|
type TestNodeOption func(config *params.NodeConfig)
|
||||||
|
|
||||||
|
@ -87,20 +80,3 @@ func FirstBlockHash(nodeManager common.NodeManager) (string, error) {
|
||||||
|
|
||||||
return firstBlock.Hash.Hex(), nil
|
return firstBlock.Hash.Hex(), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetNetworkID returns appropriate network id for test based on
|
|
||||||
// default or provided -network flag.
|
|
||||||
func GetNetworkID() int {
|
|
||||||
switch strings.ToLower(*networkSelected) {
|
|
||||||
case fmt.Sprintf("%d", params.MainNetworkID), "mainnet":
|
|
||||||
return params.MainNetworkID
|
|
||||||
case fmt.Sprintf("%d", params.RinkebyNetworkID), "rinkeby":
|
|
||||||
return params.RinkebyNetworkID
|
|
||||||
case fmt.Sprintf("%d", params.RopstenNetworkID), "ropsten":
|
|
||||||
return params.RopstenNetworkID
|
|
||||||
case fmt.Sprintf("%d", params.StatusChainNetworkID), "statuschain":
|
|
||||||
return params.StatusChainNetworkID
|
|
||||||
}
|
|
||||||
|
|
||||||
return params.StatusChainNetworkID
|
|
||||||
}
|
|
||||||
|
|
|
@ -3,6 +3,7 @@ package integration
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"errors"
|
"errors"
|
||||||
|
"flag"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
@ -14,6 +15,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
networkSelected = flag.Int("network", "statuschain", "-network=NETWORKID to select network used for tests")
|
||||||
|
|
||||||
// TestConfig defines the default config usable at package-level.
|
// TestConfig defines the default config usable at package-level.
|
||||||
TestConfig *common.TestConfig
|
TestConfig *common.TestConfig
|
||||||
|
|
||||||
|
@ -112,3 +115,20 @@ func EnsureNodeSync(nodeManager common.NodeManager) error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetNetworkID returns appropriate network id for test based on
|
||||||
|
// default or provided -network flag.
|
||||||
|
func GetNetworkID() int {
|
||||||
|
switch strings.ToLower(*networkSelected) {
|
||||||
|
case params.MainNetworkID:
|
||||||
|
return params.MainNetworkID
|
||||||
|
case params.RinkebyNetworkID:
|
||||||
|
return params.RinkebyNetworkID
|
||||||
|
case params.RopstenNetworkID:
|
||||||
|
return params.RopstenNetworkID
|
||||||
|
case params.StatusChainNetworkID:
|
||||||
|
return params.StatusChainNetworkID
|
||||||
|
}
|
||||||
|
|
||||||
|
return params.StatusChainNetworkID
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue