39 lines
691 B
Go
39 lines
691 B
Go
package pubkey
|
|
|
|
import (
|
|
"bytes"
|
|
"crypto/ed25519"
|
|
"crypto/rand"
|
|
"testing"
|
|
)
|
|
|
|
func TestP_Marshal_Unmarshal(t *testing.T) {
|
|
pk := make([]byte, ed25519.PublicKeySize)
|
|
var err error
|
|
if _, err = rand.Read(pk); chk.E(err) {
|
|
t.Fatal(err)
|
|
}
|
|
log.I.S(pk)
|
|
var p *P
|
|
if p, err = New(pk); chk.E(err) {
|
|
t.Fatal(err)
|
|
}
|
|
var o []byte
|
|
if o, err = p.Marshal(nil); chk.E(err) {
|
|
t.Fatal(err)
|
|
}
|
|
log.I.F("%d %s", len(o), o)
|
|
p2 := &P{}
|
|
var rem []byte
|
|
if rem, err = p2.Unmarshal(o); chk.E(err) {
|
|
t.Fatal(err)
|
|
}
|
|
if len(rem) > 0 {
|
|
log.I.F("%d %s", len(rem), rem)
|
|
}
|
|
log.I.S(p2.PublicKey)
|
|
if !bytes.Equal(pk, p2.PublicKey) {
|
|
t.Fatal("public key did not encode/decode faithfully")
|
|
}
|
|
}
|