commit
d0ba2d2d94
File diff suppressed because it is too large
Load Diff
@ -1,129 +1,103 @@ |
|||||||
const assert = require('assert') |
const assert = require('assert') |
||||||
const sinon = require('sinon') |
const sinon = require('sinon') |
||||||
const clone = require('clone') |
const clone = require('clone') |
||||||
|
const nock = require('nock') |
||||||
const MetaMaskController = require('../../app/scripts/metamask-controller') |
const MetaMaskController = require('../../app/scripts/metamask-controller') |
||||||
|
const blacklistJSON = require('../stub/blacklist') |
||||||
const firstTimeState = require('../../app/scripts/first-time-state') |
const firstTimeState = require('../../app/scripts/first-time-state') |
||||||
const BN = require('ethereumjs-util').BN |
|
||||||
const GWEI_BN = new BN('1000000000') |
|
||||||
|
|
||||||
describe('MetaMaskController', function () { |
describe('MetaMaskController', function () { |
||||||
const noop = () => {} |
let metamaskController |
||||||
const metamaskController = new MetaMaskController({ |
const sandbox = sinon.sandbox.create() |
||||||
showUnconfirmedMessage: noop, |
const noop = () => { } |
||||||
unlockAccountMessage: noop, |
|
||||||
showUnapprovedTx: noop, |
|
||||||
platform: {}, |
|
||||||
encryptor: { |
|
||||||
encrypt: function(password, object) { |
|
||||||
this.object = object |
|
||||||
return Promise.resolve() |
|
||||||
}, |
|
||||||
decrypt: function () { |
|
||||||
return Promise.resolve(this.object) |
|
||||||
} |
|
||||||
}, |
|
||||||
// initial state
|
|
||||||
initState: clone(firstTimeState), |
|
||||||
}) |
|
||||||
|
|
||||||
beforeEach(function () { |
beforeEach(function () { |
||||||
// sinon allows stubbing methods that are easily verified
|
|
||||||
this.sinon = sinon.sandbox.create() |
nock('https://api.infura.io') |
||||||
|
.persist() |
||||||
|
.get('/v2/blacklist') |
||||||
|
.reply(200, blacklistJSON) |
||||||
|
|
||||||
|
nock('https://api.infura.io') |
||||||
|
.persist() |
||||||
|
.get(/.*/) |
||||||
|
.reply(200) |
||||||
|
|
||||||
|
metamaskController = new MetaMaskController({ |
||||||
|
showUnapprovedTx: noop, |
||||||
|
encryptor: { |
||||||
|
encrypt: function (password, object) { |
||||||
|
this.object = object |
||||||
|
return Promise.resolve() |
||||||
|
}, |
||||||
|
decrypt: function () { |
||||||
|
return Promise.resolve(this.object) |
||||||
|
}, |
||||||
|
}, |
||||||
|
initState: clone(firstTimeState), |
||||||
|
}) |
||||||
|
sandbox.spy(metamaskController.keyringController, 'createNewVaultAndKeychain') |
||||||
|
sandbox.spy(metamaskController.keyringController, 'createNewVaultAndRestore') |
||||||
}) |
}) |
||||||
|
|
||||||
afterEach(function () { |
afterEach(function () { |
||||||
// sinon requires cleanup otherwise it will overwrite context
|
nock.cleanAll() |
||||||
this.sinon.restore() |
sandbox.restore() |
||||||
}) |
}) |
||||||
|
|
||||||
describe('Metamask Controller', function () { |
describe('#getGasPrice', function () { |
||||||
assert(metamaskController) |
it('gives the 50th percentile lowest accepted gas price from recentBlocksController', async function () { |
||||||
|
const realRecentBlocksController = metamaskController.recentBlocksController |
||||||
beforeEach(function () { |
metamaskController.recentBlocksController = { |
||||||
sinon.spy(metamaskController.keyringController, 'createNewVaultAndKeychain') |
store: { |
||||||
sinon.spy(metamaskController.keyringController, 'createNewVaultAndRestore') |
getState: () => { |
||||||
}) |
return { |
||||||
|
recentBlocks: [ |
||||||
afterEach(function () { |
{ gasPrices: [ '0x3b9aca00', '0x174876e800'] }, |
||||||
metamaskController.keyringController.createNewVaultAndKeychain.restore() |
{ gasPrices: [ '0x3b9aca00', '0x174876e800'] }, |
||||||
metamaskController.keyringController.createNewVaultAndRestore.restore() |
{ gasPrices: [ '0x174876e800', '0x174876e800' ]}, |
||||||
}) |
{ gasPrices: [ '0x174876e800', '0x174876e800' ]}, |
||||||
|
], |
||||||
describe('#getGasPrice', function () { |
|
||||||
it('gives the 50th percentile lowest accepted gas price from recentBlocksController', async function () { |
|
||||||
const realRecentBlocksController = metamaskController.recentBlocksController |
|
||||||
metamaskController.recentBlocksController = { |
|
||||||
store: { |
|
||||||
getState: () => { |
|
||||||
return { |
|
||||||
recentBlocks: [ |
|
||||||
{ gasPrices: [ '0x3b9aca00', '0x174876e800'] }, |
|
||||||
{ gasPrices: [ '0x3b9aca00', '0x174876e800'] }, |
|
||||||
{ gasPrices: [ '0x174876e800', '0x174876e800' ]}, |
|
||||||
{ gasPrices: [ '0x174876e800', '0x174876e800' ]}, |
|
||||||
] |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
const gasPrice = metamaskController.getGasPrice() |
|
||||||
assert.equal(gasPrice, '0x3b9aca00', 'accurately estimates 50th percentile accepted gas price') |
|
||||||
|
|
||||||
metamaskController.recentBlocksController = realRecentBlocksController |
|
||||||
}) |
|
||||||
|
|
||||||
it('gives the 1 gwei price if no blocks have been seen.', async function () { |
|
||||||
const realRecentBlocksController = metamaskController.recentBlocksController |
|
||||||
metamaskController.recentBlocksController = { |
|
||||||
store: { |
|
||||||
getState: () => { |
|
||||||
return { |
|
||||||
recentBlocks: [] |
|
||||||
} |
|
||||||
} |
} |
||||||
} |
}, |
||||||
} |
}, |
||||||
|
} |
||||||
const gasPrice = metamaskController.getGasPrice() |
|
||||||
assert.equal(gasPrice, '0x' + GWEI_BN.toString(16), 'defaults to 1 gwei') |
|
||||||
|
|
||||||
metamaskController.recentBlocksController = realRecentBlocksController |
const gasPrice = metamaskController.getGasPrice() |
||||||
}) |
assert.equal(gasPrice, '0x3b9aca00', 'accurately estimates 50th percentile accepted gas price') |
||||||
|
|
||||||
|
metamaskController.recentBlocksController = realRecentBlocksController |
||||||
}) |
}) |
||||||
|
}) |
||||||
|
|
||||||
describe('#createNewVaultAndKeychain', function () { |
describe('#createNewVaultAndKeychain', function () { |
||||||
it('can only create new vault on keyringController once', async function () { |
it('can only create new vault on keyringController once', async function () { |
||||||
const selectStub = sinon.stub(metamaskController, 'selectFirstIdentity') |
const selectStub = sandbox.stub(metamaskController, 'selectFirstIdentity') |
||||||
|
|
||||||
|
|
||||||
const password = 'a-fake-password' |
const password = 'a-fake-password' |
||||||
|
|
||||||
const first = await metamaskController.createNewVaultAndKeychain(password) |
await metamaskController.createNewVaultAndKeychain(password) |
||||||
const second = await metamaskController.createNewVaultAndKeychain(password) |
await metamaskController.createNewVaultAndKeychain(password) |
||||||
|
|
||||||
assert(metamaskController.keyringController.createNewVaultAndKeychain.calledOnce) |
assert(metamaskController.keyringController.createNewVaultAndKeychain.calledOnce) |
||||||
|
|
||||||
selectStub.reset() |
selectStub.reset() |
||||||
}) |
|
||||||
}) |
}) |
||||||
|
}) |
||||||
|
|
||||||
|
describe('#createNewVaultAndRestore', function () { |
||||||
|
it('should be able to call newVaultAndRestore despite a mistake.', async function () { |
||||||
|
|
||||||
|
const password = 'what-what-what' |
||||||
|
const wrongSeed = 'debris dizzy just program just float decrease vacant alarm reduce speak stadiu' |
||||||
|
const rightSeed = 'debris dizzy just program just float decrease vacant alarm reduce speak stadium' |
||||||
|
await metamaskController.createNewVaultAndRestore(password, wrongSeed) |
||||||
|
.catch((e) => { |
||||||
|
return |
||||||
|
}) |
||||||
|
await metamaskController.createNewVaultAndRestore(password, rightSeed) |
||||||
|
|
||||||
describe('#createNewVaultAndRestore', function () { |
assert(metamaskController.keyringController.createNewVaultAndRestore.calledTwice) |
||||||
it('should be able to call newVaultAndRestore despite a mistake.', async function () { |
|
||||||
// const selectStub = sinon.stub(metamaskController, 'selectFirstIdentity')
|
|
||||||
|
|
||||||
const password = 'what-what-what' |
|
||||||
const wrongSeed = 'debris dizzy just program just float decrease vacant alarm reduce speak stadiu' |
|
||||||
const rightSeed = 'debris dizzy just program just float decrease vacant alarm reduce speak stadium' |
|
||||||
const first = await metamaskController.createNewVaultAndRestore(password, wrongSeed) |
|
||||||
.catch((e) => { |
|
||||||
return |
|
||||||
}) |
|
||||||
const second = await metamaskController.createNewVaultAndRestore(password, rightSeed) |
|
||||||
|
|
||||||
assert(metamaskController.keyringController.createNewVaultAndRestore.calledTwice) |
|
||||||
}) |
|
||||||
}) |
}) |
||||||
}) |
}) |
||||||
}) |
}) |
||||||
|
Loading…
Reference in new issue