зеркало из https://github.com/mozilla/gecko-dev.git
39 строки
1.1 KiB
JavaScript
39 строки
1.1 KiB
JavaScript
var btoa;
|
|
|
|
function test_derive(cryptoSvc) {
|
|
// Extracted from test_utils_deriveKey.
|
|
let pp = "secret phrase";
|
|
let salt = "RE5YUHpQcGl3bg=="; // btoa("DNXPzPpiwn")
|
|
|
|
// 16-byte, extract key data.
|
|
let k = cryptoSvc.deriveKeyFromPassphrase(pp, salt, 16);
|
|
do_check_eq(16, k.length);
|
|
do_check_eq(btoa(k), "d2zG0d2cBfXnRwMUGyMwyg==");
|
|
|
|
// Test different key lengths.
|
|
k = cryptoSvc.deriveKeyFromPassphrase(pp, salt, 32);
|
|
do_check_eq(32, k.length);
|
|
let encKey = btoa(k);
|
|
|
|
// Test via encryption.
|
|
let iv = cryptoSvc.generateRandomIV();
|
|
do_check_eq(cryptoSvc.decrypt(cryptoSvc.encrypt("bacon", encKey, iv), encKey, iv), "bacon");
|
|
|
|
// Test default length (32).
|
|
k = cryptoSvc.deriveKeyFromPassphrase(pp, salt, null);
|
|
do_check_eq(32, k.length);
|
|
do_check_eq(encKey, btoa(k));
|
|
}
|
|
|
|
function run_test() {
|
|
let cryptoSvc;
|
|
try {
|
|
let backstagePass = Components.utils.import("resource://services-crypto/WeaveCrypto.js");
|
|
btoa = backstagePass.btoa;
|
|
} catch (ex) {
|
|
_("Aborting test: no WeaveCrypto.js.");
|
|
return;
|
|
}
|
|
test_derive(new WeaveCrypto());
|
|
}
|