diff options
author | Alex Browne <stephenalexbrowne@gmail.com> | 2018-06-30 02:21:17 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-06-30 02:21:17 +0800 |
commit | 7a222985978a8dc2310d7fe0a719ba80ce925df1 (patch) | |
tree | 8bc7b6ec17721cbfcafdf1fef00f4bc67f1314ab /packages/dev-utils/src/blockchain_lifecycle.ts | |
parent | 1a2c58494fa8ddd430c9f20829d0007e77b7d6c3 (diff) | |
parent | 4c28b665391cfaeec8d5e5236aa7448e1f2e62b1 (diff) | |
download | dexon-sol-tools-7a222985978a8dc2310d7fe0a719ba80ce925df1.tar dexon-sol-tools-7a222985978a8dc2310d7fe0a719ba80ce925df1.tar.gz dexon-sol-tools-7a222985978a8dc2310d7fe0a719ba80ce925df1.tar.bz2 dexon-sol-tools-7a222985978a8dc2310d7fe0a719ba80ce925df1.tar.lz dexon-sol-tools-7a222985978a8dc2310d7fe0a719ba80ce925df1.tar.xz dexon-sol-tools-7a222985978a8dc2310d7fe0a719ba80ce925df1.tar.zst dexon-sol-tools-7a222985978a8dc2310d7fe0a719ba80ce925df1.zip |
Merge pull request #794 from 0xProject/fix/devnet-minimum-blocks
Improve reliability of the minimum block number hack for devnet/geth
Diffstat (limited to 'packages/dev-utils/src/blockchain_lifecycle.ts')
-rw-r--r-- | packages/dev-utils/src/blockchain_lifecycle.ts | 38 |
1 files changed, 37 insertions, 1 deletions
diff --git a/packages/dev-utils/src/blockchain_lifecycle.ts b/packages/dev-utils/src/blockchain_lifecycle.ts index 4bb136097..587332f1a 100644 --- a/packages/dev-utils/src/blockchain_lifecycle.ts +++ b/packages/dev-utils/src/blockchain_lifecycle.ts @@ -1,3 +1,4 @@ +import { logUtils } from '@0xproject/utils'; import { uniqueVersionIds, Web3Wrapper } from '@0xproject/web3-wrapper'; import { includes } from 'lodash'; @@ -6,9 +7,17 @@ enum NodeType { Ganache = 'GANACHE', } +// HACK(albrow): 🐉 We have to do this so that debug.setHead works correctly. +// (Geth does not seem to like debug.setHead(0), so by sending some transactions +// we increase the current block number beyond 0). Additionally, some tests seem +// to break when there are fewer than 3 blocks in the chain. (We have no idea +// why, but it was consistently reproducible). +const MINIMUM_BLOCKS = 3; + export class BlockchainLifecycle { private _web3Wrapper: Web3Wrapper; private _snapshotIdsStack: number[]; + private _addresses: string[] = []; constructor(web3Wrapper: Web3Wrapper) { this._web3Wrapper = web3Wrapper; this._snapshotIdsStack = []; @@ -21,7 +30,13 @@ export class BlockchainLifecycle { this._snapshotIdsStack.push(snapshotId); break; case NodeType.Geth: - const blockNumber = await this._web3Wrapper.getBlockNumberAsync(); + let blockNumber = await this._web3Wrapper.getBlockNumberAsync(); + if (blockNumber < MINIMUM_BLOCKS) { + // If the minimum block number is not met, force Geth to + // mine some blocks by sending some dummy transactions. + await this._mineMinimumBlocksAsync(); + blockNumber = await this._web3Wrapper.getBlockNumberAsync(); + } this._snapshotIdsStack.push(blockNumber); break; default: @@ -56,4 +71,25 @@ export class BlockchainLifecycle { throw new Error(`Unknown client version: ${version}`); } } + private async _mineMinimumBlocksAsync(): Promise<void> { + logUtils.warn('WARNING: minimum block number for tests not met. Mining additional blocks...'); + if (this._addresses.length === 0) { + this._addresses = await this._web3Wrapper.getAvailableAddressesAsync(); + if (this._addresses.length === 0) { + throw new Error('No accounts found'); + } + } + while ((await this._web3Wrapper.getBlockNumberAsync()) < MINIMUM_BLOCKS) { + logUtils.warn('Mining block...'); + await this._web3Wrapper.awaitTransactionMinedAsync( + await this._web3Wrapper.sendTransactionAsync({ + from: this._addresses[0], + to: this._addresses[0], + value: '0', + }), + 0, + ); + } + logUtils.warn('Done mining the minimum number of blocks.'); + } } |