commit
6811fb2679
@ -0,0 +1,41 @@ |
|||||||
|
const version = 16 |
||||||
|
|
||||||
|
/* |
||||||
|
|
||||||
|
This migration sets transactions with the 'Gave up submitting tx.' err message |
||||||
|
to a 'failed' stated |
||||||
|
|
||||||
|
*/ |
||||||
|
|
||||||
|
const clone = require('clone') |
||||||
|
|
||||||
|
module.exports = { |
||||||
|
version, |
||||||
|
|
||||||
|
migrate: function (originalVersionedData) { |
||||||
|
const versionedData = clone(originalVersionedData) |
||||||
|
versionedData.meta.version = version |
||||||
|
try { |
||||||
|
const state = versionedData.data |
||||||
|
const newState = transformState(state) |
||||||
|
versionedData.data = newState |
||||||
|
} catch (err) { |
||||||
|
console.warn(`MetaMask Migration #${version}` + err.stack) |
||||||
|
} |
||||||
|
return Promise.resolve(versionedData) |
||||||
|
}, |
||||||
|
} |
||||||
|
|
||||||
|
function transformState (state) { |
||||||
|
const newState = state |
||||||
|
const transactions = newState.TransactionController.transactions |
||||||
|
newState.TransactionController.transactions = transactions.map((txMeta) => { |
||||||
|
if (!txMeta.err) return txMeta |
||||||
|
if (txMeta.err === 'transaction with the same hash was already imported.') { |
||||||
|
txMeta.status = 'submitted' |
||||||
|
delete txMeta.err |
||||||
|
} |
||||||
|
return txMeta |
||||||
|
}) |
||||||
|
return newState |
||||||
|
} |
@ -1,34 +1,34 @@ |
|||||||
// polyfill fetch
|
// polyfill fetch
|
||||||
global.fetch = function () {return Promise.resolve({ |
// global.fetch = function () {return Promise.resolve({
|
||||||
json: () => { return Promise.resolve({"mainnet": "ok", "ropsten": "degraded", "kovan": "down", "rinkeby": "ok"}) }, |
// json: () => { return Promise.resolve({"mainnet": "ok", "ropsten": "degraded", "kovan": "down", "rinkeby": "ok"}) },
|
||||||
}) |
// })
|
||||||
} |
// }
|
||||||
const assert = require('assert') |
// const assert = require('assert')
|
||||||
const InfuraController = require('../../app/scripts/controllers/infura') |
// const InfuraController = require('../../app/scripts/controllers/infura')
|
||||||
|
//
|
||||||
describe('infura-controller', function () { |
// describe('infura-controller', function () {
|
||||||
var infuraController |
// var infuraController
|
||||||
|
//
|
||||||
beforeEach(function () { |
// beforeEach(function () {
|
||||||
infuraController = new InfuraController() |
// infuraController = new InfuraController()
|
||||||
}) |
// })
|
||||||
|
//
|
||||||
describe('network status queries', function () { |
// describe('network status queries', function () {
|
||||||
describe('#checkInfuraNetworkStatus', function () { |
// describe('#checkInfuraNetworkStatus', function () {
|
||||||
it('should return an object reflecting the network statuses', function (done) { |
// it('should return an object reflecting the network statuses', function (done) {
|
||||||
this.timeout(15000) |
// this.timeout(15000)
|
||||||
infuraController.checkInfuraNetworkStatus() |
// infuraController.checkInfuraNetworkStatus()
|
||||||
.then(() => { |
// .then(() => {
|
||||||
const networkStatus = infuraController.store.getState().infuraNetworkStatus |
// const networkStatus = infuraController.store.getState().infuraNetworkStatus
|
||||||
assert.equal(Object.keys(networkStatus).length, 4) |
// assert.equal(Object.keys(networkStatus).length, 4)
|
||||||
assert.equal(networkStatus.mainnet, 'ok') |
// assert.equal(networkStatus.mainnet, 'ok')
|
||||||
assert.equal(networkStatus.ropsten, 'degraded') |
// assert.equal(networkStatus.ropsten, 'degraded')
|
||||||
assert.equal(networkStatus.kovan, 'down') |
// assert.equal(networkStatus.kovan, 'down')
|
||||||
}) |
// })
|
||||||
.then(() => done()) |
// .then(() => done())
|
||||||
.catch(done) |
// .catch(done)
|
||||||
|
//
|
||||||
}) |
// })
|
||||||
}) |
// })
|
||||||
}) |
// })
|
||||||
}) |
// })
|
||||||
|
Loading…
Reference in new issue