OLD | NEW |
(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("Test exporting a public EC key."); |
| 13 |
| 14 jsTestIsAsync = true; |
| 15 |
| 16 var extractable = true; |
| 17 |
| 18 var publicKeySpkiHex = "3059301306072A8648CE3D020106082A8648CE3D030107034200049C
B0CF69303DAFC761D4E4687B4ECF039E6D34AB964AF80810D8D558A4A8D6F72D51233A1788920A86
EE08A1962C79EFA317FB7879E297DAD2146DB995FA1C78"; |
| 19 |
| 20 debug("\nImporting a SPKI key..."); |
| 21 crypto.subtle.importKey("spki", hexStringToUint8Array(publicKeySpkiHex), {name:
"ECDSA", namedCurve: "P-256"}, extractable, ['verify']).then(function(result) { |
| 22 key = result; |
| 23 |
| 24 debug("\nExporting the key as JWK..."); |
| 25 return crypto.subtle.exportKey("jwk", key); |
| 26 }).then(function(result) { |
| 27 exportedJWK = result; |
| 28 |
| 29 shouldEvaluateAs("exportedJWK.kty", "EC"); |
| 30 shouldEvaluateAs("exportedJWK.crv", "P-256"); |
| 31 shouldEvaluateAs("exportedJWK.x", "nLDPaTA9r8dh1ORoe07PA55tNKuWSvgIENjVWKSo1
vc"); |
| 32 shouldEvaluateAs("exportedJWK.y", "LVEjOheIkgqG7gihlix576MX-3h54pfa0hRtuZX6H
Hg"); |
| 33 shouldBe("exportedJWK.alg", "undefined"); |
| 34 shouldBe("exportedJWK.ext", "true"); |
| 35 shouldBe("exportedJWK.key_ops", "['verify']"); |
| 36 shouldBe("exportedJWK.use", "undefined"); |
| 37 |
| 38 debug("\nExporting the key as SPKI..."); |
| 39 return crypto.subtle.exportKey("spki", key); |
| 40 }).then(function(result) { |
| 41 exportedSpki = result; |
| 42 |
| 43 bytesShouldMatchHexString("exportedSpki", publicKeySpkiHex, exportedSpki); |
| 44 }).then(finishJSTest, failAndFinishJSTest); |
| 45 |
| 46 </script> |
| 47 |
| 48 </body> |
| 49 </html> |
OLD | NEW |