aboutsummaryrefslogtreecommitdiffstats
path: root/test/unit/migrations
diff options
context:
space:
mode:
authorDan Finlay <542863+danfinlay@users.noreply.github.com>2018-11-17 13:27:01 +0800
committerGitHub <noreply@github.com>2018-11-17 13:27:01 +0800
commitfdea642e6d5b23d4573759e4f1a1f4016557c0be (patch)
treef72b545aa959014be4e0ec53f75cf3b0d4bbf785 /test/unit/migrations
parent1988e1e96b09a47ad5428083bb2ed38cb2d7e0a8 (diff)
downloadtangerine-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/unit/migrations')
-rw-r--r--test/unit/migrations/029-test.js38
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)
+ })
+})