mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
1880cda9b9
This is only a bug in dev, but was committed yesterday. Sometimes the `encrypt` method was being passed values other than the password as the encryption key, leading to un-unlockable vaults. To find this, and avoid it for all time hereafter, I added several more steps to our oft-neglected integration test suite, which now fully initializes a vault, locks it, and unlocks it again, to make sure all of those steps definitely work always.
72 lines
1.8 KiB
JavaScript
72 lines
1.8 KiB
JavaScript
var encryptor = require('../../../app/scripts/lib/encryptor')
|
|
|
|
QUnit.module('encryptor')
|
|
|
|
QUnit.test('encryptor:serializeBufferForStorage', function (assert) {
|
|
assert.expect(1)
|
|
var buf = new Buffer(2)
|
|
buf[0] = 16
|
|
buf[1] = 1
|
|
|
|
var output = encryptor.serializeBufferForStorage(buf)
|
|
|
|
var expect = '0x1001'
|
|
assert.equal(expect, output)
|
|
})
|
|
|
|
QUnit.test('encryptor:serializeBufferFromStorage', function (assert) {
|
|
assert.expect(2)
|
|
var input = '0x1001'
|
|
var output = encryptor.serializeBufferFromStorage(input)
|
|
|
|
assert.equal(output[0], 16)
|
|
assert.equal(output[1], 1)
|
|
})
|
|
|
|
QUnit.test('encryptor:encrypt & decrypt', function(assert) {
|
|
var done = assert.async();
|
|
var password, data, encrypted
|
|
|
|
password = 'a sample passw0rd'
|
|
data = { foo: 'data to encrypt' }
|
|
|
|
encryptor.encrypt(password, data)
|
|
.then(function(encryptedStr) {
|
|
assert.equal(typeof encryptedStr, 'string', 'returns a string')
|
|
return encryptor.decrypt(password, encryptedStr)
|
|
})
|
|
.then(function (decryptedObj) {
|
|
assert.deepEqual(decryptedObj, data, 'decrypted what was encrypted')
|
|
done()
|
|
})
|
|
.catch(function(reason) {
|
|
assert.ifError(reason, 'threw an error')
|
|
done(reason)
|
|
})
|
|
|
|
})
|
|
|
|
QUnit.test('encryptor:encrypt & decrypt with wrong password', function(assert) {
|
|
var done = assert.async();
|
|
var password, data, encrypted, wrongPassword
|
|
|
|
password = 'a sample passw0rd'
|
|
wrongPassword = 'a wrong password'
|
|
data = { foo: 'data to encrypt' }
|
|
|
|
encryptor.encrypt(password, data)
|
|
.then(function(encryptedStr) {
|
|
assert.equal(typeof encryptedStr, 'string', 'returns a string')
|
|
return encryptor.decrypt(wrongPassword, encryptedStr)
|
|
})
|
|
.then(function (decryptedObj) {
|
|
assert.equal(!decryptedObj, true, 'Wrong password should not decrypt')
|
|
done()
|
|
})
|
|
.catch(function(reason) {
|
|
done()
|
|
})
|
|
})
|
|
|
|
|