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("Tests generateKey() with bad ECDSA parameters."); | 12 description("Tests generateKey() with bad ECDSA parameters."); |
13 jsTestIsAsync = true; | 13 jsTestIsAsync = true; |
14 | 14 |
15 extractable = true; | 15 extractable = true; |
16 keyUsages = ['sign', 'verify']; | 16 keyUsages = ['sign', 'verify']; |
17 | 17 |
18 Promise.resolve(null).then(function() { | 18 Promise.resolve(null).then(function() { |
19 // Missing curve name. | 19 debug("\ngenerateKey() without namedCurve..."); |
20 return crypto.subtle.generateKey({name: 'ECDSA'}, extractable , keyUsages); | 20 return crypto.subtle.generateKey({name: 'ECDSA'}, extractable , keyUsages); |
21 }).then(failAndFinishJSTest, function(result) { | 21 }).then(failAndFinishJSTest, function(result) { |
22 logError(result); | 22 logError(result); |
23 | 23 |
24 // Named curve is invalid (an integer when it should be a string). | 24 debug("\ngenerateKey() with namedCurve that is an integer..."); |
25 return crypto.subtle.generateKey({name: 'ECDSA', namedCurve: -1}, extractabl
e , keyUsages); | 25 return crypto.subtle.generateKey({name: 'ECDSA', namedCurve: -1}, extractabl
e , keyUsages); |
26 }).then(failAndFinishJSTest, function(result) { | 26 }).then(failAndFinishJSTest, function(result) { |
27 logError(result); | 27 logError(result); |
28 | 28 |
29 // Named curve is unrecognized (lower case when it should be upper case) | 29 debug("\ngenerateKey() with namedCurve 'p-256' that contains lower case char
acter 'p'..."); |
30 return crypto.subtle.generateKey({name: 'ECDSA', namedCurve: 'p-256'}, extra
ctable , keyUsages); | 30 return crypto.subtle.generateKey({name: 'ECDSA', namedCurve: 'p-256'}, extra
ctable , keyUsages); |
31 }).then(failAndFinishJSTest, function(result) { | 31 }).then(failAndFinishJSTest, function(result) { |
32 logError(result); | 32 logError(result); |
33 | 33 |
34 // Named curve is unrecognized (contains some trailing characters). | 34 debug("\ngenerateKey() with namedCurve 'P-256aa' that contains trailing char
acters 'aa'..."); |
35 return crypto.subtle.generateKey({name: 'ECDSA', namedCurve: 'P-256aa'}, ext
ractable , keyUsages); | 35 return crypto.subtle.generateKey({name: 'ECDSA', namedCurve: 'P-256aa'}, ext
ractable , keyUsages); |
36 }).then(failAndFinishJSTest, function(result) { | 36 }).then(failAndFinishJSTest, function(result) { |
37 logError(result); | 37 logError(result); |
38 }).then(finishJSTest, failAndFinishJSTest); | 38 }).then(finishJSTest, failAndFinishJSTest); |
39 | 39 |
40 </script> | 40 </script> |
41 | 41 |
42 </body> | 42 </body> |
43 </html> | 43 </html> |
OLD | NEW |