cosmos-sdk/x/genutil/utils_test.go
Simon Zhang fecd038337
feat: port bls12381 from v0.52.rc2 (#24872)
Co-authored-by: Alex | Interchain Labs <alex@interchainlabs.io>
Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
2025-07-15 22:02:12 +00:00

172 lines
4.8 KiB
Go

package genutil
import (
"encoding/json"
"os"
"path/filepath"
"testing"
"time"
"github.com/cometbft/cometbft/v2/config"
tmed25519 "github.com/cometbft/cometbft/v2/crypto/ed25519"
"github.com/cometbft/cometbft/v2/privval"
"github.com/stretchr/testify/require"
)
func TestExportGenesisFileWithTime(t *testing.T) {
t.Parallel()
fname := filepath.Join(t.TempDir(), "genesis.json")
require.NoError(t, ExportGenesisFileWithTime(fname, "test", nil, json.RawMessage(`{"account_owner": "Bob"}`), time.Now()))
}
func TestInitializeNodeValidatorFilesFromMnemonic(t *testing.T) {
t.Parallel()
cfg := config.TestConfig()
cfg.RootDir = t.TempDir()
require.NoError(t, os.MkdirAll(filepath.Join(cfg.RootDir, "config"), 0o755))
tests := []struct {
name string
mnemonic string
expError bool
}{
{
name: "invalid mnemonic returns error",
mnemonic: "side video kiss hotel essence",
expError: true,
},
{
name: "empty mnemonic does not return error",
mnemonic: "",
expError: false,
},
{
name: "valid mnemonic does not return error",
mnemonic: "side video kiss hotel essence door angle student degree during vague adjust submit trick globe muscle frozen vacuum artwork million shield bind useful wave",
expError: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
_, _, err := InitializeNodeValidatorFilesFromMnemonic(cfg, tt.mnemonic)
if tt.expError {
require.Error(t, err)
} else {
require.NoError(t, err)
if tt.mnemonic != "" {
actualPVFile := privval.LoadFilePV(cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
expectedPrivateKey := tmed25519.GenPrivKeyFromSecret([]byte(tt.mnemonic))
expectedFile := privval.NewFilePV(expectedPrivateKey, cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
require.Equal(t, expectedFile, actualPVFile)
}
}
})
}
}
func TestInitializeNodeValidatorFilesFromMnemonicWithED25519(t *testing.T) {
t.Parallel()
cfg := config.TestConfig()
cfg.RootDir = t.TempDir()
require.NoError(t, os.MkdirAll(filepath.Join(cfg.RootDir, "config"), 0o755))
tests := []struct {
name string
mnemonic string
expError bool
}{
{
name: "invalid mnemonic returns error",
mnemonic: "side video kiss hotel essence",
expError: true,
},
{
name: "empty mnemonic does not return error",
mnemonic: "",
expError: false,
},
{
name: "valid mnemonic does not return error",
mnemonic: "side video kiss hotel essence door angle student degree during vague adjust submit trick globe muscle frozen vacuum artwork million shield bind useful wave",
expError: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
_, _, err := InitializeNodeValidatorFilesFromMnemonicWithKeyType(cfg, tt.mnemonic, "ed25519")
if tt.expError {
require.Error(t, err)
} else {
require.NoError(t, err)
if tt.mnemonic != "" {
actualPVFile := privval.LoadFilePV(cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
expectedPrivateKey := tmed25519.GenPrivKeyFromSecret([]byte(tt.mnemonic))
expectedFile := privval.NewFilePV(expectedPrivateKey, cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
require.Equal(t, expectedFile, actualPVFile)
}
}
})
}
}
// func TestInitializeNodeValidatorFilesFromMnemonicWithBLS(t *testing.T) {
// t.Parallel()
// cfg := config.TestConfig()
// cfg.RootDir = t.TempDir()
// require.NoError(t, os.MkdirAll(filepath.Join(cfg.RootDir, "config"), 0o755))
// tests := []struct {
// name string
// mnemonic string
// expError bool
// }{
// {
// name: "invalid mnemonic returns error",
// mnemonic: "side video kiss hotel essence",
// expError: true,
// },
// {
// name: "empty mnemonic does not return error",
// mnemonic: "",
// expError: false,
// },
// {
// name: "valid mnemonic returns error (BLS does not support mnemonic)",
// mnemonic: "side video kiss hotel essence door angle student degree during vague adjust submit trick globe muscle frozen vacuum artwork million shield bind useful wave",
// expError: true,
// },
// }
// for _, tt := range tests {
// t.Run(tt.name, func(t *testing.T) {
// _, _, err := InitializeNodeValidatorFilesFromMnemonicWithKeyType(cfg, tt.mnemonic, "bls12_381")
// if tt.expError {
// require.Error(t, err)
// } else {
// require.NoError(t, err)
// if tt.mnemonic == "" {
// actualPVFile := privval.LoadFilePV(cfg.PrivValidatorKeyFile(), cfg.PrivValidatorStateFile())
// privKeyBytes := actualPVFile.Key.PrivKey.Bytes()
// fmt.Println(privKeyBytes)
// pk, err := cmtbls12381.NewPrivateKeyFromBytes(privKeyBytes)
// require.Nil(t, err)
// require.NotNil(t, pk)
// }
// }
// })
// }
// }