mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-08 10:41:19 +00:00
43 lines
1.0 KiB
Go
43 lines
1.0 KiB
Go
|
package p2p
|
||
|
|
||
|
import (
|
||
|
"crypto/ecdsa"
|
||
|
"crypto/rand"
|
||
|
"encoding/hex"
|
||
|
"io/ioutil"
|
||
|
"os"
|
||
|
"testing"
|
||
|
|
||
|
curve "github.com/ethereum/go-ethereum/crypto"
|
||
|
"github.com/prysmaticlabs/prysm/shared/testutil"
|
||
|
)
|
||
|
|
||
|
func TestPrivateKeyLoading(t *testing.T) {
|
||
|
file, err := ioutil.TempFile(testutil.TempDir(), "key")
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
defer os.Remove(file.Name())
|
||
|
key, err := ecdsa.GenerateKey(curve.S256(), rand.Reader)
|
||
|
if err != nil {
|
||
|
t.Fatalf("Could not generate key: %v", err)
|
||
|
}
|
||
|
keyStr := hex.EncodeToString(curve.FromECDSA(key))
|
||
|
err = ioutil.WriteFile(file.Name(), []byte(keyStr), 0600)
|
||
|
if err != nil {
|
||
|
t.Fatalf("Could not write key to file: %v", err)
|
||
|
}
|
||
|
log.WithField("file", file.Name()).WithField("key", keyStr).Info("Wrote key to file")
|
||
|
cfg := &Config{
|
||
|
PrivateKey: file.Name(),
|
||
|
}
|
||
|
pKey, err := privKey(cfg)
|
||
|
if err != nil {
|
||
|
t.Fatalf("Could not apply option: %v", err)
|
||
|
}
|
||
|
newEncoded := hex.EncodeToString(curve.FromECDSA(pKey))
|
||
|
if newEncoded != keyStr {
|
||
|
t.Error("Private keys do not match")
|
||
|
}
|
||
|
}
|