-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdamm_test.go
117 lines (97 loc) · 2.13 KB
/
damm_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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package damm
import "testing"
func TestDamm(t *testing.T) {
expectSignature := func(a string, b string) {
c, err := Generate(a)
if err != nil {
t.Errorf("%v", err)
} else if b != c {
t.Errorf("for input " + a + " expected signature " + b + " but got " + c + " instead")
}
if !Validate(c) {
t.Errorf("Unable to validate signature that was generated")
}
}
if !Validate("00123014764700968325") {
t.Errorf("Checksum failed for valid input")
}
if Validate("1234567812345678") {
t.Errorf("Checksum passed for invalid input")
}
if Validate("xy-1") {
t.Errorf("Checksum passed for invalid alphabet")
}
expectSignature("0012301476470096832", "00123014764700968325")
}
func BenchmarkDigitSmall(b *testing.B) {
for n := 0; n < b.N; n++ {
Digit("123")
}
}
func BenchmarkDigitLarge(b *testing.B) {
for n := 0; n < b.N; n++ {
Digit("00123014764700968325")
}
}
func BenchmarkDigitSmallParallel(b *testing.B) {
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
Digit("123")
}
})
}
func BenchmarkDigitLargeParallel(b *testing.B) {
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
Digit("00123014764700968325")
}
})
}
func BenchmarkValidateSmall(b *testing.B) {
for n := 0; n < b.N; n++ {
Validate("123")
}
}
func BenchmarkValidateLarge(b *testing.B) {
for n := 0; n < b.N; n++ {
Validate("00123014764700968325")
}
}
func BenchmarkValidateSmallParallel(b *testing.B) {
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
Validate("123")
}
})
}
func BenchmarkValidateLargeParallel(b *testing.B) {
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
Validate("00123014764700968325")
}
})
}
func BenchmarkGenerateSmall(b *testing.B) {
for n := 0; n < b.N; n++ {
Generate("123")
}
}
func BenchmarkGenerateLarge(b *testing.B) {
for n := 0; n < b.N; n++ {
Generate("00123014764700968325")
}
}
func BenchmarkGenerateSmallParallel(b *testing.B) {
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
Generate("123")
}
})
}
func BenchmarkGenerateLargeParallel(b *testing.B) {
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
Generate("00123014764700968325")
}
})
}