cosmos-sdk/server/start_test.go

66 lines
1.6 KiB
Go
Raw Normal View History

package server
import (
2018-04-03 11:19:41 -07:00
"io/ioutil"
"os"
"testing"
2018-02-21 08:38:16 -08:00
"time"
2018-02-21 07:41:56 -08:00
"github.com/spf13/viper"
"github.com/stretchr/testify/require"
"github.com/cosmos/cosmos-sdk/mock"
2018-04-03 11:19:41 -07:00
"github.com/tendermint/abci/server"
tcmd "github.com/tendermint/tendermint/cmd/tendermint/commands"
2018-02-21 07:41:56 -08:00
"github.com/tendermint/tmlibs/log"
)
2018-02-21 08:38:16 -08:00
func TestStartStandAlone(t *testing.T) {
2018-04-03 11:19:41 -07:00
home, err := ioutil.TempDir("", "mock-sdk-cmd")
defer func() {
os.RemoveAll(home)
}()
2018-02-21 08:38:16 -08:00
logger := log.NewNopLogger()
cfg, err := tcmd.ParseConfig()
require.Nil(t, err)
ctx := NewContext(cfg, logger)
initCmd := InitCmd(mock.GenInitOptions, ctx)
2018-04-03 11:19:41 -07:00
err = initCmd.RunE(nil, nil)
2018-02-21 08:38:16 -08:00
require.NoError(t, err)
2018-04-03 11:19:41 -07:00
app, err := mock.NewApp(home, logger)
require.Nil(t, err)
svr, err := server.NewServer(FreeTCPAddr(t), "socket", app)
require.Nil(t, err, "Error creating listener")
svr.SetLogger(logger.With("module", "abci-server"))
svr.Start()
timer := time.NewTimer(time.Duration(5) * time.Second)
select {
case <-timer.C:
svr.Stop()
}
2018-02-21 08:38:16 -08:00
}
func TestStartWithTendermint(t *testing.T) {
defer setupViper(t)()
2018-02-21 07:41:56 -08:00
logger := log.NewTMLogger(log.NewSyncWriter(os.Stdout)).
With("module", "mock-cmd")
2018-04-05 02:21:42 -07:00
cfg, err := tcmd.ParseConfig()
require.Nil(t, err)
ctx := NewContext(cfg, logger)
initCmd := InitCmd(mock.GenInitOptions, ctx)
err = initCmd.RunE(nil, nil)
2018-02-21 07:41:56 -08:00
require.NoError(t, err)
2018-02-21 08:38:16 -08:00
// set up app and start up
viper.Set(flagWithTendermint, true)
2018-04-05 02:21:42 -07:00
startCmd := StartCmd(mock.NewApp, ctx)
2018-03-12 08:31:27 -07:00
startCmd.Flags().Set(flagAddress, FreeTCPAddr(t)) // set to a new free address
2018-04-03 11:19:41 -07:00
timeout := time.Duration(5) * time.Second
2018-02-21 08:38:16 -08:00
close(RunOrTimeout(startCmd, timeout, t))
}