aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorDan Finlay <dan@danfinlay.com>2016-04-19 08:44:10 +0800
committerDan Finlay <dan@danfinlay.com>2016-04-19 08:44:10 +0800
commit7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652 (patch)
tree920378800e10539cc02330fcf0a110f91079c9b5 /test
parent15e953f11f2675a54447fa0eed6f46925a73d077 (diff)
parent28f14661fd484f215c5bfdc93e1b447ddcdb42ca (diff)
downloadtangerine-wallet-browser-7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652.tar
tangerine-wallet-browser-7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652.tar.gz
tangerine-wallet-browser-7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652.tar.bz2
tangerine-wallet-browser-7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652.tar.lz
tangerine-wallet-browser-7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652.tar.xz
tangerine-wallet-browser-7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652.tar.zst
tangerine-wallet-browser-7291e3f1b32f933ef1c8cc9c2f96f48bb6f33652.zip
Merge branch 'AddPersistentTransactionLog'
Diffstat (limited to 'test')
-rw-r--r--test/unit/config-manager-test.js79
1 files changed, 79 insertions, 0 deletions
diff --git a/test/unit/config-manager-test.js b/test/unit/config-manager-test.js
index 10b6716d6..84632b0ea 100644
--- a/test/unit/config-manager-test.js
+++ b/test/unit/config-manager-test.js
@@ -68,4 +68,83 @@ describe('config-manager', function() {
assert.equal(secondResult, secondRpc)
})
})
+
+ describe('transactions', function() {
+ beforeEach(function() {
+ configManager._saveTxList([])
+ })
+
+ describe('#getTxList', function() {
+ it('when new should return empty array', function() {
+ var result = configManager.getTxList()
+ assert.ok(Array.isArray(result))
+ assert.equal(result.length, 0)
+ })
+ })
+
+ describe('#_saveTxList', function() {
+ it('saves the submitted data to the tx list', function() {
+ var target = [{ foo: 'bar' }]
+ configManager._saveTxList(target)
+ var result = configManager.getTxList()
+ assert.equal(result[0].foo, 'bar')
+ })
+ })
+
+ describe('#addTx', function() {
+ it('adds a tx returned in getTxList', function() {
+ var tx = { id: 1 }
+ configManager.addTx(tx)
+ var result = configManager.getTxList()
+ assert.ok(Array.isArray(result))
+ assert.equal(result.length, 1)
+ assert.equal(result[0].id, 1)
+ })
+ })
+
+ describe('#confirmTx', function() {
+ it('sets the tx status to confirmed', function() {
+ var tx = { id: 1, status: 'unconfirmed' }
+ configManager.addTx(tx)
+ configManager.confirmTx(1)
+ var result = configManager.getTxList()
+ assert.ok(Array.isArray(result))
+ assert.equal(result.length, 1)
+ assert.equal(result[0].status, 'confirmed')
+ })
+ })
+
+ describe('#rejectTx', function() {
+ it('sets the tx status to rejected', function() {
+ var tx = { id: 1, status: 'unconfirmed' }
+ configManager.addTx(tx)
+ configManager.rejectTx(1)
+ var result = configManager.getTxList()
+ assert.ok(Array.isArray(result))
+ assert.equal(result.length, 1)
+ assert.equal(result[0].status, 'rejected')
+ })
+ })
+
+ describe('#unconfirmedTxs', function() {
+ it('returns unconfirmed txs in a hash', function() {
+ configManager.addTx({ id: '1', status: 'unconfirmed' })
+ configManager.addTx({ id: '2', status: 'confirmed' })
+ let result = configManager.unconfirmedTxs()
+ assert.equal(typeof result, 'object')
+ assert.equal(result['1'].status, 'unconfirmed')
+ assert.equal(result['0'], undefined)
+ assert.equal(result['2'], undefined)
+ })
+ })
+
+ describe('#getTx', function() {
+ it('returns a tx with the requested id', function() {
+ configManager.addTx({ id: '1', status: 'unconfirmed' })
+ configManager.addTx({ id: '2', status: 'confirmed' })
+ assert.equal(configManager.getTx('1').status, 'unconfirmed')
+ assert.equal(configManager.getTx('2').status, 'confirmed')
+ })
+ })
+ })
})