120 lines
3.4 KiB
HTML
120 lines
3.4 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
|
|
<head>
|
|
<title>WebCrypto Test Suite</title>
|
|
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
|
|
<link rel="stylesheet" href="./test_WebCrypto.css"/>
|
|
<script src="/tests/SimpleTest/SimpleTest.js"></script>
|
|
|
|
<!-- General testing framework -->
|
|
<script src="./test-array.js"></script>
|
|
|
|
<script>/*<![CDATA[*/
|
|
"use strict";
|
|
|
|
// -----------------------------------------------------------------------------
|
|
TestArray.addTest(
|
|
"Import the same ECDSA key multiple times and ensure that it can be used.",
|
|
function () {
|
|
var alg = { name: "ECDSA", namedCurve: "P-256", hash: "SHA-256" };
|
|
crypto.subtle.generateKey(alg, true, ["sign", "verify"])
|
|
.then(function(keyPair) {
|
|
return crypto.subtle.exportKey("jwk", keyPair.privateKey);
|
|
})
|
|
.then(function(exportedKey) {
|
|
let keyImportPromises = [];
|
|
for (let i = 0; i < 20; i++) {
|
|
keyImportPromises.push(
|
|
crypto.subtle.importKey("jwk", exportedKey, alg, false, ["sign"]));
|
|
}
|
|
return Promise.all(keyImportPromises);
|
|
})
|
|
.then(function(importedKeys) {
|
|
let signPromises = [];
|
|
let data = crypto.getRandomValues(new Uint8Array(32));
|
|
for (let key of importedKeys) {
|
|
signPromises.push(crypto.subtle.sign(alg, key, data));
|
|
}
|
|
return Promise.all(signPromises);
|
|
})
|
|
.then(complete(this, function(signatures) {
|
|
return signatures.length == 20;
|
|
}), error(this));
|
|
}
|
|
);
|
|
|
|
// -----------------------------------------------------------------------------
|
|
// This is the same test, but with an RSA key. This test framework stringifies
|
|
// each test so it can be sent to and ran in a worker, which unfortunately
|
|
// means we can't factor out common code here.
|
|
TestArray.addTest(
|
|
"Import the same RSA key multiple times and ensure that it can be used.",
|
|
function () {
|
|
var alg = {
|
|
name: "RSASSA-PKCS1-v1_5",
|
|
modulusLength: 2048,
|
|
publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
|
|
hash: "SHA-256"
|
|
};
|
|
crypto.subtle.generateKey(alg, true, ["sign", "verify"])
|
|
.then(function(keyPair) {
|
|
return crypto.subtle.exportKey("jwk", keyPair.privateKey);
|
|
})
|
|
.then(function(exportedKey) {
|
|
let keyImportPromises = [];
|
|
for (let i = 0; i < 20; i++) {
|
|
keyImportPromises.push(
|
|
crypto.subtle.importKey("jwk", exportedKey, alg, false, ["sign"]));
|
|
}
|
|
return Promise.all(keyImportPromises);
|
|
})
|
|
.then(function(importedKeys) {
|
|
let signPromises = [];
|
|
let data = crypto.getRandomValues(new Uint8Array(32));
|
|
for (let key of importedKeys) {
|
|
signPromises.push(crypto.subtle.sign(alg, key, data));
|
|
}
|
|
return Promise.all(signPromises);
|
|
})
|
|
.then(complete(this, function(signatures) {
|
|
return signatures.length == 20;
|
|
}), error(this));
|
|
}
|
|
);
|
|
/*]]>*/</script>
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div id="content">
|
|
<div id="head">
|
|
<b>Web</b>Crypto<br>
|
|
</div>
|
|
|
|
<div id="start" onclick="start();">RUN ALL</div>
|
|
|
|
<div id="resultDiv" class="content">
|
|
Summary:
|
|
<span class="pass"><span id="passN">0</span> passed, </span>
|
|
<span class="fail"><span id="failN">0</span> failed, </span>
|
|
<span class="pending"><span id="pendingN">0</span> pending.</span>
|
|
<br/>
|
|
<br/>
|
|
|
|
<table id="results">
|
|
<tr>
|
|
<th>Test</th>
|
|
<th>Result</th>
|
|
<th>Time</th>
|
|
</tr>
|
|
</table>
|
|
|
|
</div>
|
|
|
|
<div id="foot"></div>
|
|
</div>
|
|
|
|
</body>
|
|
</html>
|