Use fork configs if FORK_RPC_URL env var is set
This commit is contained in:
parent
038c836fe5
commit
cb5384c2fb
@ -1,4 +1,4 @@
|
||||
import { devConstants, env, EnvVars, web3Factory } from '@0x/dev-utils';
|
||||
import { devConstants, env, EnvVars, Web3Config, web3Factory } from '@0x/dev-utils';
|
||||
import { prependSubprovider, Web3ProviderEngine } from '@0x/subproviders';
|
||||
import { logUtils } from '@0x/utils';
|
||||
import { Web3Wrapper } from '@0x/web3-wrapper';
|
||||
@ -9,47 +9,31 @@ import { coverage } from './coverage';
|
||||
import { profiler } from './profiler';
|
||||
import { revertTrace } from './revert_trace';
|
||||
|
||||
enum ProviderType {
|
||||
Ganache = 'ganache',
|
||||
Geth = 'geth',
|
||||
}
|
||||
|
||||
let testProvider: ProviderType;
|
||||
switch (process.env.TEST_PROVIDER) {
|
||||
case undefined:
|
||||
testProvider = ProviderType.Ganache;
|
||||
break;
|
||||
case 'ganache':
|
||||
testProvider = ProviderType.Ganache;
|
||||
break;
|
||||
case 'geth':
|
||||
testProvider = ProviderType.Geth;
|
||||
break;
|
||||
default:
|
||||
throw new Error(`Unknown TEST_PROVIDER: ${process.env.TEST_PROVIDER}`);
|
||||
}
|
||||
|
||||
const ganacheTxDefaults = {
|
||||
export const txDefaults = {
|
||||
from: devConstants.TESTRPC_FIRST_ADDRESS,
|
||||
gas: devConstants.GAS_LIMIT,
|
||||
gasPrice: constants.DEFAULT_GAS_PRICE,
|
||||
};
|
||||
const gethTxDefaults = {
|
||||
from: devConstants.TESTRPC_FIRST_ADDRESS,
|
||||
};
|
||||
export const txDefaults = testProvider === ProviderType.Ganache ? ganacheTxDefaults : gethTxDefaults;
|
||||
|
||||
const gethConfigs = {
|
||||
shouldUseInProcessGanache: false,
|
||||
rpcUrl: 'http://localhost:8501',
|
||||
shouldUseFakeGasEstimate: false,
|
||||
};
|
||||
const ganacheConfigs = {
|
||||
let providerConfigs: Web3Config = {
|
||||
total_accounts: constants.NUM_TEST_ACCOUNTS,
|
||||
shouldUseInProcessGanache: true,
|
||||
shouldAllowUnlimitedContractSize: true,
|
||||
};
|
||||
const providerConfigs = testProvider === ProviderType.Ganache ? ganacheConfigs : gethConfigs;
|
||||
|
||||
if (process.env.FORK_RPC_URL !== undefined) {
|
||||
providerConfigs = {
|
||||
...providerConfigs,
|
||||
fork: process.env.FORK_RPC_URL,
|
||||
blockTime: 0,
|
||||
// ZeroExGovernor signer addresses
|
||||
unlocked_accounts: [
|
||||
'0x257619b7155d247e43c8b6d90c8c17278ae481f0',
|
||||
'0x5ee2a00f8f01d099451844af7f894f26a57fcbf2',
|
||||
'0x894d623e0e0e8ed12c4a73dada999e275684a37d',
|
||||
],
|
||||
};
|
||||
}
|
||||
|
||||
export const provider: Web3ProviderEngine = web3Factory.getRpcProvider(providerConfigs);
|
||||
provider.stop();
|
||||
|
@ -21,6 +21,9 @@ export interface Web3Config {
|
||||
shouldUseFakeGasEstimate?: boolean; // default: true
|
||||
ganacheDatabasePath?: string; // default: undefined, creates a tmp dir
|
||||
shouldAllowUnlimitedContractSize?: boolean;
|
||||
fork?: string;
|
||||
blockTime?: number;
|
||||
unlocked_accounts?: string[];
|
||||
}
|
||||
|
||||
export const web3Factory = {
|
||||
@ -73,6 +76,9 @@ export const web3Factory = {
|
||||
port: 8545,
|
||||
network_id: 50,
|
||||
mnemonic: 'concert load couple harbor equip island argue ramp clarify fence smart topic',
|
||||
fork: config.fork,
|
||||
blockTime: config.blockTime,
|
||||
unlocked_accounts: config.unlocked_accounts,
|
||||
} as any), // TODO remove any once types are merged in DefinitelyTyped
|
||||
);
|
||||
} else {
|
||||
|
@ -13,6 +13,9 @@ declare module 'ganache-core' {
|
||||
vmErrorsOnRPCResponse?: boolean;
|
||||
db_path?: string;
|
||||
total_accounts?: number;
|
||||
fork?: string;
|
||||
blockTime?: number;
|
||||
unlocked_accounts?: string[];
|
||||
}
|
||||
export function provider(opts: GanacheOpts): EthereumTypes.Provider;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user