<!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>