v
Зеркало из https://github.com/vlang/v
1// These tests are derived from the Secure Hash Algorithm Validation System
2// test vectors contained in:
3// https://csrc.nist.gov/CSRC/media/Projects/Cryptographic-Algorithm-Validation-Program/documents/shs/shabytetestvectors.zip
4//
5// For SHA512_256, the test vectors come from:
6// SHA512_256Monte.rsp
7import crypto.sha512
8import encoding.hex
9
10const seed = 'f41ece2613e4573915696b5adcd51ca328be3bf566a9ca99c9ceb0279c1cb0a7'
11
12struct MonteTestCase {
13name string
14count int
15digest string
16}
17
18const monte_cases = [
19MonteTestCase{
20name: 'checkpoint 0'
21count: 0
22digest: 'b1d97a6536896aa01098fb2b9e15d8692621c84077051fc1f70a8a48baa6dfaf'
23},
24MonteTestCase{
25name: 'checkpoint 1'
26count: 1
27digest: 'a008d2c5adce31a95b30397ac691d8606c6769a47b801441ba3afb7f727c8a9c'
28},
29MonteTestCase{
30name: 'checkpoint 2'
31count: 2
32digest: '8eb896cb2b309db019121eb72564b89c1a59f74d4e2f2f6773c87b98c1997d77'
33},
34MonteTestCase{
35name: 'checkpoint 3'
36count: 3
37digest: 'ac71b694438cc300dde0f6f9f548d2304e2bdb6ea45e2b305af5fb3e4ec27761'
38},
39MonteTestCase{
40name: 'checkpoint 4'
41count: 4
42digest: 'd47cca4ae027778fc285bc78fb2a9c1cc7cde498267c35157e86b05fc58e698d'
43},
44MonteTestCase{
45name: 'checkpoint 5'
46count: 5
47digest: '8bc1516ecea32fa3cd4f9f12ac13a2af6763090226e7c1484b2d85757fc9e82a'
48},
49MonteTestCase{
50name: 'checkpoint 6'
51count: 6
52digest: '1abe44379539744d7806f5d3ef7c2202d0b08f575d1899b7a3df737b18e2a2a6'
53},
54MonteTestCase{
55name: 'checkpoint 7'
56count: 7
57digest: '324a7606ee9fc9cb26abd881581e70a06fedf33456f385b370973fcee8d01b7a'
58},
59MonteTestCase{
60name: 'checkpoint 8'
61count: 8
62digest: '06d1ccb978ca4b455ed380bea2e8c3afe24d0b935f5740677927f6f1a96fa111'
63},
64MonteTestCase{
65name: 'checkpoint 9'
66count: 9
67digest: 'cc78adb572c8cff2cc84020dfb61c521657baf3bcd8aea9593437cd2cdb94266'
68},
69MonteTestCase{
70name: 'checkpoint 10'
71count: 10
72digest: '935a43189f019f06a630f7601e1d40d51fc2c2ea602fea2c0da8404730c5a475'
73},
74MonteTestCase{
75name: 'checkpoint 11'
76count: 11
77digest: 'a99225bcdbbac4a87d8ed9e8e06889e823fc993a9661cedf1af02c6d38505989'
78},
79MonteTestCase{
80name: 'checkpoint 12'
81count: 12
82digest: 'e5e769874da74a143cd49f0a2f7a6cd3ad4c28f55d8719c85063dfdf0e1efbbf'
83},
84MonteTestCase{
85name: 'checkpoint 13'
86count: 13
87digest: '43f7ff7effc58dead5f13a47f8ea7e19f83dbcb409b10b3f985c78346817448f'
88},
89MonteTestCase{
90name: 'checkpoint 14'
91count: 14
92digest: 'c1acce072812dfc53682f0c4794b1cc4ae21fca882f4046e6d2c945f6d29dc24'
93},
94MonteTestCase{
95name: 'checkpoint 15'
96count: 15
97digest: 'a78313758117cf3319d90decbe3b46bf7ba20c079879f485b3290fbead662ac9'
98},
99MonteTestCase{
100name: 'checkpoint 16'
101count: 16
102digest: '8eca6994ac6093c1f7701bec60770293d754e9eb95372f9ab10ca58fe8864bd0'
103},
104MonteTestCase{
105name: 'checkpoint 17'
106count: 17
107digest: '05457ef20a508c205225b9a836f11964febd60d9dd31943c49b91578741dd7fc'
108},
109MonteTestCase{
110name: 'checkpoint 18'
111count: 18
112digest: '8ee3ca17f5ad34649a41b3cb6f4c60d24229d3c39b9afdce11725779296ce412'
113},
114MonteTestCase{
115name: 'checkpoint 19'
116count: 19
117digest: 'c9873b3341592ea56d0321a6653c350ebab65beb5e37f0a1554e9c07d93924a4'
118},
119MonteTestCase{
120name: 'checkpoint 20'
121count: 20
122digest: 'eba87758a57c5f9e3caa8da51b1acdbb2e69be17379f81715a134f5f09c4662f'
123},
124MonteTestCase{
125name: 'checkpoint 21'
126count: 21
127digest: '8f70a95573734147b50866372b11673d97a8cd0754013f7f6fb35f96b2911353'
128},
129MonteTestCase{
130name: 'checkpoint 22'
131count: 22
132digest: '19ec8b72cf00b934d5bde820566eadc516e0038cb54bfc59349c68b36d079a62'
133},
134MonteTestCase{
135name: 'checkpoint 23'
136count: 23
137digest: '22f7a748d30425980a9f83298b0b053ff8ac156f304c87aa5d10a01e2e05c397'
138},
139MonteTestCase{
140name: 'checkpoint 24'
141count: 24
142digest: '3429d8880a8862eb6973b245c7d62f2f8078b7defe8eb117e8c787b30df520bf'
143},
144MonteTestCase{
145name: 'checkpoint 25'
146count: 25
147digest: '373806e57129e849aa91a208a1f855f9bedfcd9f85b259a70fe481a35f0266ad'
148},
149MonteTestCase{
150name: 'checkpoint 26'
151count: 26
152digest: '6fa0be65b46bfc853be64470cc9cfe46e2001d1345b3eb4ce3e2f881a2c7a56d'
153},
154MonteTestCase{
155name: 'checkpoint 27'
156count: 27
157digest: 'b32b578b078f6e3c8c48ca07de123fc7db6b6abe8ec09f6b91263e0353d2c584'
158},
159MonteTestCase{
160name: 'checkpoint 28'
161count: 28
162digest: '8cb0edd50a485250433188a66758fc8167e07d665aeb1553f53e08169d1842b5'
163},
164MonteTestCase{
165name: 'checkpoint 29'
166count: 29
167digest: '92150694ff1674bf073856b6df9a6cd015087e9bd366e7387e8c19084e0cc598'
168},
169MonteTestCase{
170name: 'checkpoint 30'
171count: 30
172digest: '3ec487fd88c8e1321e9279f8d5a82026efee762d686968cd2d801ab7f6b3d912'
173},
174MonteTestCase{
175name: 'checkpoint 31'
176count: 31
177digest: '894c78e468398414affcf1e9ab8fb14426e1fae964379615a212b744e61b12e9'
178},
179MonteTestCase{
180name: 'checkpoint 32'
181count: 32
182digest: '7f6a9d2c8d476ad79c845f786da4bd4a8de9a4af05ad0cb12af1375077714cb4'
183},
184MonteTestCase{
185name: 'checkpoint 33'
186count: 33
187digest: '092ae9d7a22cff2d6f28cb2ed47c082ef279fc20e2246b638c6c0c941238a075'
188},
189MonteTestCase{
190name: 'checkpoint 34'
191count: 34
192digest: '553d007076a97c6c6566600693cff33fcba2d021c1fb690427823d65076e4249'
193},
194MonteTestCase{
195name: 'checkpoint 35'
196count: 35
197digest: '17a8b074390ff2aca2b9cb7bfa17310a293f522b6bfe9b6b6f1429d709f8be7b'
198},
199MonteTestCase{
200name: 'checkpoint 36'
201count: 36
202digest: '6d903e776f8edadc19c680fab311dfec6aebf7333dd924dadc21fd0b624ea856'
203},
204MonteTestCase{
205name: 'checkpoint 37'
206count: 37
207digest: '1a340486e0703cfddf87dbedb73c93b499ed6018ed8a50ae148ec9cb0be1a608'
208},
209MonteTestCase{
210name: 'checkpoint 38'
211count: 38
212digest: 'd694d39fadf623aaf0144abd69d5cb580d050fc4efe49f98f0d910cba5ca3531'
213},
214MonteTestCase{
215name: 'checkpoint 39'
216count: 39
217digest: '128d31156899fec03b0251cd739f2ee6b5041e9323a5aa31389f67ddf0c5a981'
218},
219MonteTestCase{
220name: 'checkpoint 40'
221count: 40
222digest: '1b3df866d64c5db4f55a4137e1d88da5b6e8a107a6fbe0022cde5e5c293a6a35'
223},
224MonteTestCase{
225name: 'checkpoint 41'
226count: 41
227digest: '31feabe0b78b6a9ab56929570e48afc949e8150e5e1dd11ad7a8c6b43f1db943'
228},
229MonteTestCase{
230name: 'checkpoint 42'
231count: 42
232digest: 'c7c08d91944704e9de672577acc1a0cc832cc109e26742a2812822c55dd432ff'
233},
234MonteTestCase{
235name: 'checkpoint 43'
236count: 43
237digest: '76b41e08876b881dcf0007746a1a1e275e512b38c0f949cadd0521cc4bb43a2a'
238},
239MonteTestCase{
240name: 'checkpoint 44'
241count: 44
242digest: 'eb015a3eee8b130cba1f120e41b83eb032124d366f8a40eedb0569124b013c34'
243},
244MonteTestCase{
245name: 'checkpoint 45'
246count: 45
247digest: '537d4b84f4c9ce3c30723db6ea2dfc3a8df1d2a4fb090c651dee04ebc019145a'
248},
249MonteTestCase{
250name: 'checkpoint 46'
251count: 46
252digest: '9000799092b166e5042f996f9dc4273daee4c96b80716e321ea17f50e3e74e18'
253},
254MonteTestCase{
255name: 'checkpoint 47'
256count: 47
257digest: '20c9c91bf7bfd79ed144cfbf5ea7226f5513ceed5944834c53326dad1a6a77a4'
258},
259MonteTestCase{
260name: 'checkpoint 48'
261count: 48
262digest: '5d3b9b8125e1c55ee5dd70548d38ebf9bc706536b6db98f85c48b3072d27cb2d'
263},
264MonteTestCase{
265name: 'checkpoint 49'
266count: 49
267digest: '53e469865c36cddde9a53b29a3ed6b8bcc5e38f2c0f6dd3b356f1354be481a62'
268},
269MonteTestCase{
270name: 'checkpoint 50'
271count: 50
272digest: '4df8eb71a1f46ab35861dfcaccb723d372dfe58af9c036e5079f70661a419c85'
273},
274MonteTestCase{
275name: 'checkpoint 51'
276count: 51
277digest: '503fd9149292f8e65f5a59db63dc8305e527f7e70e9cdc282b9d5075f23f92c9'
278},
279MonteTestCase{
280name: 'checkpoint 52'
281count: 52
282digest: '904c87a50b6383843b48cf9ce2a17c945b45c516fb0efa9eed88015fd10bb0dc'
283},
284MonteTestCase{
285name: 'checkpoint 53'
286count: 53
287digest: '888062fa782842258cadec93b1bd624bfe392500f5e6d6ef9e71b2963b73bb3a'
288},
289MonteTestCase{
290name: 'checkpoint 54'
291count: 54
292digest: '90c2a13524c81890be3f184cddb2feb44053de85335fb7933c6af8e3ee5d4ac4'
293},
294MonteTestCase{
295name: 'checkpoint 55'
296count: 55
297digest: '1efd7a3e6331c66b21c40416ce4f27d6aba8099359ad950b752e5491a156d9c8'
298},
299MonteTestCase{
300name: 'checkpoint 56'
301count: 56
302digest: '3f2a1f7bdda96ae3abe859e7767a0831ee69971b15d09d9385fac858643b0207'
303},
304MonteTestCase{
305name: 'checkpoint 57'
306count: 57
307digest: 'e021e5b9b812248cf5ea9563b84d753f5230cb1b442b04895871e3d8a7c6733e'
308},
309MonteTestCase{
310name: 'checkpoint 58'
311count: 58
312digest: 'a54312fe62b278b87bf440ff26703e280a13046071cfed2e23922e23ed7f8b17'
313},
314MonteTestCase{
315name: 'checkpoint 59'
316count: 59
317digest: '2b9906372367f7704556d4345602337c581917c3d91711466f4d27c8597c1628'
318},
319MonteTestCase{
320name: 'checkpoint 60'
321count: 60
322digest: 'd13e8e889226f72a1cfbb6d77a8cba9238900d148b4d0395e17415efc026a45f'
323},
324MonteTestCase{
325name: 'checkpoint 61'
326count: 61
327digest: '0977ad675ee02c46cc7523a4d617e5c8e69894efe0ad2d159b616eac65fdb68d'
328},
329MonteTestCase{
330name: 'checkpoint 62'
331count: 62
332digest: 'd34cd5081453b756bba9a455e0cabe97281fab2c6b5952a69171f8ed60bfb8d6'
333},
334MonteTestCase{
335name: 'checkpoint 63'
336count: 63
337digest: '720dc85f63580df35589802b1ee71cfa0522e92022382d875fd862bca3e64a19'
338},
339MonteTestCase{
340name: 'checkpoint 64'
341count: 64
342digest: '933991fa66485b36788447d2f0c8fd0f4d3d815f95a64fb197a1f66e7655ec3e'
343},
344MonteTestCase{
345name: 'checkpoint 65'
346count: 65
347digest: 'f80e89277c950a465d4b8a857efb1200dd7acf6b2dc4842bd6d3edeb1be232bd'
348},
349MonteTestCase{
350name: 'checkpoint 66'
351count: 66
352digest: 'c180da36f5e94ebc6a41747500728394cf2fbb06c003a14c9c977e20a6d98deb'
353},
354MonteTestCase{
355name: 'checkpoint 67'
356count: 67
357digest: '2d3e75cc7f37a6dee320001adc7e0d8811b87f532e126cbd99f13874cd149a80'
358},
359MonteTestCase{
360name: 'checkpoint 68'
361count: 68
362digest: '3edd7afe868f3876cfce54aeb22fb55475aa4df87015c1defed2fb41f13ee786'
363},
364MonteTestCase{
365name: 'checkpoint 69'
366count: 69
367digest: '7548c1cc9b96a65a918b37b4817825f32841bbc575ea8e6d12fd9d0c66ce8cd6'
368},
369MonteTestCase{
370name: 'checkpoint 70'
371count: 70
372digest: 'a0ea397e82b8c7639d3594199c517b8f42f5c3dc40d104b51a42b46eb891d1ac'
373},
374MonteTestCase{
375name: 'checkpoint 71'
376count: 71
377digest: '7fce4436abbf5da053cad07e8cf721c24442f926d4cc20cb8ac0a68b9d63b8b7'
378},
379MonteTestCase{
380name: 'checkpoint 72'
381count: 72
382digest: '48f93612a3689b8123fa234251e59a9784dc865dda43186e02a3fa10eac57732'
383},
384MonteTestCase{
385name: 'checkpoint 73'
386count: 73
387digest: 'f0c29f8e390435a2e233afa958ae208eb5d8eeb38e448df53a6d2e7a8e3a8266'
388},
389MonteTestCase{
390name: 'checkpoint 74'
391count: 74
392digest: 'fa43fb8ffa7d953a4da11627e11c51ba4f1cf0a62464b0e9d34cb9f1ca4a2339'
393},
394MonteTestCase{
395name: 'checkpoint 75'
396count: 75
397digest: '18a1c86b7c266b55b253f509e6457df10b48e6705bc0c78b638f9ee4eb937633'
398},
399MonteTestCase{
400name: 'checkpoint 76'
401count: 76
402digest: 'f5cd2b6b4a6bd0070942f81d012bdc85cf55c095075578a0404f2273908c20d2'
403},
404MonteTestCase{
405name: 'checkpoint 77'
406count: 77
407digest: 'b7825bba2320209852668a29f8b0eca4a3a0ad77e0e33cd2a7185761da5061b1'
408},
409MonteTestCase{
410name: 'checkpoint 78'
411count: 78
412digest: 'e7688883bbc0dbc767dd8d46ce58a0463f29d0781dfe1bde55a83ba9ca54b1b5'
413},
414MonteTestCase{
415name: 'checkpoint 79'
416count: 79
417digest: '54ba60a63f82f501435dd8a51d772404e5cfbddf226bcbc47836cf717fadb4e8'
418},
419MonteTestCase{
420name: 'checkpoint 80'
421count: 80
422digest: 'c533fff054d8dabfd37c4e860761d215954c7bf8f37ab6d6ef7ff9ec4713ea65'
423},
424MonteTestCase{
425name: 'checkpoint 81'
426count: 81
427digest: '71f36f26cb92c129f7450d76849a7f2f4bb0554e9ade0a9d5182f435541ca1fd'
428},
429MonteTestCase{
430name: 'checkpoint 82'
431count: 82
432digest: 'c39f5bfe6c241d0f64c13b05e5fb6725ffda3789ef9946c8af1dfcb424ba3d75'
433},
434MonteTestCase{
435name: 'checkpoint 83'
436count: 83
437digest: '27401de7cc0d86a8f07e276a9fbf4fe5cdf7b3d73802a5c7edd27b686f6f7039'
438},
439MonteTestCase{
440name: 'checkpoint 84'
441count: 84
442digest: 'bc56733b8682bab456b8c0819e1c9d6d3bb864b2427ec2a2003a871c44dc0246'
443},
444MonteTestCase{
445name: 'checkpoint 85'
446count: 85
447digest: 'e3843383a52a8c3d6315d255d1708467f5de61a5372308978b295460220d99aa'
448},
449MonteTestCase{
450name: 'checkpoint 86'
451count: 86
452digest: 'e03de5004325a1dc96eb709c849bb6ecadc5db9c6152aba480ca10c8fe2573e1'
453},
454MonteTestCase{
455name: 'checkpoint 87'
456count: 87
457digest: 'df09f2a9bceab29b5c149ec7db23b1c8b1cc849ff2612c4ad9d66e98cc1f1faa'
458},
459MonteTestCase{
460name: 'checkpoint 88'
461count: 88
462digest: '123426906e20a02fd517c4cee4e5f5273f894c56ae456ca466c7a0a2d1b0676c'
463},
464MonteTestCase{
465name: 'checkpoint 89'
466count: 89
467digest: '14a9e07e6280a8c7cf824cd1896ad974c310859eb1bb4bef59b715b25cfaaa30'
468},
469MonteTestCase{
470name: 'checkpoint 90'
471count: 90
472digest: 'ae7febea114679a52c9f7351aa0a207dc40ba8c8394585cc5a0b9bfc7f67d76a'
473},
474MonteTestCase{
475name: 'checkpoint 91'
476count: 91
477digest: '4966b9ba04ef0590cf0f335798c9b3e15ad32d5ebd2719a0c914c8faeed65326'
478},
479MonteTestCase{
480name: 'checkpoint 92'
481count: 92
482digest: '8ea5a43cdaf50149c3aef14cb2ff2db42279ca36267355a0e023f3ec2ea13375'
483},
484MonteTestCase{
485name: 'checkpoint 93'
486count: 93
487digest: '14ca6c157502aa86c4900086c373c5d2b8789e5cc9863a384938e498fdaa52e0'
488},
489MonteTestCase{
490name: 'checkpoint 94'
491count: 94
492digest: '8471a7d5a2cdc61a8bc885c1b0b79491a54d6610ab19a3cffbe0c83479628cb3'
493},
494MonteTestCase{
495name: 'checkpoint 95'
496count: 95
497digest: '51749feaa3f2ea9c89b38d77814ea2796a3265e4f6ee7a2c08a1804c6fbfe042'
498},
499MonteTestCase{
500name: 'checkpoint 96'
501count: 96
502digest: '8163861f1ca72bbc19cb8ce59bcee8a3d6d28c8ce17e33cea67f04277a68360a'
503},
504MonteTestCase{
505name: 'checkpoint 97'
506count: 97
507digest: '6c00f3fae370e7d14504c48cd7199064b3b4828163905af7b7a0593d2b5d06fd'
508},
509MonteTestCase{
510name: 'checkpoint 98'
511count: 98
512digest: '5fe007f269a854e2394874f1a95ef7ef3844cf06248deda3af561cfacaed1e35'
513},
514MonteTestCase{
515name: 'checkpoint 99'
516count: 99
517digest: '1822ede971ca1407fbcb1dff487ea9d93d71d756cdf32945703de673f4b3d816'
518},
519]
520
521fn test_monte_messages() {
522mut msg_seed := hex.decode(seed)!
523
524for c in monte_cases {
525mut md0 := msg_seed.clone()
526mut md1 := msg_seed.clone()
527mut md2 := msg_seed.clone()
528mut md3 := msg_seed.clone()
529
530mut mi := []u8{len: 0, cap: 64}
531
532for _ in 0 .. 1000 {
533mi.clear()
534mi << md0
535mi << md1
536mi << md2
537
538md3 = sha512.sum512_256(mi)
539
540md0 = md1.clone()
541md1 = md2.clone()
542md2 = md3.clone()
543}
544
545msg_seed = md3.clone()
546
547expected_result := hex.decode(c.digest)!
548
549assert md3 == expected_result, 'failed ${c.name}'
550}
551}
552