-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathprkg_test.go
68 lines (55 loc) · 1.33 KB
/
prkg_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package lms
import (
"bytes"
"encoding/gob"
"testing"
"github.com/LoCCS/lmots"
"github.com/LoCCS/lmots/rand"
)
func TestKeyIteratorGobEncoding(t *testing.T) {
seed := make([]byte, lmots.N)
rand.Reader.Read(seed)
prkg := NewKeyIterator(seed)
prkg.Next()
buf := new(bytes.Buffer)
if err := gob.NewEncoder(buf).Encode(prkg); nil != err {
t.Fatal(err)
}
bs := buf.Bytes()
prkg2 := new(KeyIterator)
if err := gob.NewDecoder(buf).Decode(prkg2); nil != err {
t.Fatal(err)
}
buf2 := new(bytes.Buffer)
if err := gob.NewEncoder(buf2).Encode(prkg2); nil != err {
t.Fatal(err)
}
if !bytes.Equal(bs, buf2.Bytes()) {
t.Fatalf("invalid gob: want %x, got %x", bs, buf2.Bytes())
}
}
// TestKeyIteratorExec tests correctness KeyIterator, including
// normal running (demo by iter) and recovered running from
// seed (demo by iter2)
func TestKeyIterator(t *testing.T) {
seed := make([]byte, lmots.N)
rand.Reader.Read(seed)
iter := NewKeyIterator(seed)
iter.Next()
iter2 := new(KeyIterator)
data, err := iter.Serialize()
if nil != err {
t.Fatal("unexpected error:", err)
}
if err := iter2.Deserialize(data); nil != err {
t.Fatal("invalid integrated seed")
}
for i := 0; i < 2; i++ {
sk1, _ := iter.Next()
sk2, _ := iter2.Next()
// check equality
if !sk1.Equal(sk2) {
t.Fatal("private keys should be equal")
}
}
}