diff options
author | Dan Finlay <542863+danfinlay@users.noreply.github.com> | 2018-11-17 13:27:01 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-11-17 13:27:01 +0800 |
commit | fdea642e6d5b23d4573759e4f1a1f4016557c0be (patch) | |
tree | f72b545aa959014be4e0ec53f75cf3b0d4bbf785 /test | |
parent | 1988e1e96b09a47ad5428083bb2ed38cb2d7e0a8 (diff) | |
download | tangerine-wallet-browser-fdea642e6d5b23d4573759e4f1a1f4016557c0be.tar tangerine-wallet-browser-fdea642e6d5b23d4573759e4f1a1f4016557c0be.tar.gz tangerine-wallet-browser-fdea642e6d5b23d4573759e4f1a1f4016557c0be.tar.bz2 tangerine-wallet-browser-fdea642e6d5b23d4573759e4f1a1f4016557c0be.tar.lz tangerine-wallet-browser-fdea642e6d5b23d4573759e4f1a1f4016557c0be.tar.xz tangerine-wallet-browser-fdea642e6d5b23d4573759e4f1a1f4016557c0be.tar.zst tangerine-wallet-browser-fdea642e6d5b23d4573759e4f1a1f4016557c0be.zip |
Auto fail transactions that have been approved for over 12 hours (#5765)
* Auto fail transactions that have been approved for over 12 hours
Converts txs using a migration.
This migration uses a new helper function that generates tx-failing
migrations, and only requires a version, error message, and condition to
run on each transaction.
* Linted
* Only migrate approved txs to failed
* Cleanup
* Cleanup
* Small lint fixes
Diffstat (limited to 'test')
-rw-r--r-- | test/unit/migrations/029-test.js | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/test/unit/migrations/029-test.js b/test/unit/migrations/029-test.js new file mode 100644 index 000000000..a2876487b --- /dev/null +++ b/test/unit/migrations/029-test.js @@ -0,0 +1,38 @@ +const assert = require('assert') +const migration29 = require('../../../app/scripts/migrations/029') +const properTime = (new Date()).getTime() +const storage = { + 'meta': {}, + 'data': { + 'TransactionController': { + 'transactions': [ + { 'status': 'approved', id: 1, submittedTime: 0 }, + { 'status': 'approved', id: 2, submittedTime: properTime }, + { 'status': 'confirmed', id: 3, submittedTime: properTime }, + { 'status': 'submitted', id: 4, submittedTime: properTime }, + { 'status': 'submitted', id: 5, submittedTime: 0 }, + ], + }, + }, +} + +describe('storage is migrated successfully where transactions that are submitted have submittedTimes', () => { + it('should auto fail transactions more than 12 hours old', (done) => { + migration29.migrate(storage) + .then((migratedData) => { + const txs = migratedData.data.TransactionController.transactions + const [ txMeta1 ] = txs + assert.equal(migratedData.meta.version, 29) + + assert.equal(txMeta1.status, 'failed', 'old tx is auto failed') + assert(txMeta1.err.message.includes('too long'), 'error message assigned') + + txs.forEach((tx) => { + if (tx.id === 1) return + assert.notEqual(tx.status, 'failed', 'other tx is not auto failed') + }) + + done() + }).catch(done) + }) +}) |