Merge pull request #614 from MetaMask/i546-NegativeErr
Add negative value validation to tx approvalfeature/default_network_editable
commit
095a40e33d
@ -0,0 +1,97 @@ |
|||||||
|
var assert = require('assert') |
||||||
|
var MetaMaskController = require('../../app/scripts/metamask-controller') |
||||||
|
var sinon = require('sinon') |
||||||
|
var extend = require('xtend') |
||||||
|
const STORAGE_KEY = 'metamask-config' |
||||||
|
|
||||||
|
describe('MetaMaskController', function() { |
||||||
|
const noop = () => {} |
||||||
|
let controller = new MetaMaskController({ |
||||||
|
showUnconfirmedMessage: noop, |
||||||
|
unlockAccountMessage: noop, |
||||||
|
showUnconfirmedTx: noop, |
||||||
|
setData, |
||||||
|
loadData, |
||||||
|
}) |
||||||
|
|
||||||
|
beforeEach(function() { |
||||||
|
// sinon allows stubbing methods that are easily verified
|
||||||
|
this.sinon = sinon.sandbox.create() |
||||||
|
window.localStorage = {} // Hacking localStorage support into JSDom
|
||||||
|
}) |
||||||
|
|
||||||
|
afterEach(function() { |
||||||
|
// sinon requires cleanup otherwise it will overwrite context
|
||||||
|
this.sinon.restore() |
||||||
|
}) |
||||||
|
|
||||||
|
describe('#enforceTxValidations', function () { |
||||||
|
it('returns null for positive values', function() { |
||||||
|
var sample = { |
||||||
|
value: '0x01' |
||||||
|
} |
||||||
|
var res = controller.enforceTxValidations(sample) |
||||||
|
assert.equal(res, null, 'no error') |
||||||
|
}) |
||||||
|
|
||||||
|
|
||||||
|
it('returns error for negative values', function() { |
||||||
|
var sample = { |
||||||
|
value: '-0x01' |
||||||
|
} |
||||||
|
var res = controller.enforceTxValidations(sample) |
||||||
|
assert.ok(res, 'error') |
||||||
|
}) |
||||||
|
}) |
||||||
|
}) |
||||||
|
|
||||||
|
|
||||||
|
function loadData () { |
||||||
|
var oldData = getOldStyleData() |
||||||
|
var newData |
||||||
|
try { |
||||||
|
newData = JSON.parse(window.localStorage[STORAGE_KEY]) |
||||||
|
} catch (e) {} |
||||||
|
|
||||||
|
var data = extend({ |
||||||
|
meta: { |
||||||
|
version: 0, |
||||||
|
}, |
||||||
|
data: { |
||||||
|
config: { |
||||||
|
provider: { |
||||||
|
type: 'testnet', |
||||||
|
}, |
||||||
|
}, |
||||||
|
}, |
||||||
|
}, oldData || null, newData || null) |
||||||
|
return data |
||||||
|
} |
||||||
|
|
||||||
|
function getOldStyleData () { |
||||||
|
var config, wallet, seedWords |
||||||
|
|
||||||
|
var result = { |
||||||
|
meta: { version: 0 }, |
||||||
|
data: {}, |
||||||
|
} |
||||||
|
|
||||||
|
try { |
||||||
|
config = JSON.parse(window.localStorage['config']) |
||||||
|
result.data.config = config |
||||||
|
} catch (e) {} |
||||||
|
try { |
||||||
|
wallet = JSON.parse(window.localStorage['lightwallet']) |
||||||
|
result.data.wallet = wallet |
||||||
|
} catch (e) {} |
||||||
|
try { |
||||||
|
seedWords = window.localStorage['seedWords'] |
||||||
|
result.data.seedWords = seedWords |
||||||
|
} catch (e) {} |
||||||
|
|
||||||
|
return result |
||||||
|
} |
||||||
|
|
||||||
|
function setData (data) { |
||||||
|
window.localStorage[STORAGE_KEY] = JSON.stringify(data) |
||||||
|
} |
Loading…
Reference in new issue