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_224, the test vectors come from:
6// SHA512_224Monte.rsp
7import crypto.sha512
8import encoding.hex
9
10const seed = '2e325bf8c98c0be54493d04c329e706343aebe4968fdd33b37da9c0a'
11
12struct MonteTestCase {
13name string
14count int
15digest string
16}
17
18const monte_cases = [
19MonteTestCase{
20name: 'checkpoint 0'
21count: 0
22digest: '9ee006873962aa0842d636c759646a4ef4b65bcbebcc35430b20f7f4'
23},
24MonteTestCase{
25name: 'checkpoint 1'
26count: 1
27digest: '87726eda4570734b396f4c253146ecb9770b8591739240f02a4f2a02'
28},
29MonteTestCase{
30name: 'checkpoint 2'
31count: 2
32digest: '7be0871653db5fa514b4ec1a0363df004657155575b0383bc9fdec35'
33},
34MonteTestCase{
35name: 'checkpoint 3'
36count: 3
37digest: '7a794a3a1ae255e67ffbf688a05b6aba7f231cebec64b4fc75092d49'
38},
39MonteTestCase{
40name: 'checkpoint 4'
41count: 4
42digest: 'aaf5d4ecaf9426149821b15821b41c49e3900c0fc91664fb294216ea'
43},
44MonteTestCase{
45name: 'checkpoint 5'
46count: 5
47digest: '60f6ff2fbffc9151f67c7e9325e27706f9904d1d55311bb587c183c7'
48},
49MonteTestCase{
50name: 'checkpoint 6'
51count: 6
52digest: 'c6e46e63fd0b37a7fd460f724315796a6be5dcfd047907acc0512278'
53},
54MonteTestCase{
55name: 'checkpoint 7'
56count: 7
57digest: '1c9dd92b35f00ea3cd13bcdef3c99e73fd604fe167d4a23ba1aec8eb'
58},
59MonteTestCase{
60name: 'checkpoint 8'
61count: 8
62digest: '3ebec6bbf913b0eee0cc8aec7f9611648432674551fc3f1e01520dd8'
63},
64MonteTestCase{
65name: 'checkpoint 9'
66count: 9
67digest: 'b09556d256b3de7b122096a7a2a8c1d2ffcb23a9bfc38bb1d919739a'
68},
69MonteTestCase{
70name: 'checkpoint 10'
71count: 10
72digest: '756dd96518eff331dc48e2af06c6f2a92831d49bef28af687d0c3912'
73},
74MonteTestCase{
75name: 'checkpoint 11'
76count: 11
77digest: '08ef4f1cfe5b707ff57218240f5c02e75cc875e6585fc17fd60d3af7'
78},
79MonteTestCase{
80name: 'checkpoint 12'
81count: 12
82digest: '6f956e415d7c29d8073d6e5f89d9288215988db029b86183af622de5'
83},
84MonteTestCase{
85name: 'checkpoint 13'
86count: 13
87digest: 'a39947509d4a45d39837f785b2205a2fb4ab184fc40c88ec8dd7fe7b'
88},
89MonteTestCase{
90name: 'checkpoint 14'
91count: 14
92digest: 'c7b53227a32fc6e03f300ec56bc4505f03bad3d66a39940e1670b62f'
93},
94MonteTestCase{
95name: 'checkpoint 15'
96count: 15
97digest: 'b61a60ea4173d714cbcccff0dfef932f9d719175d5747ebca2b55b09'
98},
99MonteTestCase{
100name: 'checkpoint 16'
101count: 16
102digest: 'ee2c5fc1649e4033884ddbf3c2d93fe3ec9e8e8171df0cd94b438613'
103},
104MonteTestCase{
105name: 'checkpoint 17'
106count: 17
107digest: 'a333fbe4ea8dc682f8dc5e96cc2365ec2510b96d8e6bffdec1324b41'
108},
109MonteTestCase{
110name: 'checkpoint 18'
111count: 18
112digest: '5ae36caae04f3426a6b8da72d16b261b79ddef7e94a5ac2c601a40cd'
113},
114MonteTestCase{
115name: 'checkpoint 19'
116count: 19
117digest: '0d13a738747e8a15dc02e26338ad47a556afb4af033874de50e31a39'
118},
119MonteTestCase{
120name: 'checkpoint 20'
121count: 20
122digest: '4fd90174f249e11b99e7eb63ebca5e06f8f1f78efee855b71545ef5d'
123},
124MonteTestCase{
125name: 'checkpoint 21'
126count: 21
127digest: '02a47cd22538f44db8e2b0f769cf8fe2c0528dac2f47e53740fa7384'
128},
129MonteTestCase{
130name: 'checkpoint 22'
131count: 22
132digest: '75ceb64019f21eecef34741b96e2dd57eb261b24d65fcd1a409210ce'
133},
134MonteTestCase{
135name: 'checkpoint 23'
136count: 23
137digest: '4ffe012bc77387dd23c521ece6686e67c8584f308f5f62adc46715c8'
138},
139MonteTestCase{
140name: 'checkpoint 24'
141count: 24
142digest: 'c1b12961b27395bd2d309b5e6a20451411bd3986d992bb83b30b92d5'
143},
144MonteTestCase{
145name: 'checkpoint 25'
146count: 25
147digest: '0547c463bf3aeac722005c48d45e008f09c33551f1cfdd85b8d67dec'
148},
149MonteTestCase{
150name: 'checkpoint 26'
151count: 26
152digest: '8704119b4a6f7fd8ac25bc1ad72c1d573106a0af5dad3c8b7563c742'
153},
154MonteTestCase{
155name: 'checkpoint 27'
156count: 27
157digest: '877f5024aa6fa131e4660a8c7dd19bc80ce77c784b01ad79a5528fbb'
158},
159MonteTestCase{
160name: 'checkpoint 28'
161count: 28
162digest: '15750a559a4aed2925d280671b75d34e3a5b080259143f7b671e0e5e'
163},
164MonteTestCase{
165name: 'checkpoint 29'
166count: 29
167digest: 'deb48a5c402f539d0a0a62d81928debf78519cbeaebce1a29f203b06'
168},
169MonteTestCase{
170name: 'checkpoint 30'
171count: 30
172digest: '19af4d392fecc6a03f443f8aeb8e59a5496ca3b75481771b3efe45f9'
173},
174MonteTestCase{
175name: 'checkpoint 31'
176count: 31
177digest: 'd7e0d727fea61dae8f2c92fe884f2cd939ab2737f6bbf4545aa27e67'
178},
179MonteTestCase{
180name: 'checkpoint 32'
181count: 32
182digest: 'c8b6e303d2c654a5f330209502ac89adf9840a6c832a356095c98b70'
183},
184MonteTestCase{
185name: 'checkpoint 33'
186count: 33
187digest: 'bbc6d0112d60da2975d2028cf3c6b9509aed404f378540235199456c'
188},
189MonteTestCase{
190name: 'checkpoint 34'
191count: 34
192digest: 'b8bec3ad04591295081ef9484df499d4659ee1cfbd74b11033fa3d27'
193},
194MonteTestCase{
195name: 'checkpoint 35'
196count: 35
197digest: 'e6f5a285cdc65b24496c1b5040fd354b7abbc930128e6c750fe72ef8'
198},
199MonteTestCase{
200name: 'checkpoint 36'
201count: 36
202digest: 'af77e2ccd33403b22954796a071da760f7c27fd998e9aaa38126172a'
203},
204MonteTestCase{
205name: 'checkpoint 37'
206count: 37
207digest: 'de0e347e717e3331a73fc27c4d0a6f4adae82de2c70c701a6d5ab2b3'
208},
209MonteTestCase{
210name: 'checkpoint 38'
211count: 38
212digest: '00397993b6b0ab272be84263167167270c45df00483b01fe9b1ea365'
213},
214MonteTestCase{
215name: 'checkpoint 39'
216count: 39
217digest: '9a95e0f3e52e822552ff16c701d3541674de4cf183b6f30c43154bcd'
218},
219MonteTestCase{
220name: 'checkpoint 40'
221count: 40
222digest: '6a9d0c77cc592b625be5896b41e5dfc10a28ebbfdf688c84b525e0ca'
223},
224MonteTestCase{
225name: 'checkpoint 41'
226count: 41
227digest: '39b8102119ff29ab458d92c691bad39cad3e3a9bd08a6d051b9e8603'
228},
229MonteTestCase{
230name: 'checkpoint 42'
231count: 42
232digest: '49aad2c03b7c4d3dcf8356325fe6c43705731341697290c824f9eacf'
233},
234MonteTestCase{
235name: 'checkpoint 43'
236count: 43
237digest: 'fe4e83590811ce54caa352e52829268532a20b1a38d069ad99fa9a41'
238},
239MonteTestCase{
240name: 'checkpoint 44'
241count: 44
242digest: 'eeba13d3177da1b2b6877cdbb8ba32e0886b94bae893a9a062af4d4d'
243},
244MonteTestCase{
245name: 'checkpoint 45'
246count: 45
247digest: 'edd2d2365300c6a904526ad7106ee74d75bcbb9634c97f3fec57fc48'
248},
249MonteTestCase{
250name: 'checkpoint 46'
251count: 46
252digest: '46bd3b5289ff2278b2d1d652c9294f31415dda38694fce83fdd25f15'
253},
254MonteTestCase{
255name: 'checkpoint 47'
256count: 47
257digest: '1e1059e7089fa33e23fc1572b08131c7600ac8a1bbe583b6a4c6e09e'
258},
259MonteTestCase{
260name: 'checkpoint 48'
261count: 48
262digest: 'cd70a5e3d6ba8281c5ecc468dd7e96bb3d7723754d2cdc19e8a6063d'
263},
264MonteTestCase{
265name: 'checkpoint 49'
266count: 49
267digest: 'cb46f0380d1db1b1bec9b70d51c29d1300c5c814a4b360a0db548363'
268},
269MonteTestCase{
270name: 'checkpoint 50'
271count: 50
272digest: '76b467577856973eab224e2ecd0689601446c7915f6805e93276a4bc'
273},
274MonteTestCase{
275name: 'checkpoint 51'
276count: 51
277digest: '3f4d4db5e47d20c7458a87c5029eb340c4b639ebd3b6f1fca9c20427'
278},
279MonteTestCase{
280name: 'checkpoint 52'
281count: 52
282digest: 'f8fff1c83b456dd8ce96aa977a7a1b968c1a5bd4f2cb6e0ff80aa923'
283},
284MonteTestCase{
285name: 'checkpoint 53'
286count: 53
287digest: 'f88800640deb5328d0a6985474a041be43c7248609fa97ea0b9236cb'
288},
289MonteTestCase{
290name: 'checkpoint 54'
291count: 54
292digest: 'a071d9e4da86be8c17bbbbcf47a863ceea303bf02bb872565f829bdf'
293},
294MonteTestCase{
295name: 'checkpoint 55'
296count: 55
297digest: '19e399fc939c03fd3d016f69f77345580c1f8869b42c8231aea37027'
298},
299MonteTestCase{
300name: 'checkpoint 56'
301count: 56
302digest: '87f1884b3f78b9c962beef4e024e235fc9ca25c8667426fdcf18ee34'
303},
304MonteTestCase{
305name: 'checkpoint 57'
306count: 57
307digest: '6172fb88775686115c5d62e7b32affb353b40a41fe1ebfc603917274'
308},
309MonteTestCase{
310name: 'checkpoint 58'
311count: 58
312digest: 'df9e73edd801f9f457192f7d3aae4261dd89515200b028b27684d554'
313},
314MonteTestCase{
315name: 'checkpoint 59'
316count: 59
317digest: '3c5c668e1b085b7efb28c5413657b921c7db8cec6eb91177bc5fdb25'
318},
319MonteTestCase{
320name: 'checkpoint 60'
321count: 60
322digest: '2273fe0a482b701a54dc397ea93bbf73f7a8ce0fd891cf4bd7d0b9e0'
323},
324MonteTestCase{
325name: 'checkpoint 61'
326count: 61
327digest: 'bdfd8d50df97a02af4ba997e237f99d17503321f67cc5af8c3aadf2f'
328},
329MonteTestCase{
330name: 'checkpoint 62'
331count: 62
332digest: '24f6e6a0d54767dc5b33a46ca073d368cb3ec1b36fecc2672838a194'
333},
334MonteTestCase{
335name: 'checkpoint 63'
336count: 63
337digest: 'ea7672b36987befb16352c13231fb7668c75673a932bf880181765e4'
338},
339MonteTestCase{
340name: 'checkpoint 64'
341count: 64
342digest: 'e45da9a4f5c0dc38a2f7d2a30b0c8fe153584a56d80ce69e929a2784'
343},
344MonteTestCase{
345name: 'checkpoint 65'
346count: 65
347digest: '86983ba278254438244b1bf5ea59492ec36504a078530b6a7812f832'
348},
349MonteTestCase{
350name: 'checkpoint 66'
351count: 66
352digest: 'ad9c1161761135fff88c17963e86cdbc74ff1b1cfc4433fbc8d9efc1'
353},
354MonteTestCase{
355name: 'checkpoint 67'
356count: 67
357digest: '9af064cf4fa078b50835f283cee8ecb6ada36012ece1a8426a62342c'
358},
359MonteTestCase{
360name: 'checkpoint 68'
361count: 68
362digest: '046810fe8fb6826cc5b6b15eaa5e52f6b3679359ccdd773d6d3b638c'
363},
364MonteTestCase{
365name: 'checkpoint 69'
366count: 69
367digest: 'a5ecb35e74f484c8dfbf759ab4c0ab432aa2a9d7d75fdce80e556fb0'
368},
369MonteTestCase{
370name: 'checkpoint 70'
371count: 70
372digest: '5e1de1624a8111e59cb1955a4c2c4a2b54aa4df035679c0bdbaafc2d'
373},
374MonteTestCase{
375name: 'checkpoint 71'
376count: 71
377digest: '9b449c13d9633869261dfa842c63c82ee9ac71b392b1ab268d536917'
378},
379MonteTestCase{
380name: 'checkpoint 72'
381count: 72
382digest: '502270faa8397007684f76f331365a793e7a6cc8298dd9798229a515'
383},
384MonteTestCase{
385name: 'checkpoint 73'
386count: 73
387digest: '7e1fb43c7ffd08d08ca9a0cc5d5414f8e2b20cc3458a63ac00ab388d'
388},
389MonteTestCase{
390name: 'checkpoint 74'
391count: 74
392digest: 'b8694aa799471f785e33c6f8d5729f6c0db59f46d652cbacc923dd70'
393},
394MonteTestCase{
395name: 'checkpoint 75'
396count: 75
397digest: '6b431252c1f23628d7ec11656d52e8d6724100a6204e136bfc7ccd92'
398},
399MonteTestCase{
400name: 'checkpoint 76'
401count: 76
402digest: '357f7779dc289dd46231a46bdeabaf899b167984864d232410736505'
403},
404MonteTestCase{
405name: 'checkpoint 77'
406count: 77
407digest: '28cd0f7181f891e138c3cc43f14b7e826eff9dea465cdfe948d31d88'
408},
409MonteTestCase{
410name: 'checkpoint 78'
411count: 78
412digest: 'd3eefb1a85d7ade8278706aec0c0c2b889004ca386278fe466605d2d'
413},
414MonteTestCase{
415name: 'checkpoint 79'
416count: 79
417digest: 'bbcf4c4b31af3a6ea82d23907fe71bdaf5ae4db1446fe28fabf01145'
418},
419MonteTestCase{
420name: 'checkpoint 80'
421count: 80
422digest: '1f8354c43cb18715125c504ea1bff73e4e95c64fbc19e850468924a3'
423},
424MonteTestCase{
425name: 'checkpoint 81'
426count: 81
427digest: 'd3a57114d5572427096478d26162d7cebbbe6b99cb06234327b21ef9'
428},
429MonteTestCase{
430name: 'checkpoint 82'
431count: 82
432digest: '45b964bcdbde997f8b8de4a7617152a2f80b0333aeac6aa3e53901fd'
433},
434MonteTestCase{
435name: 'checkpoint 83'
436count: 83
437digest: '2fad09cb0e93263548120115972110979eec7ef94e303c462223005d'
438},
439MonteTestCase{
440name: 'checkpoint 84'
441count: 84
442digest: '6680932f0332b4c0ccb708d4bf351af23bb05b6fb8c36b458efa46f3'
443},
444MonteTestCase{
445name: 'checkpoint 85'
446count: 85
447digest: '1076a4637cc36c9f5c2fff3700362a9d62cda3596be7b5e7f244fff1'
448},
449MonteTestCase{
450name: 'checkpoint 86'
451count: 86
452digest: '0a819369c413d8d20195fa16660b320988357d63c1a94602eb117377'
453},
454MonteTestCase{
455name: 'checkpoint 87'
456count: 87
457digest: '397fcc30577bc5327a8cf9284cc64a02700f1b2f2d1ca8a1506b9916'
458},
459MonteTestCase{
460name: 'checkpoint 88'
461count: 88
462digest: '217be1548b8d99bb1080ea0f3995be3c6494c91235fbf3a6d854a08e'
463},
464MonteTestCase{
465name: 'checkpoint 89'
466count: 89
467digest: 'ddcc841fd03e9d942f886657b0feb522682979e836307f68f4f19843'
468},
469MonteTestCase{
470name: 'checkpoint 90'
471count: 90
472digest: '4a33efa590ee444c75b6a4530a0fedd9987661199ccded49e40bc8b0'
473},
474MonteTestCase{
475name: 'checkpoint 91'
476count: 91
477digest: '970a4a3334796b06cb0ba8014eca67bbc471dbcea0efbcb22c666b2e'
478},
479MonteTestCase{
480name: 'checkpoint 92'
481count: 92
482digest: 'a7630df9688bbc66ceac6ae4a3a549513e427f5dc0f55ad2696b021a'
483},
484MonteTestCase{
485name: 'checkpoint 93'
486count: 93
487digest: 'd63c202d5feab56898d8eb793115a8ac216ea1b163a967eb119367fc'
488},
489MonteTestCase{
490name: 'checkpoint 94'
491count: 94
492digest: '0dec4d35fa7737c2d93d901a0556ce3cb357224d3caa25dec8095a05'
493},
494MonteTestCase{
495name: 'checkpoint 95'
496count: 95
497digest: 'c40b609646eef457dea98eb32f45ee1f0af31658d742680bdb784f53'
498},
499MonteTestCase{
500name: 'checkpoint 96'
501count: 96
502digest: '1b2a12a3bc4403a1bebfc1358cb2844c56215ae413ed6df10fe2f8d3'
503},
504MonteTestCase{
505name: 'checkpoint 97'
506count: 97
507digest: '8342cbc0b0e8c270134a7907448037e07201150f0891b20dcf20867c'
508},
509MonteTestCase{
510name: 'checkpoint 98'
511count: 98
512digest: 'a09ed66100b982070edecb5af45ac354759778134098ca3c0bf67b05'
513},
514MonteTestCase{
515name: 'checkpoint 99'
516count: 99
517digest: '5d8fc89761e82efe7188596a52eb43efd9492038bbc47bc0df5e9843'
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_224(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