forked from mergermarket/go-pkcs7
-
Notifications
You must be signed in to change notification settings - Fork 0
/
pkcs7_test.go
100 lines (83 loc) · 3.29 KB
/
pkcs7_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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
package pkcs7
import (
"bytes"
"fmt"
"testing"
)
const BLOCK_SIZE = 16
func TestPkcs7(t *testing.T) {
t.Run("Pads", func(t *testing.T) {
result, _ := Pad([]byte("1234567890"), BLOCK_SIZE)
expected := []byte("1234567890\x06\x06\x06\x06\x06\x06")
if bytes.Equal(result, expected) == false {
panic(fmt.Sprintf(`Failed to pad - expected "%s" but got "%s"`, expected, result))
}
})
t.Run("Unpads", func(t *testing.T) {
result, _ := Unpad([]byte("1234567890\x06\x06\x06\x06\x06\x06"), BLOCK_SIZE)
expected := []byte("1234567890")
if bytes.Equal(result, expected) == false {
panic(fmt.Sprintf(`Failed to unpad - expected "%s" but got "%s"`, expected, result))
}
})
t.Run("Unpads error length", func(t *testing.T) {
_, err := Unpad([]byte("123456789012345678901234567890123456789012345678901234567890\x11\x11\x11\x11"), BLOCK_SIZE)
if err == nil {
panic(fmt.Sprint("process error"))
}
})
t.Run("Unpads error format", func(t *testing.T) {
_, err := Unpad([]byte("12345678901\x06\x06\x06\x06\x06"), BLOCK_SIZE)
if err == nil {
panic(fmt.Sprint("process error"))
}
})
t.Run("Handles long", func(t *testing.T) {
longStr := []byte("123456789012345678901234567890123456789012345678901234567890")
padded, _ := Pad(longStr, BLOCK_SIZE)
expected := []byte("123456789012345678901234567890123456789012345678901234567890\x04\x04\x04\x04")
if bytes.Equal(padded, expected) == false {
panic(fmt.Sprintf(`Padding wrong - expected "%x" but got "%x"`, expected, padded))
}
unpadded, _ := Unpad(padded, BLOCK_SIZE)
if bytes.Equal(unpadded, longStr) == false {
panic(fmt.Sprintf(`Failed to handle long value - expected "%s" but got "%s"`, longStr, unpadded))
}
})
t.Run("Handles short", func(t *testing.T) {
shortStr := []byte("1")
padded, _ := Pad(shortStr, BLOCK_SIZE)
expected := []byte("1\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f\x0f")
if bytes.Equal(padded, expected) == false {
panic(fmt.Sprintf(`Padding wrong - expected "%x" but got "%x"`, expected, padded))
}
unpadded, _ := Unpad(padded, BLOCK_SIZE)
if bytes.Equal(unpadded, shortStr) == false {
panic(fmt.Sprintf(`Failed to handle short value - expected "%s" but got "%s"`, shortStr, unpadded))
}
})
t.Run("Handles empty", func(t *testing.T) {
emptyStr := []byte("")
padded, _ := Pad(emptyStr, BLOCK_SIZE)
expected := []byte("\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10")
if bytes.Equal(padded, expected) == false {
panic(fmt.Sprintf(`Padding wrong - expected "%x" but got "%x"`, expected, padded))
}
unpadded, _ := Unpad(padded, BLOCK_SIZE)
if bytes.Equal(unpadded, emptyStr) == false {
panic(fmt.Sprintf(`Failed to handle empty value - expected "%s" but got "%s"`, emptyStr, unpadded))
}
})
t.Run("Handles block size", func(t *testing.T) {
val := []byte("1234567890ABCDEF")
padded, _ := Pad(val, BLOCK_SIZE)
expected := []byte("1234567890ABCDEF\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10\x10")
if bytes.Equal(padded, expected) == false {
panic(fmt.Sprintf(`Padding wrong - expected "%x" but got "%x"`, expected, padded))
}
unpadded, _ := Unpad(padded, BLOCK_SIZE)
if bytes.Equal(unpadded, val) == false {
panic(fmt.Sprintf(`Failed to handle block size value - expected "%s" but got "%s"`, val, unpadded))
}
})
}