2022-10-05 06:44:10 +00:00
|
|
|
package server_test
|
2022-01-31 13:20:14 +00:00
|
|
|
|
|
|
|
import (
|
2022-09-02 11:29:47 +00:00
|
|
|
"errors"
|
2022-01-31 13:20:14 +00:00
|
|
|
"io"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
2022-02-08 14:03:17 +00:00
|
|
|
"runtime"
|
2022-01-31 13:20:14 +00:00
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/nspcc-dev/neo-go/cli/server"
|
2022-10-05 06:44:10 +00:00
|
|
|
"github.com/nspcc-dev/neo-go/internal/testcli"
|
2022-01-31 13:20:14 +00:00
|
|
|
"github.com/nspcc-dev/neo-go/pkg/config"
|
|
|
|
"github.com/stretchr/testify/require"
|
2021-09-25 10:09:55 +00:00
|
|
|
"gopkg.in/yaml.v3"
|
2022-01-31 13:20:14 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestServerStart(t *testing.T) {
|
|
|
|
tmpDir := t.TempDir()
|
2022-10-05 06:44:10 +00:00
|
|
|
goodCfg, err := config.LoadFile(filepath.Join("..", "..", "config", "protocol.unit_testnet.yml"))
|
2022-01-31 13:20:14 +00:00
|
|
|
require.NoError(t, err, "could not load config")
|
|
|
|
ptr := &goodCfg
|
|
|
|
saveCfg := func(t *testing.T, f func(cfg *config.Config)) string {
|
|
|
|
cfg := *ptr
|
|
|
|
chainPath := filepath.Join(t.TempDir(), "neogotestchain")
|
|
|
|
cfg.ApplicationConfiguration.DBConfiguration.Type = "leveldb"
|
|
|
|
cfg.ApplicationConfiguration.DBConfiguration.LevelDBOptions.DataDirectoryPath = chainPath
|
|
|
|
f(&cfg)
|
|
|
|
out, err := yaml.Marshal(cfg)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
cfgPath := filepath.Join(tmpDir, "protocol.unit_testnet.yml")
|
2022-02-22 16:27:32 +00:00
|
|
|
require.NoError(t, os.WriteFile(cfgPath, out, os.ModePerm))
|
2022-01-31 13:20:14 +00:00
|
|
|
t.Cleanup(func() {
|
|
|
|
require.NoError(t, os.Remove(cfgPath))
|
|
|
|
})
|
|
|
|
return cfgPath
|
|
|
|
}
|
|
|
|
|
|
|
|
baseCmd := []string{"neo-go", "node", "--unittest", "--config-path", tmpDir}
|
2022-10-05 06:44:10 +00:00
|
|
|
e := testcli.NewExecutor(t, false)
|
2022-01-31 13:20:14 +00:00
|
|
|
|
|
|
|
t.Run("invalid config path", func(t *testing.T) {
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
t.Run("bad logger config", func(t *testing.T) {
|
|
|
|
badConfigDir := t.TempDir()
|
|
|
|
logfile := filepath.Join(badConfigDir, "logdir")
|
2022-02-22 16:27:32 +00:00
|
|
|
require.NoError(t, os.WriteFile(logfile, []byte{1, 2, 3}, os.ModePerm))
|
2022-01-31 13:20:14 +00:00
|
|
|
saveCfg(t, func(cfg *config.Config) {
|
|
|
|
cfg.ApplicationConfiguration.LogPath = filepath.Join(logfile, "file.log")
|
|
|
|
})
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
t.Run("invalid storage", func(t *testing.T) {
|
|
|
|
saveCfg(t, func(cfg *config.Config) {
|
|
|
|
cfg.ApplicationConfiguration.DBConfiguration.Type = ""
|
|
|
|
})
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
t.Run("stateroot service is on && StateRootInHeader=true", func(t *testing.T) {
|
|
|
|
saveCfg(t, func(cfg *config.Config) {
|
|
|
|
cfg.ApplicationConfiguration.StateRoot.Enabled = true
|
|
|
|
cfg.ProtocolConfiguration.StateRootInHeader = true
|
|
|
|
})
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
t.Run("invalid Oracle config", func(t *testing.T) {
|
|
|
|
saveCfg(t, func(cfg *config.Config) {
|
|
|
|
cfg.ApplicationConfiguration.Oracle.Enabled = true
|
|
|
|
cfg.ApplicationConfiguration.Oracle.UnlockWallet.Path = "bad_orc_wallet.json"
|
|
|
|
})
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
t.Run("invalid consensus config", func(t *testing.T) {
|
|
|
|
saveCfg(t, func(cfg *config.Config) {
|
|
|
|
cfg.ApplicationConfiguration.UnlockWallet.Path = "bad_consensus_wallet.json"
|
|
|
|
})
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
t.Run("invalid Notary config", func(t *testing.T) {
|
|
|
|
t.Run("malformed config", func(t *testing.T) {
|
|
|
|
saveCfg(t, func(cfg *config.Config) {
|
|
|
|
cfg.ProtocolConfiguration.P2PSigExtensions = false
|
|
|
|
cfg.ApplicationConfiguration.P2PNotary.Enabled = true
|
|
|
|
})
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
t.Run("invalid wallet", func(t *testing.T) {
|
|
|
|
saveCfg(t, func(cfg *config.Config) {
|
|
|
|
cfg.ProtocolConfiguration.P2PSigExtensions = true
|
|
|
|
cfg.ApplicationConfiguration.P2PNotary.Enabled = true
|
|
|
|
cfg.ApplicationConfiguration.P2PNotary.UnlockWallet.Path = "bad_notary_wallet.json"
|
|
|
|
})
|
|
|
|
e.RunWithError(t, baseCmd...)
|
|
|
|
})
|
|
|
|
})
|
2022-02-08 14:03:17 +00:00
|
|
|
// We can't properly shutdown server on windows and release the resources.
|
|
|
|
// Also, windows doesn't support SIGHUP and SIGINT.
|
|
|
|
if runtime.GOOS != "windows" {
|
2022-08-05 10:32:37 +00:00
|
|
|
saveCfg(t, func(cfg *config.Config) {})
|
|
|
|
t.Run("excessive parameters", func(t *testing.T) {
|
|
|
|
e.RunWithError(t, append(baseCmd, "something")...)
|
|
|
|
})
|
2022-02-08 14:03:17 +00:00
|
|
|
t.Run("good", func(t *testing.T) {
|
|
|
|
go func() {
|
|
|
|
e.Run(t, baseCmd...)
|
|
|
|
}()
|
2022-01-31 13:20:14 +00:00
|
|
|
|
2022-02-08 14:03:17 +00:00
|
|
|
var line string
|
|
|
|
require.Eventually(t, func() bool {
|
|
|
|
line, err = e.Out.ReadString('\n')
|
2022-09-02 11:29:47 +00:00
|
|
|
if err != nil && !errors.Is(err, io.EOF) {
|
2022-02-08 14:03:17 +00:00
|
|
|
t.Fatalf("unexpected error while reading CLI output: %s", err)
|
|
|
|
}
|
|
|
|
return err == nil
|
|
|
|
}, 2*time.Second, 100*time.Millisecond)
|
|
|
|
lines := strings.Split(server.Logo(), "\n")
|
|
|
|
for _, expected := range lines {
|
|
|
|
// It should be regexp, so escape all backslashes.
|
|
|
|
expected = strings.ReplaceAll(expected, `\`, `\\`)
|
2022-10-05 06:44:10 +00:00
|
|
|
e.CheckLine(t, line, expected)
|
|
|
|
line = e.GetNextLine(t)
|
2022-01-31 13:20:14 +00:00
|
|
|
}
|
2022-10-05 06:44:10 +00:00
|
|
|
e.CheckNextLine(t, "")
|
|
|
|
e.CheckEOF(t)
|
2022-02-08 14:03:17 +00:00
|
|
|
})
|
|
|
|
}
|
2022-01-31 13:20:14 +00:00
|
|
|
}
|