Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(119)

Side by Side Diff: LayoutTests/crypto/clone-hmacKey.html

Issue 195543002: [webcrypto] Implement structured clone of keys (blink-side). (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: fix another comment Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <script src="../resources/js-test.js"></script>
5 <script src="resources/common.js"></script>
6 </head>
7 <body>
8 <p id="description"></p>
9 <div id="console"></div>
10
11 <script>
12 description("Tests structured cloning of HMAC keys");
13
14 jsTestIsAsync = true;
15
16 // Tests the 48 permutations of keys generated by:
17 // kPossibleHashAlgorithms x kPossibleExtractable x kPossibleKeyUsages x kPoss ibleKeyData
18 //
19 // For practical reasons these tests are not exhaustive.
20
21 var k128BitData = "30112233445566778899aabbccddeeff"
22 var k256BitData = "00112233445546778899aabbccddeeff000102030405060708090a0b0c0d0 e0f";
23
24 var kPossibleHashAlgorithms = ['SHA-1', 'SHA-256', 'SHA-512'];
25 var kPossibleExtractable = [true, false];
26 var kPossibleKeyUsages = [[], ['sign'], ['verify'], ['sign', 'verify']];
27 var kPossibleKeyData = [k128BitData, k256BitData];
28
29 function runTest(hashName, extractable, keyUsages, keyData)
30 {
31 return crypto.subtle.importKey('raw', hexStringToUint8Array(keyData), { name : 'HMAC', hash: {name: hashName }},
32 extractable, keyUsages).then(function(result) {
33 importedKey = result;
34
35 shouldBe("importedKey.type", evalWrap("secret"));
36 shouldBe("importedKey.extractable", evalWrap(extractable));
37 shouldBe("importedKey.algorithm.name", evalWrap("HMAC"));
38 shouldBe("importedKey.algorithm.hash.name", evalWrap(hashName));
39 shouldBe("importedKey.usages.join(',')", evalWrap(keyUsages.join(",")));
40
41 clonedKey = cloneKeyAndLog(importedKey);
42
43 shouldBe("clonedKey.type", evalWrap("secret"));
44 shouldBe("clonedKey.extractable", evalWrap(extractable));
45 shouldBe("clonedKey.algorithm.name", evalWrap("HMAC"));
46 shouldBe("clonedKey.algorithm.hash.name", evalWrap(hashName));
47 shouldBe("clonedKey.usages.join(',')", evalWrap(keyUsages.join(",")));
48
49 // Check the key bytes.
50 if (extractable) {
51 return crypto.subtle.exportKey('raw', clonedKey).then(function(resul t) {
52 bytesShouldMatchHexString("cloned key data", keyData, result);
53 });
54 }
55 });
56 }
57
58 for (var algorithmIndex = 0; algorithmIndex < kPossibleHashAlgorithms.length; ++ algorithmIndex) {
59 for (var extractableIndex = 0; extractableIndex < kPossibleExtractable.lengt h; ++extractableIndex) {
60 for (var usagesIndex = 0; usagesIndex < kPossibleKeyUsages.length; ++usa gesIndex) {
61 for (var dataIndex = 0; dataIndex < kPossibleKeyData.length; ++dataI ndex) {
62 var hashName = kPossibleHashAlgorithms[algorithmIndex];
63 var extractable = kPossibleExtractable[extractableIndex];
64 var keyUsages = kPossibleKeyUsages[usagesIndex];
65 var keyData = kPossibleKeyData[dataIndex];
66
67 addTask(runTest(hashName, extractable, keyUsages, keyData));
68 }
69 }
70 }
71 }
72
73 completeTestWhenAllTasksDone();
74
75 </script>
76
77 </body>
78 </html>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698