summaryrefslogtreecommitdiffstats
path: root/dom/crypto/test/test_WebCrypto_DH.html
blob: 06923d9da266308e735ee9891331eaeb5b5f1688 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<!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>

<!-- Utilities for manipulating ABVs -->
<script src="util.js"></script>

<!-- A simple wrapper around IndexedDB -->
<script src="simpledb.js"></script>

<!-- Test vectors drawn from the literature -->
<script src="./test-vectors.js"></script>

<!-- General testing framework -->
<script src="./test-array.js"></script>

<script>/* <![CDATA[*/
"use strict";
// DH is not permitted, so ensure all entry point methods error
// -----------------------------------------------------------------------------
TestArray.addTest(
  "Generate a DH key",
  function() {
    var that = this;
    var alg = {
      name: "DH",
      prime: tv.dh.prime,
      generator: new Uint8Array([0x02]),
    };
    crypto.subtle.generateKey(alg, false, ["deriveKey", "deriveBits"])
      .then(error(that), complete(that));
  }
);

// -----------------------------------------------------------------------------
TestArray.addTest(
  "Raw import/export of a public DH key",
  function() {
    var that = this;
    var alg = {
      name: "DH",
      prime: tv.dh_nist.prime,
      generator: tv.dh_nist.gen,
    };

    crypto.subtle.importKey("raw", tv.dh_nist.raw, alg, true, ["deriveBits"])
      .then(error(that), complete(that));
  }
);

// -----------------------------------------------------------------------------
TestArray.addTest(
  "SPKI import/export of a public DH key",
  function() {
    var that = this;

    crypto.subtle.importKey("spki", tv.dh_nist.spki, "DH", true, ["deriveBits"])
      .then(error(that), complete(that));
  }
);
/* ]]>*/</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>