aboutsummaryrefslogtreecommitdiffstats
path: root/packages/dev-utils/test/rpc_test.ts
diff options
context:
space:
mode:
authorLeonid <logvinov.leon@gmail.com>2018-02-15 07:13:12 +0800
committerGitHub <noreply@github.com>2018-02-15 07:13:12 +0800
commite22788abe86b9ccee48bdccfc0a226b3292267c0 (patch)
tree46499be4ae9cd55409047752ffc1f27b96c8c423 /packages/dev-utils/test/rpc_test.ts
parent0dfb36e6759e67a82ed720bf31185aadfbea2c63 (diff)
parentbbfbfcda85d14a60711837989bf35cc22c0c3394 (diff)
downloaddexon-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.ts42
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);
+ });
+ });
+});