-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmcgrew_testcases.py
317 lines (261 loc) · 10 KB
/
mcgrew_testcases.py
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
from testcase import Testcase
# Test cases for AES-GCM bench
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# Test cases from http://luca-giuzzi.unibs.it/corsi/Support/papers-cryptography/gcm-spec.pdf
testcases = [
Testcase(
key = """ 00000000000000000000000000000000 """,
plaintext = '',
aad = '',
nonce = """000000000000000000000000 """,
ctext_tag = """
58e2fccefa7e3061367f1d57a4e7455a """,
),
Testcase(
key = """00000000000000000000000000000000 """,
plaintext = """00000000000000000000000000000000 """,
nonce = """000000000000000000000000 """,
aad = "",
ctext_tag = """0388dace60b6a392f328c2b971b2fe78
ab6e47d42cec13bdf53a67b21257bddf """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b391aafd255 """,
nonce = """cafebabefacedbaddecaf888""",
aad = "",
ctext_tag = """ 42831ec2217774244b7221b784d0d49c
e3aa212f2c02a4e035c17e2329aca12e
21d514b25466931c7d8f6a5aac84aa05
1ba30b396a0aac973d58e091473f5985
4d5c2af327cd64a62cf35abd2ba6fab4 """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad = """ feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """cafebabefacedbaddecaf888 """,
ctext_tag = """ 42831ec2217774244b7221b784d0d49c
e3aa212f2c02a4e035c17e2329aca12e
21d514b25466931c7d8f6a5aac84aa05
1ba30b396a0aac973d58e091
5bc94fbc3221a5db94fae95ae7121a47 """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad = """ feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """cafebabefacedbad """,
ctext_tag = """ 61353b4c2806934a777ff51fa22a4755
699b2a714fcdc6f83766e5f97b6c7423
73806900e49f24b22b097544d4896b42
4989b5e1ebac0f07c23f4598
3612d2e79e3b0785561be14aaca2fccb """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad = """ feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """9313225df88406e555909c5aff5269aa
6a7a9538534f7da1e4c303d2a318a728
c3c0c95156809539fcf0e2429a6b5254
16aedbf5a0de6a57a637b39b """,
ctext_tag = """ 8ce24998625615b603a033aca13fb894
be9112a5c3a211a8ba262a3cca7e2ca7
01e4a9a4fba43c90ccdcb281d48c7c6f
d62875d2aca417034c34aee5
619cc5aefffe0bfa462af43c1699d050 """,
),
Testcase(
key = """ 00000000000000000000000000000000
0000000000000000 """,
nonce = """ 000000000000000000000000""",
plaintext = "",
aad = "",
ctext_tag = """cd33b28ac773f74ba00ed1f312572435 """,
),
Testcase(
key = """ 00000000000000000000000000000000
0000000000000000 """,
nonce = """000000000000000000000000 """,
plaintext =""" 00000000000000000000000000000000 """,
aad = "",
ctext_tag = """98e7247c07f0fe411c267e4384b0f600
2ff58d80033927ab8ef4d4587514f0fb """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c """,
plaintext =""" d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b391aafd255 """,
nonce = """cafebabefacedbaddecaf888 """,
aad = "",
ctext_tag = """ 3980ca0b3c00e841eb06fac4872a2757
859e1ceaa6efd984628593b40ca1e19c
7d773d00c144c525ac619d18c84a3f47
18e2448b2fe324d9ccda2710acade256
9924a7c8587336bfb118024db8674a14 """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad = """ feedfacedeadbeeffeedfacedeadbeef
abaddad2""",
nonce = """cafebabefacedbaddecaf888 """,
ctext_tag = """ 3980ca0b3c00e841eb06fac4872a2757
859e1ceaa6efd984628593b40ca1e19c
7d773d00c144c525ac619d18c84a3f47
18e2448b2fe324d9ccda2710
2519498e80f1478f37ba55bd6d27618c """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c """,
plaintext =""" d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad =""" feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """cafebabefacedbad """,
ctext_tag = """ 0f10f599ae14a154ed24b36e25324db8
c566632ef2bbb34f8347280fc4507057
fddc29df9a471f75c66541d4d4dad1c9
e93a19a58e8b473fa0f062f7
65dcc57fcf623a24094fcca40d3533f8 """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c """,
plaintext =""" d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad = """ feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """9313225df88406e555909c5aff5269aa
6a7a9538534f7da1e4c303d2a318a728
c3c0c95156809539fcf0e2429a6b5254
16aedbf5a0de6a57a637b39b """,
ctext_tag = """ d27e88681ce3243c4830165a8fdcf9ff
1de9a1d8e6b447ef6ef7b79828666e45
81e79012af34ddd9e2f037589b292db3
e67c036745fa22e7e9b7373b
dcf566ff291c25bbb8568fc3d376a6d9 """,
),
Testcase(
key = """ 00000000000000000000000000000000
00000000000000000000000000000000 """,
plaintext = "",
aad = "",
nonce = "000000000000000000000000",
ctext_tag = """
530f8afbc74536b9a963b4f1c4cb738b """,
),
Testcase(
key = """ 00000000000000000000000000000000
00000000000000000000000000000000 """,
plaintext = """ 00000000000000000000000000000000 """,
aad = "",
nonce = "000000000000000000000000",
ctext_tag = """cea7403d4d606b6e074ec5d3baf39d18
d0d1c8a799996bf0265b98b5d48ab919 """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b391aafd255""",
nonce = """cafebabefacedbaddecaf888 """,
aad = "",
ctext_tag = """ 522dc1f099567d07f47f37a32a84427d
643a8cdcbfe5c0c97598a2bd2555d1aa
8cb08e48590dbb3da7b08b1056828838
c5f61e6393ba7a0abcc9f662898015ad
b094dac5d93471bdec1a502270e3cc6c """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad = """ feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """cafebabefacedbaddecaf888 """,
ctext_tag = """ 522dc1f099567d07f47f37a32a84427d
643a8cdcbfe5c0c97598a2bd2555d1aa
8cb08e48590dbb3da7b08b1056828838
c5f61e6393ba7a0abcc9f662
76fc6ece0f4e1768cddf8853bb2d551b """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad = """ feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """cafebabefacedbad """,
ctext_tag = """ c3762df1ca787d32ae47c13bf19844cb
af1ae14d0b976afac52ff7d79bba9de0
feb582d33934a4f0954cc2363bc73f78
62ac430e64abe499f47c9b1f
3a337dbf46a792c45e454913fe2ea8f2 """,
),
Testcase(
key = """ feffe9928665731c6d6a8f9467308308
feffe9928665731c6d6a8f9467308308 """,
plaintext = """ d9313225f88406e5a55909c5aff5269a
86a7a9531534f7da2e4c303d8a318a72
1c3c0c95956809532fcf0e2449a6b525
b16aedf5aa0de657ba637b39 """,
aad =""" feedfacedeadbeeffeedfacedeadbeef
abaddad2 """,
nonce = """
9313225df88406e555909c5aff5269aa
6a7a9538534f7da1e4c303d2a318a728
c3c0c95156809539fcf0e2429a6b5254
16aedbf5a0de6a57a637b39b """,
ctext_tag = """ 5a8def2f0c9e53f1f75d7853659e2a20
eeb2b22aafde6419a058ab4f6f746bf4
0fc0c3b780f244452da3ebf1c5d82cde
a2418997200ef82e44ae7e3f
a44a8266ee1c8eb0c8b5d4cf5ae9f19a""",
),
]