2021-11-04 18:19:44 +00:00
|
|
|
package powchaincmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
2022-02-25 19:08:43 +00:00
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
2021-11-04 18:19:44 +00:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/prysmaticlabs/prysm/cmd/beacon-chain/flags"
|
2022-02-25 19:08:43 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/encoding/bytesutil"
|
|
|
|
"github.com/prysmaticlabs/prysm/io/file"
|
2021-11-04 18:19:44 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/testing/assert"
|
|
|
|
"github.com/prysmaticlabs/prysm/testing/require"
|
|
|
|
logTest "github.com/sirupsen/logrus/hooks/test"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestPowchainCmd(t *testing.T) {
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
set.String(flags.HTTPWeb3ProviderFlag.Name, "primary", "")
|
|
|
|
fallback := cli.StringSlice{}
|
|
|
|
err := fallback.Set("fallback1")
|
|
|
|
require.NoError(t, err)
|
|
|
|
err = fallback.Set("fallback2")
|
|
|
|
require.NoError(t, err)
|
|
|
|
set.Var(&fallback, flags.FallbackWeb3ProviderFlag.Name, "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
|
|
|
|
2022-02-10 16:46:31 +00:00
|
|
|
endpoints := parsePowchainEndpoints(ctx)
|
2021-11-04 18:19:44 +00:00
|
|
|
assert.DeepEqual(t, []string{"primary", "fallback1", "fallback2"}, endpoints)
|
|
|
|
}
|
|
|
|
|
2022-02-25 19:08:43 +00:00
|
|
|
func Test_parseJWTSecretFromFile(t *testing.T) {
|
|
|
|
t.Run("no flag value specified leads to nil secret", func(t *testing.T) {
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
set.String(flags.ExecutionJWTSecretFlag.Name, "", "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
|
|
|
secret, err := parseJWTSecretFromFile(ctx)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, true, secret == nil)
|
|
|
|
})
|
|
|
|
t.Run("flag specified but no file found", func(t *testing.T) {
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
set.String(flags.ExecutionJWTSecretFlag.Name, "/tmp/askdjkajsd", "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
|
|
|
_, err := parseJWTSecretFromFile(ctx)
|
|
|
|
require.ErrorContains(t, "no such file", err)
|
|
|
|
})
|
|
|
|
t.Run("empty string in file", func(t *testing.T) {
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
fullPath := filepath.Join(os.TempDir(), "foohex")
|
|
|
|
require.NoError(t, file.WriteFile(fullPath, []byte{}))
|
|
|
|
t.Cleanup(func() {
|
|
|
|
if err := os.RemoveAll(fullPath); err != nil {
|
|
|
|
t.Fatalf("Could not delete temp dir: %v", err)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
set.String(flags.ExecutionJWTSecretFlag.Name, fullPath, "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
|
|
|
_, err := parseJWTSecretFromFile(ctx)
|
|
|
|
require.ErrorContains(t, "cannot be empty", err)
|
|
|
|
})
|
|
|
|
t.Run("less than 32 bytes", func(t *testing.T) {
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
fullPath := filepath.Join(os.TempDir(), "foohex")
|
|
|
|
secret := bytesutil.PadTo([]byte("foo"), 31)
|
|
|
|
hexData := fmt.Sprintf("%#x", secret)
|
|
|
|
require.NoError(t, file.WriteFile(fullPath, []byte(hexData)))
|
|
|
|
t.Cleanup(func() {
|
|
|
|
if err := os.RemoveAll(fullPath); err != nil {
|
|
|
|
t.Fatalf("Could not delete temp dir: %v", err)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
set.String(flags.ExecutionJWTSecretFlag.Name, fullPath, "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
|
|
|
_, err := parseJWTSecretFromFile(ctx)
|
|
|
|
require.ErrorContains(t, "should be a hex string of at least 32 bytes", err)
|
|
|
|
})
|
|
|
|
t.Run("bad data", func(t *testing.T) {
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
fullPath := filepath.Join(os.TempDir(), "foohex")
|
|
|
|
secret := []byte("foo")
|
|
|
|
require.NoError(t, file.WriteFile(fullPath, secret))
|
|
|
|
t.Cleanup(func() {
|
|
|
|
if err := os.RemoveAll(fullPath); err != nil {
|
|
|
|
t.Fatalf("Could not delete temp dir: %v", err)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
set.String(flags.ExecutionJWTSecretFlag.Name, fullPath, "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
|
|
|
_, err := parseJWTSecretFromFile(ctx)
|
|
|
|
require.ErrorContains(t, "invalid byte", err)
|
|
|
|
})
|
|
|
|
t.Run("correct format", func(t *testing.T) {
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
fullPath := filepath.Join(os.TempDir(), "foohex")
|
|
|
|
secret := bytesutil.ToBytes32([]byte("foo"))
|
|
|
|
secretHex := fmt.Sprintf("%#x", secret)
|
|
|
|
require.NoError(t, file.WriteFile(fullPath, []byte(secretHex)))
|
|
|
|
t.Cleanup(func() {
|
|
|
|
if err := os.RemoveAll(fullPath); err != nil {
|
|
|
|
t.Fatalf("Could not delete temp dir: %v", err)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
set.String(flags.ExecutionJWTSecretFlag.Name, fullPath, "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
|
|
|
got, err := parseJWTSecretFromFile(ctx)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.DeepEqual(t, secret[:], got)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-11-04 18:19:44 +00:00
|
|
|
func TestPowchainPreregistration_EmptyWeb3Provider(t *testing.T) {
|
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
app := cli.App{}
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
set.String(flags.HTTPWeb3ProviderFlag.Name, "", "")
|
|
|
|
fallback := cli.StringSlice{}
|
|
|
|
set.Var(&fallback, flags.FallbackWeb3ProviderFlag.Name, "")
|
|
|
|
ctx := cli.NewContext(&app, set, nil)
|
2022-02-10 16:46:31 +00:00
|
|
|
parsePowchainEndpoints(ctx)
|
2021-11-04 18:19:44 +00:00
|
|
|
assert.LogsContain(t, hook, "No ETH1 node specified to run with the beacon node")
|
|
|
|
}
|