OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <html> | 2 <html> |
3 <head> | 3 <head> |
4 <script src="../resources/js-test.js"></script> | 4 <script src="../resources/js-test.js"></script> |
5 <script src="resources/common.js"></script> | 5 <script src="resources/common.js"></script> |
6 </head> | 6 </head> |
7 <body> | 7 <body> |
8 <p id="description"></p> | 8 <p id="description"></p> |
9 <div id="console"></div> | 9 <div id="console"></div> |
10 | 10 |
11 <script> | 11 <script> |
12 description("Test error handling for JWK import."); | 12 description("Test error handling for JWK import."); |
13 | 13 |
14 jsTestIsAsync = true; | 14 jsTestIsAsync = true; |
15 | 15 |
16 var extractable = true; | 16 var extractable = true; |
17 var nonExtractable = false; | 17 var nonExtractable = false; |
18 | 18 |
19 var hmac256 = {name: "HMAC", hash: {name: "sha-256"}}; | 19 var hmac256 = {name: "HMAC", hash: {name: "sha-256"}}; |
20 | 20 |
21 Promise.resolve(null).then(function(result) { | 21 Promise.resolve(null).then(function(result) { |
22 return crypto.subtle.importKey("jwk", asciiToUint8Array(''), {name: "aes-cbc
"}, extractable, []); | 22 return crypto.subtle.importKey("jwk", null, {name: "aes-cbc"}, extractable,
[]); |
23 }).then(failAndFinishJSTest, function(result) { | 23 }).then(failAndFinishJSTest, function(result) { |
24 logError(result); | 24 logError(result); |
25 return crypto.subtle.importKey("jwk", asciiToUint8Array('{'), {name: "aes-cb
c"}, extractable, []); | 25 return crypto.subtle.importKey("jwk", undefined, {name: "aes-cbc"}, extracta
ble, []); |
26 }).then(failAndFinishJSTest, function(result) { | 26 }).then(failAndFinishJSTest, function(result) { |
27 logError(result); | 27 logError(result); |
28 return crypto.subtle.importKey("jwk", asciiToUint8Array('null'), {name: "aes
-cbc"}, extractable, []); | 28 return crypto.subtle.importKey("jwk", {}, {name: "aes-cbc"}, extractable, []
); |
29 }).then(failAndFinishJSTest, function(result) { | |
30 logError(result); | |
31 return crypto.subtle.importKey("jwk", asciiToUint8Array('undefined'), {name:
"aes-cbc"}, extractable, []); | |
32 }).then(failAndFinishJSTest, function(result) { | |
33 logError(result); | |
34 return crypto.subtle.importKey("jwk", asciiToUint8Array('{}'), {name: "aes-c
bc"}, extractable, []); | |
35 }).then(failAndFinishJSTest, function(result) { | 29 }).then(failAndFinishJSTest, function(result) { |
36 logError(result); | 30 logError(result); |
37 // Unknown/invalid JWK values. | 31 // Unknown/invalid JWK values. |
38 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "foobar",
"alg": "HS256", "use": "sig", "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs"
}'), hmac256, extractable, []); | 32 return crypto.subtle.importKey("jwk", { "kty": "foobar", "alg": "HS256", "us
e": "sig", "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, hmac256, extrac
table, []); |
39 }).then(failAndFinishJSTest, function(result) { | 33 }).then(failAndFinishJSTest, function(result) { |
40 logError(result); | 34 logError(result); |
41 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "foobar", "use": "sig", "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }
'), {name: "aes-cbc"}, extractable, []); | 35 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "foobar", "use"
: "sig", "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, {name: "aes-cbc"}
, extractable, []); |
42 }).then(failAndFinishJSTest, function(result) { | 36 }).then(failAndFinishJSTest, function(result) { |
43 logError(result); | 37 logError(result); |
44 // Algorithm mismatch. | 38 // Algorithm mismatch. |
45 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "HS256", "use": "sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387f
gnsibf23qs" }'), {name: "AES-cbc"}, nonExtractable, []); | 39 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "HS256", "use":
"sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, {nam
e: "AES-cbc"}, nonExtractable, []); |
46 }).then(failAndFinishJSTest, function(result) { | 40 }).then(failAndFinishJSTest, function(result) { |
47 logError(result); | 41 logError(result); |
48 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "HS256", "use": "sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387f
gnsibf23qs" }'), { name: "hmac", hash: {name: "sha-1"} }, nonExtractable, []); | 42 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "HS256", "use":
"sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, { na
me: "hmac", hash: {name: "sha-1"} }, nonExtractable, []); |
49 }).then(failAndFinishJSTest, function(result) { | 43 }).then(failAndFinishJSTest, function(result) { |
50 logError(result); | 44 logError(result); |
51 // No key data. | 45 // No key data. |
52 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "HS256" }'), hmac256, extractable, []); | 46 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "HS256" }, hmac
256, extractable, []); |
53 }).then(failAndFinishJSTest, function(result) { | 47 }).then(failAndFinishJSTest, function(result) { |
54 logError(result); | 48 logError(result); |
55 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "A128CBC" }'), {name: "aes-cbc"}, extractable, []); | 49 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "A128CBC" }, {n
ame: "aes-cbc"}, extractable, []); |
56 }).then(failAndFinishJSTest, function(result) { | 50 }).then(failAndFinishJSTest, function(result) { |
57 logError(result); | 51 logError(result); |
58 // FIXME: http://crbug.com/378037 | 52 // FIXME: http://crbug.com/378037 |
59 // Key data length is incorrect, not allowed in JWK. | 53 // Key data length is incorrect, not allowed in JWK. |
60 // return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct",
"alg": "HS256", "use": "sig", "ext": false, "k": "1234" }'), hmac256, nonExtract
able, []); | 54 // return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct",
"alg": "HS256", "use": "sig", "ext": false, "k": "1234" }'), hmac256, nonExtract
able, []); |
61 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "A128CBC", "use": "sig", "ext": false, "k": "1234" }'), {name: "aes-cbc"}, n
onExtractable, []); | 55 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "A128CBC", "use
": "sig", "ext": false, "k": "1234" }, {name: "aes-cbc"}, nonExtractable, []); |
62 }).then(failAndFinishJSTest, function(result) { | 56 }).then(failAndFinishJSTest, function(result) { |
63 logError(result); | 57 logError(result); |
64 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "A128CBC", "use": "sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn3738
7fgnsibf23qs" }'), {name: "aes-cbc"}, nonExtractable, []); | 58 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "A128CBC", "use
": "sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, {n
ame: "aes-cbc"}, nonExtractable, []); |
65 }).then(failAndFinishJSTest, function(result) { | 59 }).then(failAndFinishJSTest, function(result) { |
66 logError(result); | 60 logError(result); |
67 // Key data is not valid base64url. | 61 // Key data is not valid base64url. |
68 // FIXME: http://crbug.com/378034 | 62 // FIXME: http://crbug.com/378034 |
69 // return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct",
"alg": "HS256", "use": "sig", "ext": false, "k": "ahjkn23387f+nsibf23qsvahjkn373
87fgnsibf23qs" }'), hmac256, nonExtractable, []); | 63 // return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct",
"alg": "HS256", "use": "sig", "ext": false, "k": "ahjkn23387f+nsibf23qsvahjkn373
87fgnsibf23qs" }'), hmac256, nonExtractable, []); |
70 | 64 |
71 // Incorrect data types. | 65 // Incorrect data types. |
72 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": 1, "alg":
"HS256", "use": "sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsi
bf23qs" }'), hmac256, nonExtractable, []); | 66 return crypto.subtle.importKey("jwk", { "kty": 1, "alg": "HS256", "use": "si
g", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, hmac256,
nonExtractable, []); |
73 }).then(failAndFinishJSTest, function(result) { | 67 }).then(failAndFinishJSTest, function(result) { |
74 logError(result); | 68 logError(result); |
75 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": 1, "use": "sig", "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf
23qs" }'), {name: "aes-cbc"}, nonExtractable, []); | 69 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": 1, "use": "sig"
, "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, {name: "ae
s-cbc"}, nonExtractable, []); |
76 }).then(failAndFinishJSTest, function(result) { | 70 }).then(failAndFinishJSTest, function(result) { |
77 logError(result); | 71 logError(result); |
78 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "HS256", "use": 1, "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsi
bf23qs" }'), hmac256, nonExtractable, []); | 72 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "HS256", "use":
1, "ext": false, "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, hmac256,
nonExtractable, []); |
79 }).then(failAndFinishJSTest, function(result) { | 73 }).then(failAndFinishJSTest, function(result) { |
80 logError(result); | 74 logError(result); |
81 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "HS256", "use": "sig", "ext": "false", "k": "ahjkn23387fgnsibf23qsvahjkn3738
7fgnsibf23qs" }'), hmac256, nonExtractable, []); | 75 // ext is recognized as a boolean even though it is a string. |
82 }).then(failAndFinishJSTest, function(result) { | 76 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "HS256", "use":
"sig", "ext": "false", "k": "ahjkn23387fgnsibf23qsvahjkn37387fgnsibf23qs" }, hm
ac256, nonExtractable, []); |
83 logError(result); | 77 }).then(function(result) { |
84 return crypto.subtle.importKey("jwk", asciiToUint8Array('{ "kty": "oct", "al
g": "HS256", "use": "sig", "ext": false, "k": 1 }'), hmac256, nonExtractable, []
); | 78 debug("Boolean JWK property passed as a string and worked"); |
85 }).then(failAndFinishJSTest, function(result) { | 79 // k is recognized as a string even though it is a number. |
86 logError(result); | 80 return crypto.subtle.importKey("jwk", { "kty": "oct", "alg": "HS256", "use":
"sig", "ext": false, "k": 1258 }, hmac256, nonExtractable, []); |
| 81 }).then(function(result) { |
| 82 debug("String JWK property passed as a number and worked"); |
87 }).then(finishJSTest, failAndFinishJSTest); | 83 }).then(finishJSTest, failAndFinishJSTest); |
88 </script> | 84 </script> |
89 | 85 |
90 </body> | 86 </body> |
91 </html> | 87 </html> |
OLD | NEW |