3a48e79a1b116b40e54c186d4ff069cd3bc10f1b
[WebKit-https.git] / LayoutTests / crypto / subtle / aes-kw-wrap-unwrap-aes.html
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <script src="../../resources/js-test-pre.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("Test wrapping and unwrapping keys with AES-KW.");
13
14 jsTestIsAsync = true;
15
16 var kekData = hexStringToUint8Array("000102030405060708090A0B0C0D0E0F");
17 var keyData = hexStringToUint8Array("00112233445566778899AABBCCDDEEFF");
18 var extractable = true;
19
20 debug("Importing key encryption key...");
21 crypto.subtle.importKey("raw", kekData, "aes-kw", extractable, ["wrapKey", "unwrapKey"]).then(function(result) {
22     kek = result;
23
24     debug("Importing a key to be wrapped...");
25     return crypto.subtle.importKey("raw", keyData, "aes-cbc", extractable, ["encrypt", "decrypt", "wrapKey", "unwrapKey"]);
26 }).then(function(result) {
27     key = result;
28
29     debug("Wrapping it...");
30     return crypto.subtle.wrapKey("raw", key, kek, "aes-kw");
31 }).then(function(result) {
32     wrappedKey = result;
33     shouldBe("bytesToHexString(wrappedKey)", "'1fa68b0a8112b447aef34bd8fb5a7b829d3e862371d2cfe5'"); // Result from RFC 3394.
34
35     debug("Unwrapping it...");
36     return crypto.subtle.unwrapKey("raw", wrappedKey, kek, "aes-kw", "aes-cbc", extractable, ["encrypt", "decrypt", "wrapKey", "unwrapKey"]);
37 }).then(function(result) {
38     unwrappedKey = result;
39     shouldBe("unwrappedKey.toString()", "'[object Key]'");
40     shouldBe("unwrappedKey.type", "'secret'");
41     shouldBe("unwrappedKey.extractable", "true");
42     shouldBe("unwrappedKey.algorithm.name", "'AES-CBC'");
43     shouldBe("unwrappedKey.algorithm.length", "128");
44     shouldBe("unwrappedKey.usages", "['encrypt', 'decrypt', 'wrapKey', 'unwrapKey']");
45
46     debug("Exporting it...");
47     return crypto.subtle.exportKey("raw", unwrappedKey);
48 }).then(function(result) {
49     unwrappedKeyData = result;
50     shouldBe("bytesToHexString(unwrappedKeyData)", "bytesToHexString(keyData)");
51
52     debug("\nWrapping it as JWK...");
53     return crypto.subtle.wrapKey("jwk", key, kek, "aes-kw");
54 }).then(function(result) {
55     wrappedKey = result;
56
57     debug("Unwrapping it...");
58     return crypto.subtle.unwrapKey("jwk", wrappedKey, kek, "aes-kw", "aes-cbc", extractable, ["encrypt", "decrypt", "wrapKey", "unwrapKey"]);
59 }).then(function(result) {
60     unwrappedKey = result;
61     shouldBe("unwrappedKey.toString()", "'[object Key]'");
62     shouldBe("unwrappedKey.type", "'secret'");
63     shouldBe("unwrappedKey.extractable", "true");
64     shouldBe("unwrappedKey.algorithm.name", "'AES-CBC'");
65     shouldBe("unwrappedKey.algorithm.length", "128");
66     shouldBe("unwrappedKey.usages", "['encrypt', 'decrypt', 'wrapKey', 'unwrapKey']");
67
68     debug("Exporting it...");
69     return crypto.subtle.exportKey("raw", unwrappedKey);
70 }).then(function(result) {
71     unwrappedKeyData = result;
72     shouldBe("bytesToHexString(unwrappedKeyData)", "bytesToHexString(keyData)");
73
74     finishJSTest();
75 });
76 </script>
77
78 <script src="../../resources/js-test-post.js"></script>
79 </body>
80 </html>