erigon-pulse/cmd/devnet/args/node_args_test.go
milen b94ca6dc1c
devnet: fix ws port clash for state-sync scenario (#9125)
Getting an error in one of the bor nodes in devnet when trying to run
the "state-sync" scenario:
```
[EROR] [01-03|16:55:44.179] cli.StartRpcServer error                 err="could not start separate Websocket RPC api at port 8546: listen tcp 127.0.0.1:8546: bind: address already in use"
```

This happens for scenarios with more than 1 node.

Digging further this regressions has happened due to this change:
https://github.com/ledgerwatch/erigon/pull/8909

This PR fixes this by updating the devnet `NodeArgs` struct to set the
corresponding `--ws.port` `arg` tag which now exists.
2024-01-03 18:58:52 +00:00

228 lines
6.9 KiB
Go

package args_test
import (
"errors"
"fmt"
"path/filepath"
"testing"
"github.com/ledgerwatch/erigon/cmd/devnet/args"
)
func TestNodeArgs(t *testing.T) {
asMap := map[string]struct{}{}
nodeArgs, _ := args.AsArgs(args.BlockProducer{
NodeArgs: args.NodeArgs{
DataDir: filepath.Join("data", fmt.Sprintf("%d", 1)),
PrivateApiAddr: "localhost:9092",
},
DevPeriod: 30,
})
for _, arg := range nodeArgs {
asMap[arg] = struct{}{}
}
for _, arg := range producingNodeArgs("data", 1) {
if _, ok := asMap[arg]; !ok {
t.Fatal(arg, "missing")
}
delete(asMap, arg)
}
if len(asMap) > 0 {
t.Fatal(asMap, "not found")
}
nodeArgs, _ = args.AsArgs(args.BlockConsumer{
NodeArgs: args.NodeArgs{
DataDir: filepath.Join("data", fmt.Sprintf("%d", 2)),
StaticPeers: "enode",
PrivateApiAddr: "localhost:9091",
},
})
for _, arg := range nodeArgs {
asMap[arg] = struct{}{}
}
for _, arg := range nonProducingNodeArgs("data", 2, "enode") {
if _, ok := asMap[arg]; !ok {
t.Fatal(arg, "missing")
}
delete(asMap, arg)
}
if len(asMap) > 0 {
t.Fatal(asMap, "not found")
}
}
func TestParameterFromArgument(t *testing.T) {
enode := fmt.Sprintf("%q", "1234567")
testCases := []struct {
argInput string
paramInput string
expectedRes string
expectedErr error
}{
{"--datadir", "./dev", "--datadir=./dev", nil},
{"--chain", "dev", "--chain=dev", nil},
{"--dev.period", "30", "--dev.period=30", nil},
{"--staticpeers", enode, "--staticpeers=" + enode, nil},
{"", "30", "", errInvalidArgument},
}
for _, testCase := range testCases {
got, err := parameterFromArgument(testCase.argInput, testCase.paramInput)
if got != testCase.expectedRes {
t.Errorf("expected %s, got %s", testCase.expectedRes, got)
}
if err != testCase.expectedErr {
t.Errorf("expected error: %s, got error: %s", testCase.expectedErr, err)
}
}
}
// errInvalidArgument for invalid arguments
var errInvalidArgument = errors.New("invalid argument")
// ParameterFromArgument merges the argument and parameter and returns a flag input string
func parameterFromArgument(arg, param string) (string, error) {
if arg == "" {
return "", errInvalidArgument
}
return fmt.Sprintf("%s=%s", arg, param), nil
}
const (
// BuildDirArg is the build directory for the devnet executable
buildDirArg = "./build/bin/devnet"
// DataDirArg is the datadir flag
dataDirArg = "--datadir"
// ChainArg is the chain flag
chainArg = "--chain"
// DevPeriodArg is the dev.period flag
devPeriodArg = "--dev.period"
// ConsoleVerbosityArg is the log.console.verbosity flag
consoleVerbosityArg = "--log.console.verbosity"
// LogDirArg is the log.dir.path flag
logDirArg = "--log.dir.path"
// TorrentPortArg is the --torrent.port flag argument
torrentPortArg = "--torrent.port"
// Mine is the mine flag
mine = "--mine"
// NoDiscover is the nodiscover flag
noDiscover = "--nodiscover"
// PrivateApiAddrArg is the private.api.addr flag
privateApiAddrArg = "--private.api.addr"
// StaticPeersArg is the staticpeers flag
staticPeersArg = "--staticpeers"
// HttpApiArg is the http.api flag
httpApiArg = "--http.api"
// WSArg is the --ws flag for rpcdaemon
wsArg = "--ws"
// DataDirParam is the datadir parameter
dataDirParam = "./dev"
// ChainParam is the chain parameter
chainParam = "dev"
// DevPeriodParam is the dev.period parameter
devPeriodParam = "30"
// ConsoleVerbosityParam is the verbosity parameter for the console logs
consoleVerbosityParam = "0"
// LogDirParam is the log directory parameter for logging to disk
logDirParam = "./cmd/devnet/debug_logs"
// TorrentPortParam is the port parameter for the second node
torrentPortParam = "42070"
// PrivateApiParamMine is the private.api.addr parameter for the mining node
privateApiParamMine = "localhost:9092"
// PrivateApiParamNoMine is the private.api.addr parameter for the non-mining node
privateApiParamNoMine = "localhost:9091"
// HttpApiParam is the http.api default parameter for rpcdaemon
httpApiParam = "admin,eth,erigon,web3,net,debug,trace,txpool,parity,ots"
)
// miningNodeArgs returns custom args for starting a mining node
func producingNodeArgs(dataDir string, nodeNumber int) []string {
nodeDataDir := filepath.Join(dataDir, fmt.Sprintf("%d", nodeNumber))
dataDirArg, _ := parameterFromArgument(dataDirArg, nodeDataDir)
chainType, _ := parameterFromArgument(chainArg, chainParam)
devPeriod, _ := parameterFromArgument(devPeriodArg, devPeriodParam)
privateApiAddr, _ := parameterFromArgument(privateApiAddrArg, privateApiParamMine)
httpApi, _ := parameterFromArgument(httpApiArg, httpApiParam)
ws := wsArg
consoleVerbosity, _ := parameterFromArgument(consoleVerbosityArg, consoleVerbosityParam)
p2pProtocol, _ := parameterFromArgument("--p2p.protocol", "68")
downloaderArg, _ := parameterFromArgument("--no-downloader", "true")
httpPortArg, _ := parameterFromArgument("--http.port", "8545")
wsPortArg, _ := parameterFromArgument("--ws.port", "8546")
authrpcPortArg, _ := parameterFromArgument("--authrpc.port", "8551")
natArg, _ := parameterFromArgument("--nat", "none")
accountSlotsArg, _ := parameterFromArgument("--txpool.accountslots", "16")
withHeimdallMilestonesArg, _ := parameterFromArgument("--bor.milestone", "false")
return []string{
buildDirArg,
dataDirArg,
chainType,
privateApiAddr,
httpPortArg,
wsPortArg,
authrpcPortArg,
mine,
httpApi,
ws,
natArg,
devPeriod,
consoleVerbosity,
p2pProtocol,
downloaderArg,
accountSlotsArg,
withHeimdallMilestonesArg,
}
}
// nonMiningNodeArgs returns custom args for starting a non-mining node
func nonProducingNodeArgs(dataDir string, nodeNumber int, enode string) []string {
nodeDataDir := filepath.Join(dataDir, fmt.Sprintf("%d", nodeNumber))
dataDirArg, _ := parameterFromArgument(dataDirArg, nodeDataDir)
chainType, _ := parameterFromArgument(chainArg, chainParam)
privateApiAddr, _ := parameterFromArgument(privateApiAddrArg, privateApiParamNoMine)
staticPeers, _ := parameterFromArgument(staticPeersArg, enode)
consoleVerbosity, _ := parameterFromArgument(consoleVerbosityArg, consoleVerbosityParam)
torrentPort, _ := parameterFromArgument(torrentPortArg, torrentPortParam)
p2pProtocol, _ := parameterFromArgument("--p2p.protocol", "68")
downloaderArg, _ := parameterFromArgument("--no-downloader", "true")
httpPortArg, _ := parameterFromArgument("--http.port", "8545")
wsPortArg, _ := parameterFromArgument("--ws.port", "8546")
httpApi, _ := parameterFromArgument(httpApiArg, "admin,eth,debug,net,trace,web3,erigon,txpool")
authrpcPortArg, _ := parameterFromArgument("--authrpc.port", "8551")
natArg, _ := parameterFromArgument("--nat", "none")
ws := wsArg
withHeimdallMilestonesArg, _ := parameterFromArgument("--bor.milestone", "false")
return []string{
buildDirArg,
dataDirArg,
chainType,
privateApiAddr,
httpPortArg,
wsPortArg,
authrpcPortArg,
httpApi,
ws,
natArg,
staticPeers,
noDiscover,
consoleVerbosity,
torrentPort,
p2pProtocol,
downloaderArg,
withHeimdallMilestonesArg,
}
}