mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
123 lines
3.6 KiB
JavaScript
123 lines
3.6 KiB
JavaScript
var KeyringController = require('../../../app/scripts/keyring-controller')
|
|
var ConfigManager = require('../../../app/scripts/lib/config-manager')
|
|
|
|
var oldStyleVault = require('../mocks/oldVault.json')
|
|
var badStyleVault = require('../mocks/badVault.json')
|
|
|
|
var STORAGE_KEY = 'metamask-config'
|
|
var PASSWORD = '12345678'
|
|
var FIRST_ADDRESS = '0x4dd5d356c5A016A220bCD69e82e5AF680a430d00'.toLowerCase()
|
|
|
|
var BAD_STYLE_FIRST_ADDRESS = '0xac39b311dceb2a4b2f5d8461c1cdaf756f4f7ae9'
|
|
|
|
|
|
QUnit.module('Old Style Vaults', {
|
|
beforeEach: function () {
|
|
window.localStorage[STORAGE_KEY] = JSON.stringify(oldStyleVault)
|
|
|
|
this.configManager = new ConfigManager({
|
|
loadData: () => { return JSON.parse(window.localStorage[STORAGE_KEY]) },
|
|
setData: (data) => { window.localStorage[STORAGE_KEY] = JSON.stringify(data) },
|
|
})
|
|
|
|
this.keyringController = new KeyringController({
|
|
configManager: this.configManager,
|
|
getNetwork: () => { return '2' },
|
|
})
|
|
|
|
this.ethStore = {
|
|
addAccount: () => {},
|
|
removeAccount: () => {},
|
|
}
|
|
|
|
this.keyringController.setStore(this.ethStore)
|
|
}
|
|
})
|
|
|
|
QUnit.test('keyringController:isInitialized', function (assert) {
|
|
assert.ok(this.keyringController.getState().isInitialized)
|
|
})
|
|
|
|
QUnit.test('keyringController:submitPassword', function (assert) {
|
|
var done = assert.async()
|
|
|
|
this.keyringController.submitPassword(PASSWORD)
|
|
.then((state) => {
|
|
assert.ok(state.identities[FIRST_ADDRESS])
|
|
assert.equal(state.lostAccounts.length, 0, 'no lost accounts')
|
|
done()
|
|
})
|
|
})
|
|
|
|
QUnit.test('keyringController:setLocked', function (assert) {
|
|
var done = assert.async()
|
|
var self = this
|
|
|
|
this.keyringController.setLocked()
|
|
.then(function() {
|
|
assert.notOk(self.keyringController.password, 'password should be deallocated')
|
|
assert.deepEqual(self.keyringController.keyrings, [], 'keyrings should be deallocated')
|
|
done()
|
|
})
|
|
.catch((reason) => {
|
|
assert.ifError(reason)
|
|
done()
|
|
})
|
|
})
|
|
|
|
QUnit.module('Old Style Vaults with bad HD seed', {
|
|
beforeEach: function () {
|
|
window.localStorage[STORAGE_KEY] = JSON.stringify(badStyleVault)
|
|
|
|
this.configManager = new ConfigManager({
|
|
loadData: () => { return JSON.parse(window.localStorage[STORAGE_KEY]) },
|
|
setData: (data) => { window.localStorage[STORAGE_KEY] = JSON.stringify(data) },
|
|
})
|
|
|
|
this.keyringController = new KeyringController({
|
|
configManager: this.configManager,
|
|
getNetwork: () => { return '2' },
|
|
})
|
|
|
|
this.ethStore = {
|
|
addAccount: () => {},
|
|
removeAccount: () => {},
|
|
}
|
|
|
|
this.keyringController.setStore(this.ethStore)
|
|
}
|
|
})
|
|
|
|
QUnit.test('keyringController:isInitialized', function (assert) {
|
|
assert.ok(this.keyringController.getState().isInitialized, 'vault is initialized')
|
|
})
|
|
|
|
QUnit.test('keyringController:submitPassword', function (assert) {
|
|
var done = assert.async()
|
|
|
|
this.keyringController.submitPassword(PASSWORD)
|
|
.then((state) => {
|
|
assert.ok(state.identities[BAD_STYLE_FIRST_ADDRESS])
|
|
assert.equal(state.lostAccounts.length, 1, 'one lost account')
|
|
assert.equal(state.lostAccounts[0], '0xe15D894BeCB0354c501AE69429B05143679F39e0'.toLowerCase())
|
|
assert.deepEqual(this.configManager.getLostAccounts(), state.lostAccounts, 'persisted')
|
|
done()
|
|
})
|
|
})
|
|
|
|
QUnit.test('keyringController:setLocked', function (assert) {
|
|
var done = assert.async()
|
|
var self = this
|
|
|
|
this.keyringController.setLocked()
|
|
.then(function() {
|
|
assert.notOk(self.keyringController.password, 'password should be deallocated')
|
|
assert.deepEqual(self.keyringController.keyrings, [], 'keyrings should be deallocated')
|
|
done()
|
|
})
|
|
.catch((reason) => {
|
|
assert.ifError(reason)
|
|
done()
|
|
})
|
|
})
|