aboutsummaryrefslogtreecommitdiffstats
path: root/test/unit/nonce-tracker-test.js
blob: 5a05d6170debf7480ec3f494605b2061229792d2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
const assert = require('assert')
const NonceTracker = require('../../app/scripts/lib/nonce-tracker')

describe('Nonce Tracker', function () {
  let nonceTracker, provider, getPendingTransactions, pendingTxs
  const noop = () => {}


  beforeEach(function () {
    pendingTxs =[{
      'status': 'submitted',
      'txParams': {
        'from': '0x7d3517b0d011698406d6e0aed8453f0be2697926',
        'gas': '0x30d40',
        'value': '0x0',
        'nonce': '0x1',
      },
    }]


    getPendingTransactions = () => pendingTxs
    provider = { sendAsync: (_, cb) => { cb(undefined , {result: '0x0'}) }, }
    nonceTracker = new NonceTracker({
      blockTracker: {
        getCurrentBlock: () =>  '0x11b568',
        once: (...args) => {
          setTimeout(() => {
            args.pop()()
          }, 5000)
        }
      },
      provider,
      getPendingTransactions,
    })
  })

  describe('#getNonceLock', function () {
    it('should work', async function (done) {
      this.timeout(15000)
      const nonceLock = await nonceTracker.getNonceLock('0x7d3517b0d011698406d6e0aed8453f0be2697926')
      assert.equal(nonceLock.nextNonce, '2', 'nonce should be 2')
      nonceLock.releaseLock()
      done()
    })
  })
})