2016-10-12 00:09:22 +02:00
|
|
|
var assert = require('assert')
|
|
|
|
var KeyringController = require('../../app/scripts/keyring-controller')
|
|
|
|
var configManagerGen = require('../lib/mock-config-manager')
|
|
|
|
const ethUtil = require('ethereumjs-util')
|
|
|
|
const async = require('async')
|
2016-10-21 21:11:54 +02:00
|
|
|
const mockEncryptor = require('../lib/mock-encryptor')
|
2016-10-12 00:09:22 +02:00
|
|
|
|
|
|
|
describe('KeyringController', function() {
|
|
|
|
|
2016-10-21 21:11:54 +02:00
|
|
|
let keyringController
|
|
|
|
let password = 'password123'
|
|
|
|
let entropy = 'entripppppyy duuude'
|
|
|
|
let seedWords
|
|
|
|
let accounts = []
|
|
|
|
let originalKeystore
|
|
|
|
|
|
|
|
beforeEach(function() {
|
|
|
|
window.localStorage = {} // Hacking localStorage support into JSDom
|
|
|
|
|
|
|
|
keyringController = new KeyringController({
|
|
|
|
configManager: configManagerGen(),
|
|
|
|
ethStore: {
|
|
|
|
addAccount(acct) { accounts.push(ethUtil.addHexPrefix(acct)) },
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
// Stub out the browser crypto for a mock encryptor.
|
|
|
|
// Browser crypto is tested in the integration test suite.
|
|
|
|
keyringController.encryptor = mockEncryptor
|
|
|
|
})
|
|
|
|
|
2016-10-12 00:09:22 +02:00
|
|
|
describe('#createNewVault', function () {
|
2016-10-21 21:11:54 +02:00
|
|
|
it('should set a vault on the configManager', function(done) {
|
|
|
|
assert(!keyringController.configManager.getVault(), 'no previous vault')
|
|
|
|
keyringController.createNewVault(password, null, function (err, state) {
|
|
|
|
assert.ifError(err)
|
|
|
|
const vault = keyringController.configManager.getVault()
|
|
|
|
assert(vault, 'vault created')
|
2016-10-12 00:09:22 +02:00
|
|
|
|
|
|
|
done()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2016-10-21 21:11:54 +02:00
|
|
|
|
2016-10-12 00:09:22 +02:00
|
|
|
})
|
2016-10-21 21:11:54 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|