1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Add reproduction and mutex code

This commit is contained in:
Dan Finlay 2017-11-20 13:27:29 -08:00
parent 408bbe726f
commit c0aa7ce857

View File

@ -31,6 +31,7 @@ const ConfigManager = require('./lib/config-manager')
const nodeify = require('./lib/nodeify') const nodeify = require('./lib/nodeify')
const accountImporter = require('./account-import-strategies') const accountImporter = require('./account-import-strategies')
const getBuyEthUrl = require('./lib/buy-eth-url') const getBuyEthUrl = require('./lib/buy-eth-url')
const Mutex = require('await-semaphore').Mutex
const version = require('../manifest.json').version const version = require('../manifest.json').version
module.exports = class MetamaskController extends EventEmitter { module.exports = class MetamaskController extends EventEmitter {
@ -38,6 +39,10 @@ module.exports = class MetamaskController extends EventEmitter {
constructor (opts) { constructor (opts) {
super() super()
this.createVaultRequestStart = []
this.createVaultRequestEnd = []
this.createVaultMutex = new Mutex()
this.sendUpdate = debounce(this.privateSendUpdate.bind(this), 200) this.sendUpdate = debounce(this.privateSendUpdate.bind(this), 200)
this.opts = opts this.opts = opts
@ -467,15 +472,45 @@ module.exports = class MetamaskController extends EventEmitter {
// Vault Management // Vault Management
// //
async createNewVaultAndKeychain (password, cb) { async createNewVaultAndKeychain (password) {
const release = await this.createVaultMutex.acquire()
this.createVaultRequestStart.push(performance.now())
this.createVaultRequestEnd.push(0);
const idx = this.createVaultRequestStart.length - 1;
if(idx === 1) {
await this.sleep(8000)
}
const vault = await this.keyringController.createNewVaultAndKeychain(password) const vault = await this.keyringController.createNewVaultAndKeychain(password)
if(idx === 0) {
//await this.sleep(3000)
}
console.log({
"idx": idx,
"when": "before",
"obj": vault
});
this.selectFirstIdentity(vault) this.selectFirstIdentity(vault)
console.log({
"idx": idx,
"when": "after",
"obj": vault
});
this.createVaultRequestEnd[idx] = performance.now()
console.log(this.createVaultRequestStart)
console.log(this.createVaultRequestEnd)
release()
return vault return vault
} }
async createNewVaultAndRestore (password, seed, cb) { sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
async createNewVaultAndRestore (password, seed) {
const release = await this.createVaultMutex.acquire()
const vault = await this.keyringController.createNewVaultAndRestore(password, seed) const vault = await this.keyringController.createNewVaultAndRestore(password, seed)
this.selectFirstIdentity(vault) this.selectFirstIdentity(vault)
release()
return vault return vault
} }