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 the digest() method using ArrayBuffer"); | 12 description("Tests the digest() method using ArrayBuffer, with a memory allocati on failure."); |
13 | 13 |
14 jsTestIsAsync = true; | 14 jsTestIsAsync = true; |
15 | 15 |
16 var algorithmName = "sha-256"; | 16 var algorithmName = "sha-256"; |
17 var inputHex = "00"; | 17 var inputHex = "00"; |
18 var expectedOutputHex = "6e340b9cffb37a989ca544e6bb780a2c78901d3fb33738768511a30 617afa01d"; | 18 var expectedOutputHex = "6e340b9cffb37a989ca544e6bb780a2c78901d3fb33738768511a30 617afa01d"; |
19 | 19 |
20 // Most of the crypto LayouTests use ArrayBufferView for data input. This one | |
21 // passes an ArrayBuffer instead. | |
22 var input = hexStringToUint8Array(inputHex).buffer; | 20 var input = hexStringToUint8Array(inputHex).buffer; |
23 | 21 |
24 crypto.subtle.digest({name : algorithmName}, input).then(function(result) { | 22 if (window.internals) { |
25 bytesShouldMatchHexString("sha-256 of [0]", expectedOutputHex, result); | 23 internals.fakeOutOfMemoryForNextArrayBufferAllocation(); |
Stephen White
2015/10/29 16:29:52
Nice!
| |
26 }).then(finishJSTest, failAndFinishJSTest); | 24 // Test succeeds if promise is rejected. |
25 crypto.subtle.digest({name : algorithmName}, input).then(failAndFinishJSTest , finishJSTest); | |
26 } | |
27 | 27 |
28 </script> | 28 </script> |
29 | 29 |
30 </body> | 30 </body> |
31 </html> | 31 </html> |
OLD | NEW |