Commit 7c079f7c authored by xun.sun@intel.com's avatar xun.sun@intel.com

Add Layouttest for importing keys with invalid usages

BUG=425651
R=eroman@chromium.org

Review URL: https://codereview.chromium.org/692763002

git-svn-id: svn://svn.chromium.org/blink/trunk@184849 bbb929c8-8fbe-4397-9dbb-9b2b20218538
parent 330219a3
......@@ -126,5 +126,25 @@ var kKeyData = {
"a223701701aa8370b90878df96a6950e3b3ed52326a5cabbf376c97aa644" +
"c50fafe38f7496fb9e69efdd138b3525d8b7ac162bd75fe84cb4ce7066d6" +
"b786e80c42d5e63059ae939c7bcfa497ed"
}
},
jwkRSAPublicKeyJSON : {
kty: "RSA",
alg: "RS1",
n: "rcCUCv7Oc1HVam1DIhCzqknThWawOp8QLk8Ziy2p10ByjQFCajoFiyuAWl-R1WXZaf4xitLRracT9agpzIzc-MbLSHIGgWQGO21lGiImy5ftZ-D8bHAqRz2y15pzD4c4CEou7XSSLDoRnR0QG5MsDhD6s2gV9mwHkrtkCxtMWdBi-77as8wGmlNRldcOSgZDLK8UnCSgA1OguZ989bFyc8tOOEIb0xUSfPSz3LPSCnyYz68aDjmKVeNH-ig857OScyWbGyEy3Biw64qun3juUlNWsJ3zngkOdteYWytx5Qr4XKNs6R-Myyq72KUp02mJDZiiyiglxML_i3-_CeecCw",
e: "AQAB"
},
jwkRSAPrivateKeyJSON : {
kty: "RSA",
alg: "RS1",
n: "rcCUCv7Oc1HVam1DIhCzqknThWawOp8QLk8Ziy2p10ByjQFCajoFiyuAWl-R1WXZaf4xitLRracT9agpzIzc-MbLSHIGgWQGO21lGiImy5ftZ-D8bHAqRz2y15pzD4c4CEou7XSSLDoRnR0QG5MsDhD6s2gV9mwHkrtkCxtMWdBi-77as8wGmlNRldcOSgZDLK8UnCSgA1OguZ989bFyc8tOOEIb0xUSfPSz3LPSCnyYz68aDjmKVeNH-ig857OScyWbGyEy3Biw64qun3juUlNWsJ3zngkOdteYWytx5Qr4XKNs6R-Myyq72KUp02mJDZiiyiglxML_i3-_CeecCw",
e: "AQAB",
d: "eNLS37aCz7RXSNPD_DtLBJ6j5T8cSxdzRBCjPaI6WcGqJp16lq3UTwuoDLAqlA9oGYm238dsIWpuucP_lQtbWe-7SpxoI6_vmYGf7YVUHv1-DF9qiOmSrMmdxMnVOzYXY8RaT6thPjn_J5cfLV2xI_LwsrMtmpdSyNlgX0zTUhwtuahgAKMEChYjH2EnjHdHw6sY2-wApdcQI7ULE0oo5RzbQZpmuhcN9hiBc0L3hhF0qo50mbl02_65_GQ7DpVkXBxNgRBLzlPabmzzG2oAhfefLgYmSC1opaCkXE6vRWQNWNL45RZNZFYM3uoJghOMqGeocM0BpjdChHrPOlFvSQ",
p: "4miTuAjKMeH5uJ5KB397QUwhbkYEgSbcA2mifmSkvE2018gb55qkBHK1eVryf1_m43LNlc6O_ak6gfzdZIZvS5NCGjPl0q09plUpu8qFOSspBwA67qGH76lFlZLn_d4yglS7wfLru4_5Ys8qLLs-DqVLviwposOnyyWqwM5AXp0",
q: "xHYrzkivtmnz_sGchnWGc0q-pDOkKicptRpv2pMFIIXxnFX5aMeEXIZjVujXtwUy1UlFIN2GZJSvy5KJ79mu_XyNnFHMzedH-A3ee3u8h1UUrZF-vUu1_e4U_x67NN1dedzUSKynN7pFl3OkuShMBWGV-cwzOPdcVAfVuZlxUMc",
dp: "fBzDzYDUBmBQGop7Hn0dvf_T27V6RqpctWo074CQZcFbP2atFVtKSj3viWT3xid2VHzcgiDHdfpM3nEVlEO1wwIonGCSvdjGEOZiiFVOjrZAOVxA8guOjyyFvqbXke06VwPIIVvfKeSU2zuhbP__1tt6F_fxow4Kb2xonGT0GGk",
dq: "jmE2DiIPdhwDgLXAQpIaBqQ81bO3XfVT_LRULAwwwwlPuQV148H04zlh9TJ6Y2GZHYokV1U0eOBpJxfkb7dLYtpJpuiBjRf4yIUEoGlkkI_QlJnFSFr-YjGRdfNHqWBkxlSMZL770R9mIATndGkH7z5x-r9KwBZFC4FCG2hg_zE",
qi: "YCX_pLwbMBA1ThVH0WcwmnytqNcrMCEwTm7ByA2eU6nWbQrULvf7m9_kzfLUcjsnpAVlBQG5JMXMy0Sq4ptwbywsa5-G8KAOOOR2L3v4hC-Eys9ftgFM_3i0o40eeQH4b3haPbntrIeMg8IzlOuVYKf9-2QuKDoWeRdd7NsdxTk"
},
};
Tests that importing keys with invalid usages should fail with SyntaxError.
On success, you will see a series of "PASS" messages, followed by "TEST COMPLETE".
error is: SyntaxError: Cannot create a key using the specified key usages.
error is: SyntaxError: Cannot create a key using the specified key usages.
error is: SyntaxError: Cannot create a key using the specified key usages.
error is: SyntaxError: Cannot create a key using the specified key usages.
PASS successfullyParsed is true
TEST COMPLETE
<!DOCTYPE html>
<html>
<head>
<script src="../resources/js-test.js"></script>
<script src="resources/common.js"></script>
<script src="resources/keys.js"></script>
</head>
<body>
<p id="description"></p>
<div id="console"></div>
<script>
description("Tests that importing keys with invalid usages should fail with SyntaxError.");
jsTestIsAsync = true;
function importPkcs8ForDecryption()
{
var keyData = hexStringToUint8Array(kKeyData.rsa1.pkcs8);
var usages = ['decrypt'];
var extractable = false;
var algorithm = {name: 'RSASSA-PKCS1-v1_5', hash: {name: 'sha-1'}};
return crypto.subtle.importKey('pkcs8', keyData, algorithm, extractable, usages);
}
function importSpkiForEncryption()
{
var keyData = hexStringToUint8Array(kKeyData.rsa1.spki);
var usages = ['encrypt'];
var extractable = false;
var algorithm = {name: 'RSASSA-PKCS1-v1_5', hash: {name: 'sha-1'}};
return crypto.subtle.importKey('spki', keyData, algorithm, extractable, usages);
}
function importJwkPublicKeyForSigning()
{
var keyData = kKeyData.jwkRSAPublicKeyJSON;
var usages = ['sign'];
var extractable = false;
var algorithm = {name: 'RSASSA-PKCS1-v1_5', hash: {name: "sha-1"}};
return crypto.subtle.importKey('jwk', keyData, algorithm, extractable, usages);
}
function importJwkPrivateKeyForEncryption()
{
var keyData = kKeyData.jwkRSAPrivateKeyJSON;
var usages = ['encrypt'];
var extractable = false;
var algorithm = {name: 'RSASSA-PKCS1-v1_5', hash: {name: "sha-1"}};
return crypto.subtle.importKey('jwk', keyData, algorithm, extractable, usages);
}
importPkcs8ForDecryption().then(failAndFinishJSTest, function(result) {
logError(result);
return importSpkiForEncryption();
}).then(failAndFinishJSTest, function(result) {
logError(result);
return importJwkPublicKeyForSigning();
}).then(failAndFinishJSTest, function(result) {
logError(result);
return importJwkPrivateKeyForEncryption();
}).then(failAndFinishJSTest, function(result) {
logError(result);
}).then(finishJSTest, failAndFinishJSTest);
</script>
</body>
</html>
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment