2017-05-25 14:23:01 +03:00
|
|
|
package api_test
|
|
|
|
|
|
|
|
import (
|
2017-05-27 23:26:07 +03:00
|
|
|
"io/ioutil"
|
2017-05-25 16:14:52 +03:00
|
|
|
"math/rand"
|
2017-05-27 23:26:07 +03:00
|
|
|
"os"
|
|
|
|
"strconv"
|
2017-05-25 14:23:01 +03:00
|
|
|
"testing"
|
2017-05-25 15:34:13 +03:00
|
|
|
"time"
|
2017-05-25 14:23:01 +03:00
|
|
|
|
2017-10-11 16:20:51 +02:00
|
|
|
"github.com/status-im/status-go/e2e"
|
2017-05-25 14:23:01 +03:00
|
|
|
"github.com/status-im/status-go/geth/api"
|
2017-08-10 15:35:58 +02:00
|
|
|
"github.com/status-im/status-go/geth/log"
|
2017-05-25 14:23:01 +03:00
|
|
|
"github.com/status-im/status-go/geth/params"
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAPI(t *testing.T) {
|
|
|
|
suite.Run(t, new(APITestSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type APITestSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
api *api.StatusAPI
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *APITestSuite) SetupTest() {
|
2017-10-11 16:20:51 +02:00
|
|
|
s.api = api.NewStatusAPI()
|
|
|
|
s.NotNil(s.api)
|
2017-05-25 14:23:01 +03:00
|
|
|
}
|
2017-05-27 23:26:07 +03:00
|
|
|
|
|
|
|
func (s *APITestSuite) TestCHTUpdate() {
|
|
|
|
tmpDir, err := ioutil.TempDir(os.TempDir(), "cht-updates")
|
2017-10-11 16:20:51 +02:00
|
|
|
s.NoError(err)
|
2017-05-27 23:26:07 +03:00
|
|
|
defer os.RemoveAll(tmpDir)
|
|
|
|
|
|
|
|
configJSON := `{
|
|
|
|
"NetworkId": ` + strconv.Itoa(params.RopstenNetworkID) + `,
|
|
|
|
"DataDir": "` + tmpDir + `",
|
|
|
|
"LogLevel": "INFO",
|
2017-08-25 11:56:54 +02:00
|
|
|
"RPCEnabled": true
|
2017-05-27 23:26:07 +03:00
|
|
|
}`
|
2017-08-04 23:14:17 +07:00
|
|
|
//nodeConfig, err := params.LoadNodeConfig(configJSON)
|
|
|
|
_, err = params.LoadNodeConfig(configJSON)
|
2017-10-11 16:20:51 +02:00
|
|
|
s.NoError(err)
|
2017-05-27 23:26:07 +03:00
|
|
|
|
|
|
|
// start node
|
2017-08-04 23:14:17 +07:00
|
|
|
//nodeConfig.DevMode = true
|
|
|
|
//s.api.StartNode(nodeConfig)
|
|
|
|
//s.api.StopNode()
|
|
|
|
// TODO(tiabc): Test that CHT is really updated.
|
2017-05-27 23:26:07 +03:00
|
|
|
}
|
|
|
|
|
2017-05-25 16:14:52 +03:00
|
|
|
func (s *APITestSuite) TestRaceConditions() {
|
|
|
|
cnt := 25
|
|
|
|
progress := make(chan struct{}, cnt)
|
|
|
|
rnd := rand.New(rand.NewSource(time.Now().UnixNano()))
|
|
|
|
|
2017-10-11 16:20:51 +02:00
|
|
|
nodeConfig1, err := e2e.MakeTestNodeConfig(params.RopstenNetworkID)
|
|
|
|
s.NoError(err)
|
2017-05-25 14:23:01 +03:00
|
|
|
|
2017-10-11 16:20:51 +02:00
|
|
|
nodeConfig2, err := e2e.MakeTestNodeConfig(params.RinkebyNetworkID)
|
|
|
|
s.NoError(err)
|
2017-05-25 14:23:01 +03:00
|
|
|
|
2017-05-25 16:14:52 +03:00
|
|
|
nodeConfigs := []*params.NodeConfig{nodeConfig1, nodeConfig2}
|
2017-05-25 14:23:01 +03:00
|
|
|
|
2017-05-25 16:14:52 +03:00
|
|
|
var funcsToTest = []func(*params.NodeConfig){
|
|
|
|
func(config *params.NodeConfig) {
|
|
|
|
log.Info("StartNodeAsync()")
|
|
|
|
_, err := s.api.StartNodeAsync(config)
|
|
|
|
s.T().Logf("StartNodeAsync() for network: %d, error: %v", config.NetworkID, err)
|
|
|
|
progress <- struct{}{}
|
|
|
|
},
|
|
|
|
func(config *params.NodeConfig) {
|
|
|
|
log.Info("StopNodeAsync()")
|
|
|
|
_, err := s.api.StopNodeAsync()
|
|
|
|
s.T().Logf("StopNodeAsync(), error: %v", err)
|
|
|
|
progress <- struct{}{}
|
|
|
|
},
|
|
|
|
func(config *params.NodeConfig) {
|
|
|
|
log.Info("RestartNodeAsync()")
|
|
|
|
_, err := s.api.RestartNodeAsync()
|
|
|
|
s.T().Logf("RestartNodeAsync(), error: %v", err)
|
|
|
|
progress <- struct{}{}
|
|
|
|
},
|
2017-10-11 16:20:51 +02:00
|
|
|
// TODO(adam): quarantined until it uses a different datadir
|
|
|
|
// as otherwise it wipes out cached blockchain data.
|
|
|
|
// func(config *params.NodeConfig) {
|
|
|
|
// log.Info("ResetChainDataAsync()")
|
|
|
|
// _, err := s.api.ResetChainDataAsync()
|
|
|
|
// s.T().Logf("ResetChainDataAsync(), error: %v", err)
|
|
|
|
// progress <- struct{}{}
|
|
|
|
// },
|
2017-05-25 14:23:01 +03:00
|
|
|
}
|
2017-05-25 16:14:52 +03:00
|
|
|
|
|
|
|
// increase StartNode()/StopNode() population
|
|
|
|
for i := 0; i < 5; i++ {
|
|
|
|
funcsToTest = append(funcsToTest, funcsToTest[0], funcsToTest[1])
|
2017-05-25 14:23:01 +03:00
|
|
|
}
|
|
|
|
|
2017-05-25 16:14:52 +03:00
|
|
|
for i := 0; i < cnt; i++ {
|
|
|
|
randConfig := nodeConfigs[rnd.Intn(len(nodeConfigs))]
|
|
|
|
randFunc := funcsToTest[rnd.Intn(len(funcsToTest))]
|
2017-05-25 15:34:13 +03:00
|
|
|
|
2017-05-25 16:14:52 +03:00
|
|
|
if rnd.Intn(100) > 75 { // introduce random delays
|
|
|
|
time.Sleep(500 * time.Millisecond)
|
|
|
|
}
|
|
|
|
go randFunc(randConfig)
|
2017-05-25 14:23:01 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
for range progress {
|
2017-05-25 16:14:52 +03:00
|
|
|
cnt -= 1
|
|
|
|
if cnt <= 0 {
|
2017-05-25 14:23:01 +03:00
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
2017-05-25 16:14:52 +03:00
|
|
|
|
|
|
|
time.Sleep(2 * time.Second) // so that we see some logs
|
|
|
|
s.api.StopNode() // just in case we have a node running
|
2017-05-25 14:23:01 +03:00
|
|
|
}
|