-
Notifications
You must be signed in to change notification settings - Fork 64
/
Copy pathnonce_test.go
60 lines (47 loc) · 1.52 KB
/
nonce_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
// Copyright 2017 Keybase, Inc. All rights reserved. Use of
// this source code is governed by the included BSD license.
package saltpack
import (
"testing"
)
func TestNonceForPayloadKeyBoxV1(t *testing.T) {
nonce1 := nonceForPayloadKeyBox(Version1(), 0)
nonce2 := nonceForPayloadKeyBox(Version1(), 1)
// The V1 MAC key doesn't depend on the index; this is fixed
// in V2.
if nonce2 != nonce1 {
t.Errorf("nonce2 == %v != nonce1 == %v unexpectedly", nonce2, nonce1)
}
}
func TestNonceForPayloadKeyBoxV2(t *testing.T) {
nonce1a := nonceForPayloadKeyBoxV2(0)
nonce1b := nonceForPayloadKeyBox(Version2(), 0)
nonce2a := nonceForPayloadKeyBoxV2(1)
nonce2b := nonceForPayloadKeyBox(Version2(), 1)
if nonce1b != nonce1a {
t.Errorf("nonce1b == %v != nonce1a == %v unexpectedly", nonce1b, nonce1a)
}
if nonce2b != nonce2a {
t.Errorf("nonce2b == %v != nonce2a == %v unexpectedly", nonce2b, nonce2a)
}
if nonce2a == nonce1a {
t.Errorf("nonce2a == nonce1a == %v unexpectedly", nonce1a)
}
}
func TestNonceForMACKeyBoxV2(t *testing.T) {
hash1 := headerHash{0x01}
hash2 := headerHash{0x02}
nonce1 := nonceForMACKeyBoxV2(hash1, false, 0)
nonce2 := nonceForMACKeyBoxV2(hash2, false, 0)
nonce3 := nonceForMACKeyBoxV2(hash1, true, 0)
nonce4 := nonceForMACKeyBoxV2(hash1, false, 1)
if nonce2 == nonce1 {
t.Errorf("nonce2 == nonce1 == %v unexpectedly", nonce1)
}
if nonce3 == nonce1 {
t.Errorf("nonce3 == nonce1 == %v unexpectedly", nonce1)
}
if nonce4 == nonce1 {
t.Errorf("nonce4 == nonce1 == %v unexpectedly", nonce1)
}
}