Remove tests related to read-only mode

This commit is contained in:
Amir Bandeali
2019-10-27 11:10:15 -07:00
parent 58e9c70203
commit 33a0c22021
8 changed files with 2 additions and 203 deletions

View File

@@ -37,7 +37,7 @@
}, },
"config": { "config": {
"abis:comment": "This list is auto-generated by contracts-gen. Don't edit manually.", "abis:comment": "This list is auto-generated by contracts-gen. Don't edit manually.",
"abis": "./generated-artifacts/@(IStaking|IStakingEvents|IStakingProxy|IStorage|IStorageInit|IStructs|IZrxVault|IZrxVaultBackstop|LibCobbDouglas|LibFixedMath|LibFixedMathRichErrors|LibProxy|LibSafeDowncast|LibStakingRichErrors|MixinAbstract|MixinConstants|MixinCumulativeRewards|MixinDeploymentConstants|MixinExchangeFees|MixinExchangeManager|MixinFinalizer|MixinParams|MixinScheduler|MixinStake|MixinStakeBalances|MixinStakeStorage|MixinStakingPool|MixinStakingPoolRewards|MixinStorage|ReadOnlyProxy|Staking|StakingProxy|TestAssertStorageParams|TestCobbDouglas|TestCumulativeRewardTracking|TestDelegatorRewards|TestExchangeManager|TestFinalizer|TestInitTarget|TestLibFixedMath|TestLibProxy|TestLibProxyReceiver|TestLibSafeDowncast|TestMixinParams|TestMixinStake|TestMixinStakeStorage|TestMixinStakingPool|TestProtocolFees|TestStaking|TestStakingNoWETH|TestStakingProxy|TestStorageLayoutAndConstants|ZrxVault|ZrxVaultBackstop).json" "abis": "./generated-artifacts/@(IStaking|IStakingEvents|IStakingProxy|IStorage|IStorageInit|IStructs|IZrxVault|LibCobbDouglas|LibFixedMath|LibFixedMathRichErrors|LibProxy|LibSafeDowncast|LibStakingRichErrors|MixinAbstract|MixinConstants|MixinCumulativeRewards|MixinDeploymentConstants|MixinExchangeFees|MixinExchangeManager|MixinFinalizer|MixinParams|MixinScheduler|MixinStake|MixinStakeBalances|MixinStakeStorage|MixinStakingPool|MixinStakingPoolRewards|MixinStorage|Staking|StakingProxy|TestAssertStorageParams|TestCobbDouglas|TestCumulativeRewardTracking|TestDelegatorRewards|TestExchangeManager|TestFinalizer|TestInitTarget|TestLibFixedMath|TestLibProxy|TestLibProxyReceiver|TestLibSafeDowncast|TestMixinParams|TestMixinStake|TestMixinStakeStorage|TestMixinStakingPool|TestProtocolFees|TestStaking|TestStakingNoWETH|TestStakingProxy|TestStorageLayoutAndConstants|ZrxVault).json"
}, },
"repository": { "repository": {
"type": "git", "type": "git",

View File

@@ -12,7 +12,6 @@ import * as IStorage from '../generated-artifacts/IStorage.json';
import * as IStorageInit from '../generated-artifacts/IStorageInit.json'; import * as IStorageInit from '../generated-artifacts/IStorageInit.json';
import * as IStructs from '../generated-artifacts/IStructs.json'; import * as IStructs from '../generated-artifacts/IStructs.json';
import * as IZrxVault from '../generated-artifacts/IZrxVault.json'; import * as IZrxVault from '../generated-artifacts/IZrxVault.json';
import * as IZrxVaultBackstop from '../generated-artifacts/IZrxVaultBackstop.json';
import * as LibCobbDouglas from '../generated-artifacts/LibCobbDouglas.json'; import * as LibCobbDouglas from '../generated-artifacts/LibCobbDouglas.json';
import * as LibFixedMath from '../generated-artifacts/LibFixedMath.json'; import * as LibFixedMath from '../generated-artifacts/LibFixedMath.json';
import * as LibFixedMathRichErrors from '../generated-artifacts/LibFixedMathRichErrors.json'; import * as LibFixedMathRichErrors from '../generated-artifacts/LibFixedMathRichErrors.json';
@@ -34,7 +33,6 @@ import * as MixinStakeStorage from '../generated-artifacts/MixinStakeStorage.jso
import * as MixinStakingPool from '../generated-artifacts/MixinStakingPool.json'; import * as MixinStakingPool from '../generated-artifacts/MixinStakingPool.json';
import * as MixinStakingPoolRewards from '../generated-artifacts/MixinStakingPoolRewards.json'; import * as MixinStakingPoolRewards from '../generated-artifacts/MixinStakingPoolRewards.json';
import * as MixinStorage from '../generated-artifacts/MixinStorage.json'; import * as MixinStorage from '../generated-artifacts/MixinStorage.json';
import * as ReadOnlyProxy from '../generated-artifacts/ReadOnlyProxy.json';
import * as Staking from '../generated-artifacts/Staking.json'; import * as Staking from '../generated-artifacts/Staking.json';
import * as StakingProxy from '../generated-artifacts/StakingProxy.json'; import * as StakingProxy from '../generated-artifacts/StakingProxy.json';
import * as TestAssertStorageParams from '../generated-artifacts/TestAssertStorageParams.json'; import * as TestAssertStorageParams from '../generated-artifacts/TestAssertStorageParams.json';
@@ -58,13 +56,10 @@ import * as TestStakingNoWETH from '../generated-artifacts/TestStakingNoWETH.jso
import * as TestStakingProxy from '../generated-artifacts/TestStakingProxy.json'; import * as TestStakingProxy from '../generated-artifacts/TestStakingProxy.json';
import * as TestStorageLayoutAndConstants from '../generated-artifacts/TestStorageLayoutAndConstants.json'; import * as TestStorageLayoutAndConstants from '../generated-artifacts/TestStorageLayoutAndConstants.json';
import * as ZrxVault from '../generated-artifacts/ZrxVault.json'; import * as ZrxVault from '../generated-artifacts/ZrxVault.json';
import * as ZrxVaultBackstop from '../generated-artifacts/ZrxVaultBackstop.json';
export const artifacts = { export const artifacts = {
ReadOnlyProxy: ReadOnlyProxy as ContractArtifact,
Staking: Staking as ContractArtifact, Staking: Staking as ContractArtifact,
StakingProxy: StakingProxy as ContractArtifact, StakingProxy: StakingProxy as ContractArtifact,
ZrxVault: ZrxVault as ContractArtifact, ZrxVault: ZrxVault as ContractArtifact,
ZrxVaultBackstop: ZrxVaultBackstop as ContractArtifact,
MixinExchangeFees: MixinExchangeFees as ContractArtifact, MixinExchangeFees: MixinExchangeFees as ContractArtifact,
MixinExchangeManager: MixinExchangeManager as ContractArtifact, MixinExchangeManager: MixinExchangeManager as ContractArtifact,
MixinConstants: MixinConstants as ContractArtifact, MixinConstants: MixinConstants as ContractArtifact,
@@ -77,7 +72,6 @@ export const artifacts = {
IStorageInit: IStorageInit as ContractArtifact, IStorageInit: IStorageInit as ContractArtifact,
IStructs: IStructs as ContractArtifact, IStructs: IStructs as ContractArtifact,
IZrxVault: IZrxVault as ContractArtifact, IZrxVault: IZrxVault as ContractArtifact,
IZrxVaultBackstop: IZrxVaultBackstop as ContractArtifact,
LibCobbDouglas: LibCobbDouglas as ContractArtifact, LibCobbDouglas: LibCobbDouglas as ContractArtifact,
LibFixedMath: LibFixedMath as ContractArtifact, LibFixedMath: LibFixedMath as ContractArtifact,
LibFixedMathRichErrors: LibFixedMathRichErrors as ContractArtifact, LibFixedMathRichErrors: LibFixedMathRichErrors as ContractArtifact,

View File

@@ -10,7 +10,6 @@ export * from '../generated-wrappers/i_storage';
export * from '../generated-wrappers/i_storage_init'; export * from '../generated-wrappers/i_storage_init';
export * from '../generated-wrappers/i_structs'; export * from '../generated-wrappers/i_structs';
export * from '../generated-wrappers/i_zrx_vault'; export * from '../generated-wrappers/i_zrx_vault';
export * from '../generated-wrappers/i_zrx_vault_backstop';
export * from '../generated-wrappers/lib_cobb_douglas'; export * from '../generated-wrappers/lib_cobb_douglas';
export * from '../generated-wrappers/lib_fixed_math'; export * from '../generated-wrappers/lib_fixed_math';
export * from '../generated-wrappers/lib_fixed_math_rich_errors'; export * from '../generated-wrappers/lib_fixed_math_rich_errors';
@@ -32,7 +31,6 @@ export * from '../generated-wrappers/mixin_stake_storage';
export * from '../generated-wrappers/mixin_staking_pool'; export * from '../generated-wrappers/mixin_staking_pool';
export * from '../generated-wrappers/mixin_staking_pool_rewards'; export * from '../generated-wrappers/mixin_staking_pool_rewards';
export * from '../generated-wrappers/mixin_storage'; export * from '../generated-wrappers/mixin_storage';
export * from '../generated-wrappers/read_only_proxy';
export * from '../generated-wrappers/staking'; export * from '../generated-wrappers/staking';
export * from '../generated-wrappers/staking_proxy'; export * from '../generated-wrappers/staking_proxy';
export * from '../generated-wrappers/test_assert_storage_params'; export * from '../generated-wrappers/test_assert_storage_params';
@@ -56,4 +54,3 @@ export * from '../generated-wrappers/test_staking_no_w_e_t_h';
export * from '../generated-wrappers/test_staking_proxy'; export * from '../generated-wrappers/test_staking_proxy';
export * from '../generated-wrappers/test_storage_layout_and_constants'; export * from '../generated-wrappers/test_storage_layout_and_constants';
export * from '../generated-wrappers/zrx_vault'; export * from '../generated-wrappers/zrx_vault';
export * from '../generated-wrappers/zrx_vault_backstop';

View File

@@ -1,109 +0,0 @@
import { ERC20Wrapper } from '@0x/contracts-asset-proxy';
import { blockchainTests, describe, expect } from '@0x/contracts-test-utils';
import { BigNumber } from '@0x/utils';
import { LogWithDecodedArgs } from 'ethereum-types';
import * as _ from 'lodash';
import { StakingProxyReadOnlyModeSetEventArgs } from '../src';
import { deployAndConfigureContractsAsync, StakingApiWrapper } from './utils/api_wrapper';
import { toBaseUnitAmount } from './utils/number_utils';
import { StakeStatus } from './utils/types';
// tslint:disable:no-unnecessary-type-assertion
blockchainTests.resets('Catastrophe Tests', env => {
// constants
const ZERO = new BigNumber(0);
// tokens & addresses
let accounts: string[];
let owner: string;
let actors: string[];
// wrappers
let stakingApiWrapper: StakingApiWrapper;
let erc20Wrapper: ERC20Wrapper;
// tests
before(async () => {
// create accounts
accounts = await env.web3Wrapper.getAvailableAddressesAsync();
owner = accounts[0];
actors = accounts.slice(2, 5);
// set up ERC20Wrapper
erc20Wrapper = new ERC20Wrapper(env.provider, accounts, owner);
// deploy staking contracts
stakingApiWrapper = await deployAndConfigureContractsAsync(env, owner, erc20Wrapper);
});
describe('Read-Only Mode', () => {
it('should be able to change state by default', async () => {
// stake some zrx and assert the balance
const amountToStake = toBaseUnitAmount(10);
await stakingApiWrapper.stakingContract.stake.awaitTransactionSuccessAsync(amountToStake, {
from: actors[0],
});
const undelegatedStakeBalance = await stakingApiWrapper.stakingContract.getOwnerStakeByStatus.callAsync(
actors[0],
StakeStatus.Undelegated,
);
expect(undelegatedStakeBalance.currentEpochBalance).to.be.bignumber.equal(amountToStake);
});
it('should not change state when in read-only mode', async () => {
// set to read-only mode
await stakingApiWrapper.stakingProxyContract.setReadOnlyMode.awaitTransactionSuccessAsync(true);
// try to stake
const amountToStake = toBaseUnitAmount(10);
await stakingApiWrapper.stakingContract.stake.awaitTransactionSuccessAsync(amountToStake, {
from: actors[0],
});
const undelegatedStakeBalance = await stakingApiWrapper.stakingContract.getOwnerStakeByStatus.callAsync(
actors[0],
StakeStatus.Undelegated,
);
expect(undelegatedStakeBalance.currentEpochBalance).to.be.bignumber.equal(ZERO);
});
it('should read values correctly when in read-only mode', async () => {
// stake some zrx
const amountToStake = toBaseUnitAmount(10);
await stakingApiWrapper.stakingContract.stake.awaitTransactionSuccessAsync(amountToStake, {
from: actors[0],
});
// set to read-only mode
await stakingApiWrapper.stakingProxyContract.setReadOnlyMode.awaitTransactionSuccessAsync(true);
// read stake balance in read-only mode
const undelegatedStakeBalanceReadOnly = await stakingApiWrapper.stakingContract.getOwnerStakeByStatus.callAsync(
actors[0],
StakeStatus.Undelegated,
);
expect(undelegatedStakeBalanceReadOnly.currentEpochBalance).to.be.bignumber.equal(amountToStake);
});
it('should exit read-only mode', async () => {
// set to read-only mode
await stakingApiWrapper.stakingProxyContract.setReadOnlyMode.awaitTransactionSuccessAsync(true);
await stakingApiWrapper.stakingProxyContract.setReadOnlyMode.awaitTransactionSuccessAsync(false);
// try to stake
const amountToStake = toBaseUnitAmount(10);
await stakingApiWrapper.stakingContract.stake.awaitTransactionSuccessAsync(amountToStake, {
from: actors[0],
});
const undelegatedStakeBalance = await stakingApiWrapper.stakingContract.getOwnerStakeByStatus.callAsync(
actors[0],
StakeStatus.Undelegated,
);
expect(undelegatedStakeBalance.currentEpochBalance).to.be.bignumber.equal(amountToStake);
});
it('should emit event and store correct configuration when setting read-only mode', async () => {
// set to read-only mode
const txReceipt = await stakingApiWrapper.stakingProxyContract.setReadOnlyMode.awaitTransactionSuccessAsync(
true,
);
expect(txReceipt.logs.length).to.be.equal(1);
const trueLog = txReceipt.logs[0] as LogWithDecodedArgs<StakingProxyReadOnlyModeSetEventArgs>;
expect(trueLog.args.readOnlyMode).to.be.true();
const timestamp = await env.web3Wrapper.getBlockTimestampAsync(txReceipt.blockNumber);
expect(trueLog.args.timestamp).to.bignumber.equal(timestamp);
const readOnlyState = await stakingApiWrapper.stakingProxyContract.readOnlyState.callAsync();
expect(readOnlyState[0]).to.be.true();
expect(readOnlyState[1]).to.bignumber.equal(timestamp);
});
});
});
// tslint:enable:no-unnecessary-type-assertion

View File

@@ -108,7 +108,6 @@ blockchainTests('Migration tests', env => {
env.txDefaults, env.txDefaults,
artifacts, artifacts,
stakingContract.address, stakingContract.address,
stakingContract.address,
)).address; )).address;
const stakingProxyContract = new StakingContract( const stakingProxyContract = new StakingContract(

View File

@@ -10,12 +10,10 @@ import {
artifacts, artifacts,
IStakingEventsEpochEndedEventArgs, IStakingEventsEpochEndedEventArgs,
IStakingEventsStakingPoolEarnedRewardsInEpochEventArgs, IStakingEventsStakingPoolEarnedRewardsInEpochEventArgs,
ReadOnlyProxyContract,
StakingProxyContract, StakingProxyContract,
TestCobbDouglasContract, TestCobbDouglasContract,
TestStakingContract, TestStakingContract,
TestStakingEvents, TestStakingEvents,
ZrxVaultBackstopContract,
ZrxVaultContract, ZrxVaultContract,
} from '../../src'; } from '../../src';
@@ -33,7 +31,6 @@ export class StakingApiWrapper {
public zrxTokenContract: DummyERC20TokenContract; public zrxTokenContract: DummyERC20TokenContract;
public wethContract: WETH9Contract; public wethContract: WETH9Contract;
public cobbDouglasContract: TestCobbDouglasContract; public cobbDouglasContract: TestCobbDouglasContract;
public zrxVaultBackstopContract: ZrxVaultBackstopContract;
public utils = { public utils = {
// Epoch Utils // Epoch Utils
fastForwardToNextEpochAsync: async (): Promise<void> => { fastForwardToNextEpochAsync: async (): Promise<void> => {
@@ -176,14 +173,12 @@ export class StakingApiWrapper {
zrxTokenContract: DummyERC20TokenContract, zrxTokenContract: DummyERC20TokenContract,
wethContract: WETH9Contract, wethContract: WETH9Contract,
cobbDouglasContract: TestCobbDouglasContract, cobbDouglasContract: TestCobbDouglasContract,
zrxVaultBackstopContract: ZrxVaultBackstopContract,
) { ) {
this._web3Wrapper = env.web3Wrapper; this._web3Wrapper = env.web3Wrapper;
this.zrxVaultContract = zrxVaultContract; this.zrxVaultContract = zrxVaultContract;
this.zrxTokenContract = zrxTokenContract; this.zrxTokenContract = zrxTokenContract;
this.wethContract = wethContract; this.wethContract = wethContract;
this.cobbDouglasContract = cobbDouglasContract; this.cobbDouglasContract = cobbDouglasContract;
this.zrxVaultBackstopContract = zrxVaultBackstopContract;
this.stakingContractAddress = stakingContract.address; this.stakingContractAddress = stakingContract.address;
this.stakingProxyContract = stakingProxyContract; this.stakingProxyContract = stakingProxyContract;
// disguise the staking proxy as a StakingContract // disguise the staking proxy as a StakingContract
@@ -249,14 +244,6 @@ export async function deployAndConfigureContractsAsync(
zrxVaultContract.address, zrxVaultContract.address,
); );
// deploy read-only proxy
const readOnlyProxyContract = await ReadOnlyProxyContract.deployFrom0xArtifactAsync(
artifacts.ReadOnlyProxy,
env.provider,
env.txDefaults,
artifacts,
);
// deploy staking proxy // deploy staking proxy
const stakingProxyContract = await StakingProxyContract.deployFrom0xArtifactAsync( const stakingProxyContract = await StakingProxyContract.deployFrom0xArtifactAsync(
artifacts.StakingProxy, artifacts.StakingProxy,
@@ -264,7 +251,6 @@ export async function deployAndConfigureContractsAsync(
env.txDefaults, env.txDefaults,
artifacts, artifacts,
stakingContract.address, stakingContract.address,
readOnlyProxyContract.address,
); );
await stakingProxyContract.addAuthorizedAddress.awaitTransactionSuccessAsync(ownerAddress); await stakingProxyContract.addAuthorizedAddress.awaitTransactionSuccessAsync(ownerAddress);
@@ -277,23 +263,10 @@ export async function deployAndConfigureContractsAsync(
artifacts, artifacts,
); );
const zrxVaultBackstopContract = await ZrxVaultBackstopContract.deployFrom0xArtifactAsync(
artifacts.ZrxVaultBackstop,
env.provider,
env.txDefaults,
artifacts,
stakingProxyContract.address,
zrxVaultContract.address,
);
// configure erc20 proxy to accept calls from zrx vault // configure erc20 proxy to accept calls from zrx vault
await erc20ProxyContract.addAuthorizedAddress.awaitTransactionSuccessAsync(zrxVaultContract.address); await erc20ProxyContract.addAuthorizedAddress.awaitTransactionSuccessAsync(zrxVaultContract.address);
// set staking proxy contract in zrx vault // set staking proxy contract in zrx vault
await zrxVaultContract.setStakingProxy.awaitTransactionSuccessAsync(stakingProxyContract.address); await zrxVaultContract.setStakingProxy.awaitTransactionSuccessAsync(stakingProxyContract.address);
// add zrxVaultBackstop as an authorized address
await zrxVaultContract.addAuthorizedAddress.awaitTransactionSuccessAsync(zrxVaultBackstopContract.address, {
from: ownerAddress,
});
return new StakingApiWrapper( return new StakingApiWrapper(
env, env,
ownerAddress, ownerAddress,
@@ -303,6 +276,5 @@ export async function deployAndConfigureContractsAsync(
zrxTokenContract, zrxTokenContract,
wethContract, wethContract,
cobbDouglasContract, cobbDouglasContract,
zrxVaultBackstopContract,
); );
} }

View File

@@ -1,51 +0,0 @@
import { ERC20Wrapper } from '@0x/contracts-asset-proxy';
import { blockchainTests, describe, expect, increaseTimeAndMineBlockAsync } from '@0x/contracts-test-utils';
import { StringRevertError } from '@0x/utils';
import { LogWithDecodedArgs } from 'ethereum-types';
import { ZrxVaultInCatastrophicFailureModeEventArgs } from '../src';
import { deployAndConfigureContractsAsync, StakingApiWrapper } from './utils/api_wrapper';
blockchainTests.resets('ZrxVaultBackstop', env => {
let stakingApiWrapper: StakingApiWrapper;
let authorizedAddress: string;
let notAuthorizedAddress: string;
before(async () => {
const accounts = await env.web3Wrapper.getAvailableAddressesAsync();
[authorizedAddress, notAuthorizedAddress] = accounts;
const erc20Wrapper = new ERC20Wrapper(env.provider, [], authorizedAddress);
stakingApiWrapper = await deployAndConfigureContractsAsync(env, authorizedAddress, erc20Wrapper);
});
describe('enterCatastrophicFailureIfProlongedReadOnlyMode', () => {
it('should revert if read-only mode is not set', async () => {
const expectedError = new StringRevertError('READ_ONLY_MODE_NOT_SET');
expect(
stakingApiWrapper.zrxVaultBackstopContract.enterCatastrophicFailureIfProlongedReadOnlyMode.awaitTransactionSuccessAsync(),
).to.revertWith(expectedError);
});
it('should revert if read-only mode has been set for less than 40 days', async () => {
await stakingApiWrapper.stakingProxyContract.setReadOnlyMode.awaitTransactionSuccessAsync(true, {
from: authorizedAddress,
});
const expectedError = new StringRevertError('READ_ONLY_MODE_DURATION_TOO_SHORT');
expect(
stakingApiWrapper.zrxVaultBackstopContract.enterCatastrophicFailureIfProlongedReadOnlyMode.awaitTransactionSuccessAsync(),
).to.revertWith(expectedError);
});
it('should enter catastophic failure mode if read-only mode has been set for 40 days', async () => {
await stakingApiWrapper.stakingProxyContract.setReadOnlyMode.awaitTransactionSuccessAsync(true, {
from: authorizedAddress,
});
const fourtyDaysInSec = 40 * 24 * 60 * 60;
await increaseTimeAndMineBlockAsync(fourtyDaysInSec);
const txReceipt = await stakingApiWrapper.zrxVaultBackstopContract.enterCatastrophicFailureIfProlongedReadOnlyMode.awaitTransactionSuccessAsync(
{ from: notAuthorizedAddress },
);
expect(txReceipt.logs.length).to.equal(1);
// tslint:disable:no-unnecessary-type-assertion
const logArgs = (txReceipt.logs[0] as LogWithDecodedArgs<ZrxVaultInCatastrophicFailureModeEventArgs>).args;
expect(logArgs.sender).to.equal(stakingApiWrapper.zrxVaultBackstopContract.address);
});
});
});

View File

@@ -10,7 +10,6 @@
"generated-artifacts/IStorageInit.json", "generated-artifacts/IStorageInit.json",
"generated-artifacts/IStructs.json", "generated-artifacts/IStructs.json",
"generated-artifacts/IZrxVault.json", "generated-artifacts/IZrxVault.json",
"generated-artifacts/IZrxVaultBackstop.json",
"generated-artifacts/LibCobbDouglas.json", "generated-artifacts/LibCobbDouglas.json",
"generated-artifacts/LibFixedMath.json", "generated-artifacts/LibFixedMath.json",
"generated-artifacts/LibFixedMathRichErrors.json", "generated-artifacts/LibFixedMathRichErrors.json",
@@ -32,7 +31,6 @@
"generated-artifacts/MixinStakingPool.json", "generated-artifacts/MixinStakingPool.json",
"generated-artifacts/MixinStakingPoolRewards.json", "generated-artifacts/MixinStakingPoolRewards.json",
"generated-artifacts/MixinStorage.json", "generated-artifacts/MixinStorage.json",
"generated-artifacts/ReadOnlyProxy.json",
"generated-artifacts/Staking.json", "generated-artifacts/Staking.json",
"generated-artifacts/StakingProxy.json", "generated-artifacts/StakingProxy.json",
"generated-artifacts/TestAssertStorageParams.json", "generated-artifacts/TestAssertStorageParams.json",
@@ -55,8 +53,7 @@
"generated-artifacts/TestStakingNoWETH.json", "generated-artifacts/TestStakingNoWETH.json",
"generated-artifacts/TestStakingProxy.json", "generated-artifacts/TestStakingProxy.json",
"generated-artifacts/TestStorageLayoutAndConstants.json", "generated-artifacts/TestStorageLayoutAndConstants.json",
"generated-artifacts/ZrxVault.json", "generated-artifacts/ZrxVault.json"
"generated-artifacts/ZrxVaultBackstop.json"
], ],
"exclude": ["./deploy/solc/solc_bin"] "exclude": ["./deploy/solc/solc_bin"]
} }