diff options
author | Leonid <logvinov.leon@gmail.com> | 2018-02-15 07:13:12 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-02-15 07:13:12 +0800 |
commit | e22788abe86b9ccee48bdccfc0a226b3292267c0 (patch) | |
tree | 46499be4ae9cd55409047752ffc1f27b96c8c423 /packages/dev-utils/test/rpc_test.ts | |
parent | 0dfb36e6759e67a82ed720bf31185aadfbea2c63 (diff) | |
parent | bbfbfcda85d14a60711837989bf35cc22c0c3394 (diff) | |
download | dexon-sol-tools-e22788abe86b9ccee48bdccfc0a226b3292267c0.tar dexon-sol-tools-e22788abe86b9ccee48bdccfc0a226b3292267c0.tar.gz dexon-sol-tools-e22788abe86b9ccee48bdccfc0a226b3292267c0.tar.bz2 dexon-sol-tools-e22788abe86b9ccee48bdccfc0a226b3292267c0.tar.lz dexon-sol-tools-e22788abe86b9ccee48bdccfc0a226b3292267c0.tar.xz dexon-sol-tools-e22788abe86b9ccee48bdccfc0a226b3292267c0.tar.zst dexon-sol-tools-e22788abe86b9ccee48bdccfc0a226b3292267c0.zip |
Merge pull request #392 from 0xProject/feature/subproviders_move
Move subproviders from dev-utils to subproviders package and add tests for dev-utils
Diffstat (limited to 'packages/dev-utils/test/rpc_test.ts')
-rw-r--r-- | packages/dev-utils/test/rpc_test.ts | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/packages/dev-utils/test/rpc_test.ts b/packages/dev-utils/test/rpc_test.ts new file mode 100644 index 000000000..2f0e5ff7f --- /dev/null +++ b/packages/dev-utils/test/rpc_test.ts @@ -0,0 +1,42 @@ +import { BlockParamLiteral } from '@0xproject/types'; +import { Web3Wrapper } from '@0xproject/web3-wrapper'; +import * as chai from 'chai'; +import 'mocha'; + +import { RPC, web3Factory } from '../src'; + +const expect = chai.expect; + +describe('RPC tests', () => { + const web3 = web3Factory.create(); + const web3Wrapper = new Web3Wrapper(web3.currentProvider); + const rpc = new RPC(); + describe('#mineBlockAsync', () => { + it('increases block number when called', async () => { + const blockNumberBefore = await web3Wrapper.getBlockNumberAsync(); + await rpc.mineBlockAsync(); + const blockNumberAfter = await web3Wrapper.getBlockNumberAsync(); + expect(blockNumberAfter).to.be.equal(blockNumberBefore + 1); + }); + }); + describe('#increaseTimeAsync', () => { + it('increases time when called', async () => { + const TIME_DELTA = 1000; + const blockTimestampBefore = await web3Wrapper.getBlockTimestampAsync(BlockParamLiteral.Latest); + await rpc.increaseTimeAsync(TIME_DELTA); + await rpc.mineBlockAsync(); + const blockTimestampAfter = await web3Wrapper.getBlockTimestampAsync(BlockParamLiteral.Latest); + expect(blockTimestampAfter).to.be.at.least(blockTimestampBefore + TIME_DELTA); + }); + }); + describe('#takeSnapshotAsync/revertSnapshotAsync', () => { + it('reverts changes in between', async () => { + const blockNumberBefore = await web3Wrapper.getBlockNumberAsync(); + const snapshotId = await rpc.takeSnapshotAsync(); + await rpc.mineBlockAsync(); + await rpc.revertSnapshotAsync(snapshotId); + const blockNumberAfter = await web3Wrapper.getBlockNumberAsync(); + expect(blockNumberAfter).to.be.equal(blockNumberBefore); + }); + }); +}); |