Apply prettier config
This commit is contained in:
@@ -1,15 +1,15 @@
|
||||
import {ZeroEx, ZeroExError} from '0x.js';
|
||||
import {promisify} from '@0xproject/utils';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { ZeroEx, ZeroExError } from '0x.js';
|
||||
import { promisify } from '@0xproject/utils';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import Web3 = require('web3');
|
||||
|
||||
import {Artifacts} from '../../util/artifacts';
|
||||
import {constants} from '../../util/constants';
|
||||
import { Artifacts } from '../../util/artifacts';
|
||||
import { constants } from '../../util/constants';
|
||||
|
||||
import {chaiSetup} from './utils/chai_setup';
|
||||
import { chaiSetup } from './utils/chai_setup';
|
||||
|
||||
const {EtherToken} = new Artifacts(artifacts);
|
||||
const { EtherToken } = new Artifacts(artifacts);
|
||||
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
@@ -44,8 +44,9 @@ contract('EtherToken', (accounts: string[]) => {
|
||||
const initEthBalance = await getEthBalanceAsync(account);
|
||||
const ethToDeposit = initEthBalance.plus(1);
|
||||
|
||||
return expect(zeroEx.etherToken.depositAsync(etherTokenAddress, ethToDeposit, account))
|
||||
.to.be.rejectedWith(ZeroExError.InsufficientEthBalanceForDeposit);
|
||||
return expect(zeroEx.etherToken.depositAsync(etherTokenAddress, ethToDeposit, account)).to.be.rejectedWith(
|
||||
ZeroExError.InsufficientEthBalanceForDeposit,
|
||||
);
|
||||
});
|
||||
|
||||
it('should convert deposited Ether to wrapped Ether tokens', async () => {
|
||||
@@ -71,8 +72,9 @@ contract('EtherToken', (accounts: string[]) => {
|
||||
const initEthTokenBalance = await zeroEx.token.getBalanceAsync(etherTokenAddress, account);
|
||||
const ethTokensToWithdraw = initEthTokenBalance.plus(1);
|
||||
|
||||
return expect(zeroEx.etherToken.withdrawAsync(etherTokenAddress, ethTokensToWithdraw, account))
|
||||
.to.be.rejectedWith(ZeroExError.InsufficientWEthBalanceForWithdrawal);
|
||||
return expect(
|
||||
zeroEx.etherToken.withdrawAsync(etherTokenAddress, ethTokensToWithdraw, account),
|
||||
).to.be.rejectedWith(ZeroExError.InsufficientWEthBalanceForWithdrawal);
|
||||
});
|
||||
|
||||
it('should convert ether tokens to ether with sufficient balance', async () => {
|
||||
@@ -89,8 +91,9 @@ contract('EtherToken', (accounts: string[]) => {
|
||||
const finalEthBalance = await getEthBalanceAsync(account);
|
||||
const finalEthTokenBalance = await zeroEx.token.getBalanceAsync(etherTokenAddress, account);
|
||||
|
||||
expect(finalEthBalance).to.be.bignumber
|
||||
.equal(initEthBalance.plus(ethTokensToWithdraw.minus(ethSpentOnGas)));
|
||||
expect(finalEthBalance).to.be.bignumber.equal(
|
||||
initEthBalance.plus(ethTokensToWithdraw.minus(ethSpentOnGas)),
|
||||
);
|
||||
expect(finalEthTokenBalance).to.be.bignumber.equal(initEthTokenBalance.minus(ethTokensToWithdraw));
|
||||
});
|
||||
});
|
||||
|
||||
@@ -1,28 +1,22 @@
|
||||
import {ZeroEx} from '0x.js';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { ZeroEx } from '0x.js';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import ethUtil = require('ethereumjs-util');
|
||||
import * as Web3 from 'web3';
|
||||
|
||||
import {Artifacts} from '../../../util/artifacts';
|
||||
import {Balances} from '../../../util/balances';
|
||||
import {constants} from '../../../util/constants';
|
||||
import {crypto} from '../../../util/crypto';
|
||||
import {ExchangeWrapper} from '../../../util/exchange_wrapper';
|
||||
import {Order} from '../../../util/order';
|
||||
import {OrderFactory} from '../../../util/order_factory';
|
||||
import {BalancesByOwner, ContractInstance, ExchangeContractErrs} from '../../../util/types';
|
||||
import {chaiSetup} from '../utils/chai_setup';
|
||||
import { Artifacts } from '../../../util/artifacts';
|
||||
import { Balances } from '../../../util/balances';
|
||||
import { constants } from '../../../util/constants';
|
||||
import { crypto } from '../../../util/crypto';
|
||||
import { ExchangeWrapper } from '../../../util/exchange_wrapper';
|
||||
import { Order } from '../../../util/order';
|
||||
import { OrderFactory } from '../../../util/order_factory';
|
||||
import { BalancesByOwner, ContractInstance, ExchangeContractErrs } from '../../../util/types';
|
||||
import { chaiSetup } from '../utils/chai_setup';
|
||||
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
const {
|
||||
Exchange,
|
||||
TokenTransferProxy,
|
||||
DummyToken,
|
||||
TokenRegistry,
|
||||
MaliciousToken,
|
||||
} = new Artifacts(artifacts);
|
||||
const { Exchange, TokenTransferProxy, DummyToken, TokenRegistry, MaliciousToken } = new Artifacts(artifacts);
|
||||
|
||||
// In order to benefit from type-safety, we re-assign the global web3 instance injected by Truffle
|
||||
// with type `any` to a variable of type `Web3`.
|
||||
@@ -52,10 +46,7 @@ contract('Exchange', (accounts: string[]) => {
|
||||
let zeroEx: ZeroEx;
|
||||
|
||||
before(async () => {
|
||||
[tokenRegistry, exchange] = await Promise.all([
|
||||
TokenRegistry.deployed(),
|
||||
Exchange.deployed(),
|
||||
]);
|
||||
[tokenRegistry, exchange] = await Promise.all([TokenRegistry.deployed(), Exchange.deployed()]);
|
||||
exWrapper = new ExchangeWrapper(exchange);
|
||||
zeroEx = new ZeroEx(web3.currentProvider, {
|
||||
exchangeContractAddress: exchange.address,
|
||||
@@ -88,18 +79,30 @@ contract('Exchange', (accounts: string[]) => {
|
||||
]);
|
||||
dmyBalances = new Balances([rep, dgd, zrx], [maker, taker, feeRecipient]);
|
||||
await Promise.all([
|
||||
rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: maker}),
|
||||
rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: taker}),
|
||||
rep.setBalance(maker, INITIAL_BALANCE, {from: tokenOwner}),
|
||||
rep.setBalance(taker, INITIAL_BALANCE, {from: tokenOwner}),
|
||||
dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: maker}),
|
||||
dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: taker}),
|
||||
dgd.setBalance(maker, INITIAL_BALANCE, {from: tokenOwner}),
|
||||
dgd.setBalance(taker, INITIAL_BALANCE, {from: tokenOwner}),
|
||||
zrx.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: maker}),
|
||||
zrx.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: taker}),
|
||||
zrx.setBalance(maker, INITIAL_BALANCE, {from: tokenOwner}),
|
||||
zrx.setBalance(taker, INITIAL_BALANCE, {from: tokenOwner}),
|
||||
rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: maker,
|
||||
}),
|
||||
rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: taker,
|
||||
}),
|
||||
rep.setBalance(maker, INITIAL_BALANCE, { from: tokenOwner }),
|
||||
rep.setBalance(taker, INITIAL_BALANCE, { from: tokenOwner }),
|
||||
dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: maker,
|
||||
}),
|
||||
dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: taker,
|
||||
}),
|
||||
dgd.setBalance(maker, INITIAL_BALANCE, { from: tokenOwner }),
|
||||
dgd.setBalance(taker, INITIAL_BALANCE, { from: tokenOwner }),
|
||||
zrx.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: maker,
|
||||
}),
|
||||
zrx.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: taker,
|
||||
}),
|
||||
zrx.setBalance(maker, INITIAL_BALANCE, { from: tokenOwner }),
|
||||
zrx.setBalance(taker, INITIAL_BALANCE, { from: tokenOwner }),
|
||||
]);
|
||||
});
|
||||
|
||||
@@ -133,22 +136,29 @@ contract('Exchange', (accounts: string[]) => {
|
||||
takerTokenAmount: new BigNumber(3),
|
||||
});
|
||||
|
||||
const filledTakerTokenAmountBefore =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountBefore = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountBefore).to.be.bignumber.equal(0);
|
||||
|
||||
const fillTakerTokenAmount1 = new BigNumber(2);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount: fillTakerTokenAmount1});
|
||||
await exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: fillTakerTokenAmount1,
|
||||
});
|
||||
|
||||
const filledTakerTokenAmountAfter1 =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountAfter1 = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountAfter1).to.be.bignumber.equal(fillTakerTokenAmount1);
|
||||
|
||||
const fillTakerTokenAmount2 = new BigNumber(1);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount: fillTakerTokenAmount2});
|
||||
await exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: fillTakerTokenAmount2,
|
||||
});
|
||||
|
||||
const filledTakerTokenAmountAfter2 =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountAfter2 = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountAfter2).to.be.bignumber.equal(filledTakerTokenAmountAfter1);
|
||||
});
|
||||
|
||||
@@ -158,42 +168,51 @@ contract('Exchange', (accounts: string[]) => {
|
||||
takerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(100), 18),
|
||||
});
|
||||
|
||||
const filledTakerTokenAmountBefore =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountBefore = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountBefore).to.be.bignumber.equal(0);
|
||||
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount});
|
||||
await exWrapper.fillOrderAsync(order, taker, { fillTakerTokenAmount });
|
||||
|
||||
const filledTakerTokenAmountAfter =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountAfter = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountAfter).to.be.bignumber.equal(fillTakerTokenAmount);
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
|
||||
const fillMakerTokenAmount = fillTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const paidMakerFee = order.params.makerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const paidTakerFee = order.params.takerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.makerToken].minus(fillMakerTokenAmount));
|
||||
expect(newBalances[maker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.takerToken].add(fillTakerTokenAmount));
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[maker][zrx.address].minus(paidMakerFee));
|
||||
expect(newBalances[taker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.takerToken].minus(fillTakerTokenAmount));
|
||||
expect(newBalances[taker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.makerToken].add(fillMakerTokenAmount));
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[taker][zrx.address].minus(paidTakerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)));
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.makerToken].minus(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.takerToken].add(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[maker][zrx.address].minus(paidMakerFee),
|
||||
);
|
||||
expect(newBalances[taker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.takerToken].minus(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.makerToken].add(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[taker][zrx.address].minus(paidTakerFee),
|
||||
);
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should transfer the correct amounts when makerTokenAmount > takerTokenAmount', async () => {
|
||||
@@ -202,42 +221,51 @@ contract('Exchange', (accounts: string[]) => {
|
||||
takerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(100), 18),
|
||||
});
|
||||
|
||||
const filledTakerTokenAmountBefore =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountBefore = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountBefore).to.be.bignumber.equal(0);
|
||||
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount});
|
||||
await exWrapper.fillOrderAsync(order, taker, { fillTakerTokenAmount });
|
||||
|
||||
const filledTakerTokenAmountAfter =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountAfter = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountAfter).to.be.bignumber.equal(fillTakerTokenAmount);
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
|
||||
const fillMakerTokenAmount = fillTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const paidMakerFee = order.params.makerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const paidTakerFee = order.params.takerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.makerToken].minus(fillMakerTokenAmount));
|
||||
expect(newBalances[maker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.takerToken].add(fillTakerTokenAmount));
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[maker][zrx.address].minus(paidMakerFee));
|
||||
expect(newBalances[taker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.takerToken].minus(fillTakerTokenAmount));
|
||||
expect(newBalances[taker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.makerToken].add(fillMakerTokenAmount));
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[taker][zrx.address].minus(paidTakerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)));
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.makerToken].minus(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.takerToken].add(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[maker][zrx.address].minus(paidMakerFee),
|
||||
);
|
||||
expect(newBalances[taker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.takerToken].minus(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.makerToken].add(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[taker][zrx.address].minus(paidTakerFee),
|
||||
);
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should transfer the correct amounts when makerTokenAmount < takerTokenAmount', async () => {
|
||||
@@ -246,42 +274,51 @@ contract('Exchange', (accounts: string[]) => {
|
||||
takerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(200), 18),
|
||||
});
|
||||
|
||||
const filledTakerTokenAmountBefore =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountBefore = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountBefore).to.be.bignumber.equal(0);
|
||||
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount});
|
||||
await exWrapper.fillOrderAsync(order, taker, { fillTakerTokenAmount });
|
||||
|
||||
const filledTakerTokenAmountAfter =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountAfter = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountAfter).to.be.bignumber.equal(fillTakerTokenAmount);
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
|
||||
const fillMakerTokenAmount = fillTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const paidMakerFee = order.params.makerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const paidTakerFee = order.params.takerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.makerToken].minus(fillMakerTokenAmount));
|
||||
expect(newBalances[maker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.takerToken].add(fillTakerTokenAmount));
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[maker][zrx.address].minus(paidMakerFee));
|
||||
expect(newBalances[taker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.takerToken].minus(fillTakerTokenAmount));
|
||||
expect(newBalances[taker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.makerToken].add(fillMakerTokenAmount));
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[taker][zrx.address].minus(paidTakerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)));
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.makerToken].minus(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.takerToken].add(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[maker][zrx.address].minus(paidMakerFee),
|
||||
);
|
||||
expect(newBalances[taker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.takerToken].minus(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.makerToken].add(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[taker][zrx.address].minus(paidTakerFee),
|
||||
);
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should transfer the correct amounts when taker is specified and order is claimed by taker', async () => {
|
||||
@@ -291,78 +328,95 @@ contract('Exchange', (accounts: string[]) => {
|
||||
takerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(200), 18),
|
||||
});
|
||||
|
||||
const filledTakerTokenAmountBefore =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountBefore = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
expect(filledTakerTokenAmountBefore).to.be.bignumber.equal(0);
|
||||
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount});
|
||||
await exWrapper.fillOrderAsync(order, taker, { fillTakerTokenAmount });
|
||||
|
||||
const filledTakerTokenAmountAfter =
|
||||
await zeroEx.exchange.getFilledTakerAmountAsync(order.params.orderHashHex);
|
||||
const filledTakerTokenAmountAfter = await zeroEx.exchange.getFilledTakerAmountAsync(
|
||||
order.params.orderHashHex,
|
||||
);
|
||||
const expectedFillAmountTAfter = fillTakerTokenAmount.add(filledTakerTokenAmountBefore);
|
||||
expect(filledTakerTokenAmountAfter).to.be.bignumber.equal(expectedFillAmountTAfter);
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
|
||||
const fillMakerTokenAmount = fillTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const paidMakerFee = order.params.makerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const paidTakerFee = order.params.takerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.makerToken].minus(fillMakerTokenAmount));
|
||||
expect(newBalances[maker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.takerToken].add(fillTakerTokenAmount));
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[maker][zrx.address].minus(paidMakerFee));
|
||||
expect(newBalances[taker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.takerToken].minus(fillTakerTokenAmount));
|
||||
expect(newBalances[taker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.makerToken].add(fillMakerTokenAmount));
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[taker][zrx.address].minus(paidTakerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)));
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.makerToken].minus(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.takerToken].add(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[maker][zrx.address].minus(paidMakerFee),
|
||||
);
|
||||
expect(newBalances[taker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.takerToken].minus(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.makerToken].add(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[taker][zrx.address].minus(paidTakerFee),
|
||||
);
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should fill remaining value if fillTakerTokenAmount > remaining takerTokenAmount', async () => {
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount});
|
||||
await exWrapper.fillOrderAsync(order, taker, { fillTakerTokenAmount });
|
||||
|
||||
const res = await exWrapper.fillOrderAsync(order, taker,
|
||||
{fillTakerTokenAmount: order.params.takerTokenAmount});
|
||||
const res = await exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: order.params.takerTokenAmount,
|
||||
});
|
||||
|
||||
expect(res.logs[0].args.filledTakerTokenAmount)
|
||||
.to.be.bignumber.equal(order.params.takerTokenAmount.minus(fillTakerTokenAmount));
|
||||
expect(res.logs[0].args.filledTakerTokenAmount).to.be.bignumber.equal(
|
||||
order.params.takerTokenAmount.minus(fillTakerTokenAmount),
|
||||
);
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
|
||||
expect(newBalances[maker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.makerToken].minus(order.params.makerTokenAmount));
|
||||
expect(newBalances[maker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.takerToken].add(order.params.takerTokenAmount));
|
||||
expect(newBalances[maker][zrx.address])
|
||||
.to.be.bignumber.equal(balances[maker][zrx.address].minus(order.params.makerFee));
|
||||
expect(newBalances[taker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.takerToken].minus(order.params.takerTokenAmount));
|
||||
expect(newBalances[taker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.makerToken].add(order.params.makerTokenAmount));
|
||||
expect(newBalances[taker][zrx.address])
|
||||
.to.be.bignumber.equal(balances[taker][zrx.address].minus(order.params.takerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(order.params.makerFee.add(order.params.takerFee)),
|
||||
);
|
||||
expect(newBalances[maker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.makerToken].minus(order.params.makerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.takerToken].add(order.params.takerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[maker][zrx.address].minus(order.params.makerFee),
|
||||
);
|
||||
expect(newBalances[taker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.takerToken].minus(order.params.takerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.makerToken].add(order.params.makerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[taker][zrx.address].minus(order.params.takerFee),
|
||||
);
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(order.params.makerFee.add(order.params.takerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should log 1 event with the correct arguments when order has a feeRecipient', async () => {
|
||||
const divisor = 2;
|
||||
const res = await exWrapper.fillOrderAsync(order, taker,
|
||||
{fillTakerTokenAmount: order.params.takerTokenAmount.div(divisor)});
|
||||
const res = await exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: order.params.takerTokenAmount.div(divisor),
|
||||
});
|
||||
expect(res.logs).to.have.length(1);
|
||||
|
||||
const logArgs = res.logs[0].args;
|
||||
@@ -391,8 +445,9 @@ contract('Exchange', (accounts: string[]) => {
|
||||
feeRecipient: ZeroEx.NULL_ADDRESS,
|
||||
});
|
||||
const divisor = 2;
|
||||
const res = await exWrapper.fillOrderAsync(order, taker,
|
||||
{fillTakerTokenAmount: order.params.takerTokenAmount.div(divisor)});
|
||||
const res = await exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: order.params.takerTokenAmount.div(divisor),
|
||||
});
|
||||
expect(res.logs).to.have.length(1);
|
||||
|
||||
const logArgs = res.logs[0].args;
|
||||
@@ -455,13 +510,15 @@ contract('Exchange', (accounts: string[]) => {
|
||||
it('should throw if fillTakerTokenAmount is 0', async () => {
|
||||
order = await orderFactory.newSignedOrderAsync();
|
||||
|
||||
return expect(exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount: new BigNumber(0)}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: new BigNumber(0),
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should not change balances if maker balances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
makerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(100000), 18),
|
||||
});
|
||||
@@ -472,19 +529,20 @@ contract('Exchange', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should throw if maker balances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true',
|
||||
async () => {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true', async () => {
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
makerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(100000), 18),
|
||||
});
|
||||
|
||||
return expect(exWrapper.fillOrderAsync(order, taker, {shouldThrowOnInsufficientBalanceOrAllowance: true}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
exWrapper.fillOrderAsync(order, taker, {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance: true,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should not change balances if taker balances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
takerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(100000), 18),
|
||||
});
|
||||
@@ -495,59 +553,70 @@ contract('Exchange', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should throw if taker balances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true',
|
||||
async () => {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true', async () => {
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
takerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(100000), 18),
|
||||
});
|
||||
|
||||
return expect(exWrapper.fillOrderAsync(order, taker, {shouldThrowOnInsufficientBalanceOrAllowance: true}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
exWrapper.fillOrderAsync(order, taker, {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance: true,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should not change balances if maker allowances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
await rep.approve(TokenTransferProxy.address, 0, {from: maker});
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
await rep.approve(TokenTransferProxy.address, 0, { from: maker });
|
||||
await exWrapper.fillOrderAsync(order, taker);
|
||||
await rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: maker});
|
||||
await rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: maker,
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(newBalances).to.be.deep.equal(balances);
|
||||
});
|
||||
|
||||
it('should throw if maker allowances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true',
|
||||
async () => {
|
||||
await rep.approve(TokenTransferProxy.address, 0, {from: maker});
|
||||
expect(exWrapper.fillOrderAsync(order, taker, {shouldThrowOnInsufficientBalanceOrAllowance: true}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
await rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: maker});
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true', async () => {
|
||||
await rep.approve(TokenTransferProxy.address, 0, { from: maker });
|
||||
expect(
|
||||
exWrapper.fillOrderAsync(order, taker, {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance: true,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
await rep.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: maker,
|
||||
});
|
||||
});
|
||||
|
||||
it('should not change balances if taker allowances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
await dgd.approve(TokenTransferProxy.address, 0, {from: taker});
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
await dgd.approve(TokenTransferProxy.address, 0, { from: taker });
|
||||
await exWrapper.fillOrderAsync(order, taker);
|
||||
await dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: taker});
|
||||
await dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: taker,
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(newBalances).to.be.deep.equal(balances);
|
||||
});
|
||||
|
||||
it('should throw if taker allowances are too low to fill order and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true',
|
||||
async () => {
|
||||
await dgd.approve(TokenTransferProxy.address, 0, {from: taker});
|
||||
expect(exWrapper.fillOrderAsync(order, taker, {shouldThrowOnInsufficientBalanceOrAllowance: true}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
await dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: taker});
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = true', async () => {
|
||||
await dgd.approve(TokenTransferProxy.address, 0, { from: taker });
|
||||
expect(
|
||||
exWrapper.fillOrderAsync(order, taker, {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance: true,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
await dgd.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {
|
||||
from: taker,
|
||||
});
|
||||
});
|
||||
|
||||
it('should not change balances if makerToken is ZRX, makerTokenAmount + makerFee > maker balance, \
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
const makerZRXBalance = new BigNumber(balances[maker][zrx.address]);
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
makerToken: zrx.address,
|
||||
@@ -560,8 +629,7 @@ contract('Exchange', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should not change balances if makerToken is ZRX, makerTokenAmount + makerFee > maker allowance, \
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
const makerZRXAllowance = await zrx.allowance(maker, TokenTransferProxy.address);
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
makerToken: zrx.address,
|
||||
@@ -574,8 +642,7 @@ contract('Exchange', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should not change balances if takerToken is ZRX, takerTokenAmount + takerFee > taker balance, \
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
const takerZRXBalance = new BigNumber(balances[taker][zrx.address]);
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
takerToken: zrx.address,
|
||||
@@ -588,8 +655,7 @@ contract('Exchange', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should not change balances if takerToken is ZRX, takerTokenAmount + takerFee > taker allowance, \
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false',
|
||||
async () => {
|
||||
and shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
const takerZRXAllowance = await zrx.allowance(taker, TokenTransferProxy.address);
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
takerToken: zrx.address,
|
||||
@@ -604,14 +670,17 @@ contract('Exchange', (accounts: string[]) => {
|
||||
it('should throw if getBalance or getAllowance attempts to change state and \
|
||||
shouldThrowOnInsufficientBalanceOrAllowance = false', async () => {
|
||||
const maliciousToken = await MaliciousToken.new();
|
||||
await maliciousToken.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, {from: taker});
|
||||
await maliciousToken.approve(TokenTransferProxy.address, INITIAL_ALLOWANCE, { from: taker });
|
||||
|
||||
order = await orderFactory.newSignedOrderAsync({
|
||||
takerToken: maliciousToken.address,
|
||||
});
|
||||
|
||||
return expect(exWrapper.fillOrderAsync(order, taker, {shouldThrowOnInsufficientBalanceOrAllowance: false}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
exWrapper.fillOrderAsync(order, taker, {
|
||||
shouldThrowOnInsufficientBalanceOrAllowance: false,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should not change balances if an order is expired', async () => {
|
||||
@@ -674,13 +743,18 @@ contract('Exchange', (accounts: string[]) => {
|
||||
it('should throw if cancelTakerTokenAmount is 0', async () => {
|
||||
order = await orderFactory.newSignedOrderAsync();
|
||||
|
||||
return expect(exWrapper.cancelOrderAsync(order, maker, {cancelTakerTokenAmount: new BigNumber(0)}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
exWrapper.cancelOrderAsync(order, maker, {
|
||||
cancelTakerTokenAmount: new BigNumber(0),
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should be able to cancel a full order', async () => {
|
||||
await exWrapper.cancelOrderAsync(order, maker);
|
||||
await exWrapper.fillOrderAsync(order, taker, {fillTakerTokenAmount: order.params.takerTokenAmount.div(2)});
|
||||
await exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: order.params.takerTokenAmount.div(2),
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(newBalances).to.be.deep.equal(balances);
|
||||
@@ -688,43 +762,55 @@ contract('Exchange', (accounts: string[]) => {
|
||||
|
||||
it('should be able to cancel part of an order', async () => {
|
||||
const cancelTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
await exWrapper.cancelOrderAsync(order, maker, {cancelTakerTokenAmount});
|
||||
await exWrapper.cancelOrderAsync(order, maker, {
|
||||
cancelTakerTokenAmount,
|
||||
});
|
||||
|
||||
const res = await exWrapper.fillOrderAsync(order, taker,
|
||||
{fillTakerTokenAmount: order.params.takerTokenAmount});
|
||||
expect(res.logs[0].args.filledTakerTokenAmount)
|
||||
.to.be.bignumber.equal(order.params.takerTokenAmount.minus(cancelTakerTokenAmount));
|
||||
const res = await exWrapper.fillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount: order.params.takerTokenAmount,
|
||||
});
|
||||
expect(res.logs[0].args.filledTakerTokenAmount).to.be.bignumber.equal(
|
||||
order.params.takerTokenAmount.minus(cancelTakerTokenAmount),
|
||||
);
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
const cancelMakerTokenAmount = cancelTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const paidMakerFee = order.params.makerFee
|
||||
.times(cancelMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(cancelMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const paidTakerFee = order.params.takerFee
|
||||
.times(cancelMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.makerToken].minus(cancelMakerTokenAmount));
|
||||
expect(newBalances[maker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.takerToken].add(cancelTakerTokenAmount));
|
||||
expect(newBalances[maker][zrx.address])
|
||||
.to.be.bignumber.equal(balances[maker][zrx.address].minus(paidMakerFee));
|
||||
expect(newBalances[taker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.takerToken].minus(cancelTakerTokenAmount));
|
||||
expect(newBalances[taker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.makerToken].add(cancelMakerTokenAmount));
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[taker][zrx.address].minus(paidTakerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)));
|
||||
.times(cancelMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.makerToken].minus(cancelMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.takerToken].add(cancelTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[maker][zrx.address].minus(paidMakerFee),
|
||||
);
|
||||
expect(newBalances[taker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.takerToken].minus(cancelTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.makerToken].add(cancelMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[taker][zrx.address].minus(paidTakerFee),
|
||||
);
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(paidMakerFee.add(paidTakerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should log 1 event with correct arguments', async () => {
|
||||
const divisor = 2;
|
||||
const res = await exWrapper.cancelOrderAsync(order, maker,
|
||||
{cancelTakerTokenAmount: order.params.takerTokenAmount.div(divisor)});
|
||||
const res = await exWrapper.cancelOrderAsync(order, maker, {
|
||||
cancelTakerTokenAmount: order.params.takerTokenAmount.div(divisor),
|
||||
});
|
||||
expect(res.logs).to.have.length(1);
|
||||
|
||||
const logArgs = res.logs[0].args;
|
||||
|
||||
@@ -1,21 +1,18 @@
|
||||
import {ZeroEx} from '0x.js';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { ZeroEx } from '0x.js';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import ethUtil = require('ethereumjs-util');
|
||||
|
||||
import {Artifacts} from '../../../util/artifacts';
|
||||
import {ExchangeWrapper} from '../../../util/exchange_wrapper';
|
||||
import {Order} from '../../../util/order';
|
||||
import {OrderFactory} from '../../../util/order_factory';
|
||||
import {chaiSetup} from '../utils/chai_setup';
|
||||
import { Artifacts } from '../../../util/artifacts';
|
||||
import { ExchangeWrapper } from '../../../util/exchange_wrapper';
|
||||
import { Order } from '../../../util/order';
|
||||
import { OrderFactory } from '../../../util/order_factory';
|
||||
import { chaiSetup } from '../utils/chai_setup';
|
||||
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
|
||||
const {
|
||||
Exchange,
|
||||
TokenRegistry,
|
||||
} = new Artifacts(artifacts);
|
||||
const { Exchange, TokenRegistry } = new Artifacts(artifacts);
|
||||
|
||||
contract('Exchange', (accounts: string[]) => {
|
||||
const maker = accounts[0];
|
||||
@@ -26,10 +23,7 @@ contract('Exchange', (accounts: string[]) => {
|
||||
let orderFactory: OrderFactory;
|
||||
|
||||
before(async () => {
|
||||
const [tokenRegistry, exchange] = await Promise.all([
|
||||
TokenRegistry.deployed(),
|
||||
Exchange.deployed(),
|
||||
]);
|
||||
const [tokenRegistry, exchange] = await Promise.all([TokenRegistry.deployed(), Exchange.deployed()]);
|
||||
exchangeWrapper = new ExchangeWrapper(exchange);
|
||||
const [repAddress, dgdAddress] = await Promise.all([
|
||||
tokenRegistry.getTokenAddressBySymbol('REP'),
|
||||
|
||||
@@ -1,25 +1,20 @@
|
||||
import {ZeroEx} from '0x.js';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { ZeroEx } from '0x.js';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import * as _ from 'lodash';
|
||||
|
||||
import {Artifacts} from '../../../util/artifacts';
|
||||
import {Balances} from '../../../util/balances';
|
||||
import {constants} from '../../../util/constants';
|
||||
import {ExchangeWrapper} from '../../../util/exchange_wrapper';
|
||||
import {Order} from '../../../util/order';
|
||||
import {OrderFactory} from '../../../util/order_factory';
|
||||
import {BalancesByOwner, ContractInstance} from '../../../util/types';
|
||||
import {chaiSetup} from '../utils/chai_setup';
|
||||
import { Artifacts } from '../../../util/artifacts';
|
||||
import { Balances } from '../../../util/balances';
|
||||
import { constants } from '../../../util/constants';
|
||||
import { ExchangeWrapper } from '../../../util/exchange_wrapper';
|
||||
import { Order } from '../../../util/order';
|
||||
import { OrderFactory } from '../../../util/order_factory';
|
||||
import { BalancesByOwner, ContractInstance } from '../../../util/types';
|
||||
import { chaiSetup } from '../utils/chai_setup';
|
||||
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
const {
|
||||
Exchange,
|
||||
TokenTransferProxy,
|
||||
DummyToken,
|
||||
TokenRegistry,
|
||||
} = new Artifacts(artifacts);
|
||||
const { Exchange, TokenTransferProxy, DummyToken, TokenRegistry } = new Artifacts(artifacts);
|
||||
|
||||
contract('Exchange', (accounts: string[]) => {
|
||||
const maker = accounts[0];
|
||||
@@ -43,10 +38,7 @@ contract('Exchange', (accounts: string[]) => {
|
||||
let orderFactory: OrderFactory;
|
||||
|
||||
before(async () => {
|
||||
[tokenRegistry, exchange] = await Promise.all([
|
||||
TokenRegistry.deployed(),
|
||||
Exchange.deployed(),
|
||||
]);
|
||||
[tokenRegistry, exchange] = await Promise.all([TokenRegistry.deployed(), Exchange.deployed()]);
|
||||
exWrapper = new ExchangeWrapper(exchange);
|
||||
const [repAddress, dgdAddress, zrxAddress] = await Promise.all([
|
||||
tokenRegistry.getTokenAddressBySymbol('REP'),
|
||||
@@ -74,18 +66,18 @@ contract('Exchange', (accounts: string[]) => {
|
||||
]);
|
||||
dmyBalances = new Balances([rep, dgd, zrx], [maker, taker, feeRecipient]);
|
||||
await Promise.all([
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, {from: maker}),
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, {from: taker}),
|
||||
rep.setBalance(maker, INIT_BAL, {from: tokenOwner}),
|
||||
rep.setBalance(taker, INIT_BAL, {from: tokenOwner}),
|
||||
dgd.approve(TokenTransferProxy.address, INIT_ALLOW, {from: maker}),
|
||||
dgd.approve(TokenTransferProxy.address, INIT_ALLOW, {from: taker}),
|
||||
dgd.setBalance(maker, INIT_BAL, {from: tokenOwner}),
|
||||
dgd.setBalance(taker, INIT_BAL, {from: tokenOwner}),
|
||||
zrx.approve(TokenTransferProxy.address, INIT_ALLOW, {from: maker}),
|
||||
zrx.approve(TokenTransferProxy.address, INIT_ALLOW, {from: taker}),
|
||||
zrx.setBalance(maker, INIT_BAL, {from: tokenOwner}),
|
||||
zrx.setBalance(taker, INIT_BAL, {from: tokenOwner}),
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, { from: maker }),
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, { from: taker }),
|
||||
rep.setBalance(maker, INIT_BAL, { from: tokenOwner }),
|
||||
rep.setBalance(taker, INIT_BAL, { from: tokenOwner }),
|
||||
dgd.approve(TokenTransferProxy.address, INIT_ALLOW, { from: maker }),
|
||||
dgd.approve(TokenTransferProxy.address, INIT_ALLOW, { from: taker }),
|
||||
dgd.setBalance(maker, INIT_BAL, { from: tokenOwner }),
|
||||
dgd.setBalance(taker, INIT_BAL, { from: tokenOwner }),
|
||||
zrx.approve(TokenTransferProxy.address, INIT_ALLOW, { from: maker }),
|
||||
zrx.approve(TokenTransferProxy.address, INIT_ALLOW, { from: taker }),
|
||||
zrx.setBalance(maker, INIT_BAL, { from: tokenOwner }),
|
||||
zrx.setBalance(taker, INIT_BAL, { from: tokenOwner }),
|
||||
]);
|
||||
});
|
||||
|
||||
@@ -100,31 +92,38 @@ contract('Exchange', (accounts: string[]) => {
|
||||
takerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(200), 18),
|
||||
});
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
await exWrapper.fillOrKillOrderAsync(order, taker, {fillTakerTokenAmount});
|
||||
await exWrapper.fillOrKillOrderAsync(order, taker, {
|
||||
fillTakerTokenAmount,
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
|
||||
const fillMakerTokenAmount = fillTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const makerFee = order.params.makerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const takerFee = order.params.takerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.makerToken].minus(fillMakerTokenAmount));
|
||||
expect(newBalances[maker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][order.params.takerToken].add(fillTakerTokenAmount));
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
expect(newBalances[maker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.makerToken].minus(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][order.params.takerToken].add(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(balances[maker][zrx.address].minus(makerFee));
|
||||
expect(newBalances[taker][order.params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.takerToken].minus(fillTakerTokenAmount));
|
||||
expect(newBalances[taker][order.params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][order.params.makerToken].add(fillMakerTokenAmount));
|
||||
expect(newBalances[taker][order.params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.takerToken].minus(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][order.params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][order.params.makerToken].add(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(balances[taker][zrx.address].minus(takerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(balances[feeRecipient][zrx.address].add(makerFee.add(takerFee)));
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(makerFee.add(takerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should throw if an order is expired', async () => {
|
||||
@@ -132,18 +131,18 @@ contract('Exchange', (accounts: string[]) => {
|
||||
expirationTimestampInSec: new BigNumber(Math.floor((Date.now() - 10000) / 1000)),
|
||||
});
|
||||
|
||||
return expect(exWrapper.fillOrKillOrderAsync(order, taker))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(exWrapper.fillOrKillOrderAsync(order, taker)).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should throw if entire fillTakerTokenAmount not filled', async () => {
|
||||
const order = await orderFactory.newSignedOrderAsync();
|
||||
|
||||
const from = taker;
|
||||
await exWrapper.fillOrderAsync(order, from, {fillTakerTokenAmount: order.params.takerTokenAmount.div(2)});
|
||||
await exWrapper.fillOrderAsync(order, from, {
|
||||
fillTakerTokenAmount: order.params.takerTokenAmount.div(2),
|
||||
});
|
||||
|
||||
return expect(exWrapper.fillOrKillOrderAsync(order, taker))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(exWrapper.fillOrKillOrderAsync(order, taker)).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
});
|
||||
|
||||
@@ -166,14 +165,14 @@ contract('Exchange', (accounts: string[]) => {
|
||||
orders.forEach(order => {
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
const fillMakerTokenAmount = fillTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const makerFee = order.params.makerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const takerFee = order.params.takerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
fillTakerTokenAmounts.push(fillTakerTokenAmount);
|
||||
balances[maker][makerToken] = balances[maker][makerToken].minus(fillMakerTokenAmount);
|
||||
balances[maker][takerToken] = balances[maker][takerToken].add(fillTakerTokenAmount);
|
||||
@@ -181,11 +180,14 @@ contract('Exchange', (accounts: string[]) => {
|
||||
balances[taker][makerToken] = balances[taker][makerToken].add(fillMakerTokenAmount);
|
||||
balances[taker][takerToken] = balances[taker][takerToken].minus(fillTakerTokenAmount);
|
||||
balances[taker][zrx.address] = balances[taker][zrx.address].minus(takerFee);
|
||||
balances[feeRecipient][zrx.address] =
|
||||
balances[feeRecipient][zrx.address].add(makerFee.add(takerFee));
|
||||
balances[feeRecipient][zrx.address] = balances[feeRecipient][zrx.address].add(
|
||||
makerFee.add(takerFee),
|
||||
);
|
||||
});
|
||||
|
||||
await exWrapper.batchFillOrdersAsync(orders, taker, {fillTakerTokenAmounts});
|
||||
await exWrapper.batchFillOrdersAsync(orders, taker, {
|
||||
fillTakerTokenAmounts,
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(newBalances).to.be.deep.equal(balances);
|
||||
@@ -200,14 +202,14 @@ contract('Exchange', (accounts: string[]) => {
|
||||
orders.forEach(order => {
|
||||
const fillTakerTokenAmount = order.params.takerTokenAmount.div(2);
|
||||
const fillMakerTokenAmount = fillTakerTokenAmount
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
.times(order.params.makerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.takerTokenAmount);
|
||||
const makerFee = order.params.makerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
const takerFee = order.params.takerFee
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
.times(fillMakerTokenAmount)
|
||||
.dividedToIntegerBy(order.params.makerTokenAmount);
|
||||
fillTakerTokenAmounts.push(fillTakerTokenAmount);
|
||||
balances[maker][makerToken] = balances[maker][makerToken].minus(fillMakerTokenAmount);
|
||||
balances[maker][takerToken] = balances[maker][takerToken].add(fillTakerTokenAmount);
|
||||
@@ -215,11 +217,14 @@ contract('Exchange', (accounts: string[]) => {
|
||||
balances[taker][makerToken] = balances[taker][makerToken].add(fillMakerTokenAmount);
|
||||
balances[taker][takerToken] = balances[taker][takerToken].minus(fillTakerTokenAmount);
|
||||
balances[taker][zrx.address] = balances[taker][zrx.address].minus(takerFee);
|
||||
balances[feeRecipient][zrx.address] =
|
||||
balances[feeRecipient][zrx.address].add(makerFee.add(takerFee));
|
||||
balances[feeRecipient][zrx.address] = balances[feeRecipient][zrx.address].add(
|
||||
makerFee.add(takerFee),
|
||||
);
|
||||
});
|
||||
|
||||
await exWrapper.batchFillOrKillOrdersAsync(orders, taker, {fillTakerTokenAmounts});
|
||||
await exWrapper.batchFillOrKillOrdersAsync(orders, taker, {
|
||||
fillTakerTokenAmounts,
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(newBalances).to.be.deep.equal(balances);
|
||||
@@ -234,57 +239,77 @@ contract('Exchange', (accounts: string[]) => {
|
||||
|
||||
await exWrapper.fillOrKillOrderAsync(orders[0], taker);
|
||||
|
||||
return expect(exWrapper.batchFillOrKillOrdersAsync(orders, taker, {fillTakerTokenAmounts}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
exWrapper.batchFillOrKillOrdersAsync(orders, taker, {
|
||||
fillTakerTokenAmounts,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
});
|
||||
|
||||
describe('fillOrdersUpTo', () => {
|
||||
it('should stop when the entire fillTakerTokenAmount is filled', async () => {
|
||||
const fillTakerTokenAmount =
|
||||
orders[0].params.takerTokenAmount.plus(orders[1].params.takerTokenAmount.div(2));
|
||||
await exWrapper.fillOrdersUpToAsync(orders, taker, {fillTakerTokenAmount});
|
||||
const fillTakerTokenAmount = orders[0].params.takerTokenAmount.plus(
|
||||
orders[1].params.takerTokenAmount.div(2),
|
||||
);
|
||||
await exWrapper.fillOrdersUpToAsync(orders, taker, {
|
||||
fillTakerTokenAmount,
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
|
||||
const fillMakerTokenAmount = orders[0].params.makerTokenAmount.add(
|
||||
orders[1].params.makerTokenAmount.dividedToIntegerBy(2));
|
||||
orders[1].params.makerTokenAmount.dividedToIntegerBy(2),
|
||||
);
|
||||
const makerFee = orders[0].params.makerFee.add(orders[1].params.makerFee.dividedToIntegerBy(2));
|
||||
const takerFee = orders[0].params.takerFee.add(orders[1].params.takerFee.dividedToIntegerBy(2));
|
||||
expect(newBalances[maker][orders[0].params.makerToken])
|
||||
.to.be.bignumber.equal(balances[maker][orders[0].params.makerToken].minus(fillMakerTokenAmount));
|
||||
expect(newBalances[maker][orders[0].params.takerToken])
|
||||
.to.be.bignumber.equal(balances[maker][orders[0].params.takerToken].add(fillTakerTokenAmount));
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[maker][zrx.address].minus(makerFee));
|
||||
expect(newBalances[taker][orders[0].params.takerToken])
|
||||
.to.be.bignumber.equal(balances[taker][orders[0].params.takerToken].minus(fillTakerTokenAmount));
|
||||
expect(newBalances[taker][orders[0].params.makerToken])
|
||||
.to.be.bignumber.equal(balances[taker][orders[0].params.makerToken].add(fillMakerTokenAmount));
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber
|
||||
.equal(balances[taker][zrx.address].minus(takerFee));
|
||||
expect(newBalances[feeRecipient][zrx.address])
|
||||
.to.be.bignumber.equal(balances[feeRecipient][zrx.address].add(makerFee.add(takerFee)));
|
||||
expect(newBalances[maker][orders[0].params.makerToken]).to.be.bignumber.equal(
|
||||
balances[maker][orders[0].params.makerToken].minus(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][orders[0].params.takerToken]).to.be.bignumber.equal(
|
||||
balances[maker][orders[0].params.takerToken].add(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[maker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[maker][zrx.address].minus(makerFee),
|
||||
);
|
||||
expect(newBalances[taker][orders[0].params.takerToken]).to.be.bignumber.equal(
|
||||
balances[taker][orders[0].params.takerToken].minus(fillTakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][orders[0].params.makerToken]).to.be.bignumber.equal(
|
||||
balances[taker][orders[0].params.makerToken].add(fillMakerTokenAmount),
|
||||
);
|
||||
expect(newBalances[taker][zrx.address]).to.be.bignumber.equal(
|
||||
balances[taker][zrx.address].minus(takerFee),
|
||||
);
|
||||
expect(newBalances[feeRecipient][zrx.address]).to.be.bignumber.equal(
|
||||
balances[feeRecipient][zrx.address].add(makerFee.add(takerFee)),
|
||||
);
|
||||
});
|
||||
|
||||
it('should fill all orders if cannot fill entire fillTakerTokenAmount', async () => {
|
||||
const fillTakerTokenAmount = ZeroEx.toBaseUnitAmount(new BigNumber(100000), 18);
|
||||
orders.forEach(order => {
|
||||
balances[maker][order.params.makerToken] = balances[maker][order.params.makerToken]
|
||||
.minus(order.params.makerTokenAmount);
|
||||
balances[maker][order.params.takerToken] = balances[maker][order.params.takerToken]
|
||||
.add(order.params.takerTokenAmount);
|
||||
balances[maker][zrx.address] = balances[maker][zrx.address]
|
||||
.minus(order.params.makerFee);
|
||||
balances[taker][order.params.makerToken] = balances[taker][order.params.makerToken]
|
||||
.add(order.params.makerTokenAmount);
|
||||
balances[taker][order.params.takerToken] = balances[taker][order.params.takerToken]
|
||||
.minus(order.params.takerTokenAmount);
|
||||
balances[maker][order.params.makerToken] = balances[maker][order.params.makerToken].minus(
|
||||
order.params.makerTokenAmount,
|
||||
);
|
||||
balances[maker][order.params.takerToken] = balances[maker][order.params.takerToken].add(
|
||||
order.params.takerTokenAmount,
|
||||
);
|
||||
balances[maker][zrx.address] = balances[maker][zrx.address].minus(order.params.makerFee);
|
||||
balances[taker][order.params.makerToken] = balances[taker][order.params.makerToken].add(
|
||||
order.params.makerTokenAmount,
|
||||
);
|
||||
balances[taker][order.params.takerToken] = balances[taker][order.params.takerToken].minus(
|
||||
order.params.takerTokenAmount,
|
||||
);
|
||||
balances[taker][zrx.address] = balances[taker][zrx.address].minus(order.params.takerFee);
|
||||
balances[feeRecipient][zrx.address] =
|
||||
balances[feeRecipient][zrx.address].add(order.params.makerFee.add(order.params.takerFee));
|
||||
balances[feeRecipient][zrx.address] = balances[feeRecipient][zrx.address].add(
|
||||
order.params.makerFee.add(order.params.takerFee),
|
||||
);
|
||||
});
|
||||
await exWrapper.fillOrdersUpToAsync(orders, taker, {
|
||||
fillTakerTokenAmount,
|
||||
});
|
||||
await exWrapper.fillOrdersUpToAsync(orders, taker, {fillTakerTokenAmount});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(newBalances).to.be.deep.equal(balances);
|
||||
@@ -293,13 +318,14 @@ contract('Exchange', (accounts: string[]) => {
|
||||
it('should throw when an order does not use the same takerToken', async () => {
|
||||
orders = await Promise.all([
|
||||
orderFactory.newSignedOrderAsync(),
|
||||
orderFactory.newSignedOrderAsync({takerToken: zrx.address}),
|
||||
orderFactory.newSignedOrderAsync({ takerToken: zrx.address }),
|
||||
orderFactory.newSignedOrderAsync(),
|
||||
]);
|
||||
|
||||
return expect(
|
||||
exWrapper.fillOrdersUpToAsync(
|
||||
orders, taker, {fillTakerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(1000), 18)}),
|
||||
exWrapper.fillOrdersUpToAsync(orders, taker, {
|
||||
fillTakerTokenAmount: ZeroEx.toBaseUnitAmount(new BigNumber(1000), 18),
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
});
|
||||
@@ -307,10 +333,13 @@ contract('Exchange', (accounts: string[]) => {
|
||||
describe('batchCancelOrders', () => {
|
||||
it('should be able to cancel multiple orders', async () => {
|
||||
const cancelTakerTokenAmounts = _.map(orders, order => order.params.takerTokenAmount);
|
||||
await exWrapper.batchCancelOrdersAsync(orders, maker, {cancelTakerTokenAmounts});
|
||||
await exWrapper.batchCancelOrdersAsync(orders, maker, {
|
||||
cancelTakerTokenAmounts,
|
||||
});
|
||||
|
||||
await exWrapper.batchFillOrdersAsync(
|
||||
orders, taker, {fillTakerTokenAmounts: cancelTakerTokenAmounts});
|
||||
await exWrapper.batchFillOrdersAsync(orders, taker, {
|
||||
fillTakerTokenAmounts: cancelTakerTokenAmounts,
|
||||
});
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(balances).to.be.deep.equal(newBalances);
|
||||
});
|
||||
|
||||
@@ -1,19 +1,19 @@
|
||||
import {RPC} from '@0xproject/dev-utils';
|
||||
import {promisify} from '@0xproject/utils';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { RPC } from '@0xproject/dev-utils';
|
||||
import { promisify } from '@0xproject/utils';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import Web3 = require('web3');
|
||||
|
||||
import * as multiSigWalletJSON from '../../build/contracts/MultiSigWalletWithTimeLock.json';
|
||||
import * as truffleConf from '../../truffle.js';
|
||||
import {Artifacts} from '../../util/artifacts';
|
||||
import {constants} from '../../util/constants';
|
||||
import {MultiSigWrapper} from '../../util/multi_sig_wrapper';
|
||||
import {ContractInstance} from '../../util/types';
|
||||
import { Artifacts } from '../../util/artifacts';
|
||||
import { constants } from '../../util/constants';
|
||||
import { MultiSigWrapper } from '../../util/multi_sig_wrapper';
|
||||
import { ContractInstance } from '../../util/types';
|
||||
|
||||
import {chaiSetup} from './utils/chai_setup';
|
||||
import { chaiSetup } from './utils/chai_setup';
|
||||
|
||||
const {MultiSigWalletWithTimeLock} = new Artifacts(artifacts);
|
||||
const { MultiSigWalletWithTimeLock } = new Artifacts(artifacts);
|
||||
|
||||
const MULTI_SIG_ABI = (multiSigWalletJSON as any).abi;
|
||||
chaiSetup.configure();
|
||||
@@ -45,8 +45,9 @@ contract('MultiSigWalletWithTimeLock', (accounts: string[]) => {
|
||||
|
||||
describe('changeTimeLock', () => {
|
||||
it('should throw when not called by wallet', async () => {
|
||||
return expect(multiSig.changeTimeLock(SECONDS_TIME_LOCKED, {from: owners[0]}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(multiSig.changeTimeLock(SECONDS_TIME_LOCKED, { from: owners[0] })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
it('should throw without enough confirmations', async () => {
|
||||
@@ -64,7 +65,7 @@ contract('MultiSigWalletWithTimeLock', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should set confirmation time with enough confirmations', async () => {
|
||||
const res = await multiSig.confirmTransaction(txId, {from: owners[1]});
|
||||
const res = await multiSig.confirmTransaction(txId, { from: owners[1] });
|
||||
expect(res.logs).to.have.length(2);
|
||||
const blockNum = await promisify<number>(web3.eth.getBlockNumber)();
|
||||
const blockInfo = await promisify<Web3.BlockWithoutTransactionData>(web3.eth.getBlock)(blockNum);
|
||||
@@ -96,7 +97,9 @@ contract('MultiSigWalletWithTimeLock', (accounts: string[]) => {
|
||||
const subRes = await multiSigWrapper.submitTransactionAsync(destination, from, dataParams);
|
||||
|
||||
txId = subRes.logs[0].args.transactionId.toNumber();
|
||||
const confRes = await multiSig.confirmTransaction(txId, {from: owners[1]});
|
||||
const confRes = await multiSig.confirmTransaction(txId, {
|
||||
from: owners[1],
|
||||
});
|
||||
expect(confRes.logs).to.have.length(2);
|
||||
|
||||
return expect(multiSig.executeTransaction(txId)).to.be.rejectedWith(constants.REVERT);
|
||||
|
||||
@@ -1,14 +1,14 @@
|
||||
import * as chai from 'chai';
|
||||
|
||||
import * as tokenTransferProxyJSON from '../../build/contracts/TokenTransferProxy.json';
|
||||
import {Artifacts} from '../../util/artifacts';
|
||||
import {constants} from '../../util/constants';
|
||||
import {crypto} from '../../util/crypto';
|
||||
import {MultiSigWrapper} from '../../util/multi_sig_wrapper';
|
||||
import {ContractInstance, TransactionDataParams} from '../../util/types';
|
||||
import { Artifacts } from '../../util/artifacts';
|
||||
import { constants } from '../../util/constants';
|
||||
import { crypto } from '../../util/crypto';
|
||||
import { MultiSigWrapper } from '../../util/multi_sig_wrapper';
|
||||
import { ContractInstance, TransactionDataParams } from '../../util/types';
|
||||
|
||||
import {chaiSetup} from './utils/chai_setup';
|
||||
const {TokenTransferProxy, MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress} = new Artifacts(artifacts);
|
||||
import { chaiSetup } from './utils/chai_setup';
|
||||
const { TokenTransferProxy, MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress } = new Artifacts(artifacts);
|
||||
const PROXY_ABI = (tokenTransferProxyJSON as any).abi;
|
||||
|
||||
chaiSetup.configure();
|
||||
@@ -20,8 +20,14 @@ contract('MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress', (accounts: s
|
||||
const SECONDS_TIME_LOCKED = 1000000;
|
||||
|
||||
// initialize fake addresses
|
||||
const authorizedAddress = `0x${crypto.solSHA3([accounts[0]]).slice(0, 20).toString('hex')}`;
|
||||
const unauthorizedAddress = `0x${crypto.solSHA3([accounts[1]]).slice(0, 20).toString('hex')}`;
|
||||
const authorizedAddress = `0x${crypto
|
||||
.solSHA3([accounts[0]])
|
||||
.slice(0, 20)
|
||||
.toString('hex')}`;
|
||||
const unauthorizedAddress = `0x${crypto
|
||||
.solSHA3([accounts[1]])
|
||||
.slice(0, 20)
|
||||
.toString('hex')}`;
|
||||
|
||||
let tokenTransferProxy: ContractInstance;
|
||||
let multiSig: ContractInstance;
|
||||
@@ -31,11 +37,19 @@ contract('MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress', (accounts: s
|
||||
|
||||
beforeEach(async () => {
|
||||
const initialOwner = accounts[0];
|
||||
tokenTransferProxy = await TokenTransferProxy.new({from: initialOwner});
|
||||
await tokenTransferProxy.addAuthorizedAddress(authorizedAddress, {from: initialOwner});
|
||||
tokenTransferProxy = await TokenTransferProxy.new({ from: initialOwner });
|
||||
await tokenTransferProxy.addAuthorizedAddress(authorizedAddress, {
|
||||
from: initialOwner,
|
||||
});
|
||||
multiSig = await MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress.new(
|
||||
owners, requiredApprovals, SECONDS_TIME_LOCKED, tokenTransferProxy.address);
|
||||
await tokenTransferProxy.transferOwnership(multiSig.address, {from: initialOwner});
|
||||
owners,
|
||||
requiredApprovals,
|
||||
SECONDS_TIME_LOCKED,
|
||||
tokenTransferProxy.address,
|
||||
);
|
||||
await tokenTransferProxy.transferOwnership(multiSig.address, {
|
||||
from: initialOwner,
|
||||
});
|
||||
multiSigWrapper = new MultiSigWrapper(multiSig);
|
||||
validDestination = tokenTransferProxy.address;
|
||||
});
|
||||
@@ -43,8 +57,7 @@ contract('MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress', (accounts: s
|
||||
describe('isFunctionRemoveAuthorizedAddress', () => {
|
||||
it('should throw if data is not for removeAuthorizedAddress', async () => {
|
||||
const data = MultiSigWrapper.encodeFnArgs('addAuthorizedAddress', PROXY_ABI, [owners[0]]);
|
||||
return expect(multiSig.isFunctionRemoveAuthorizedAddress.call(data))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(multiSig.isFunctionRemoveAuthorizedAddress.call(data)).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should return true if data is for removeAuthorizedAddress', async () => {
|
||||
@@ -77,7 +90,7 @@ contract('MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress', (accounts: s
|
||||
};
|
||||
const res = await multiSigWrapper.submitTransactionAsync(invalidDestination, owners[0], dataParams);
|
||||
const txId = res.logs[0].args.transactionId.toString();
|
||||
await multiSig.confirmTransaction(txId, {from: owners[1]});
|
||||
await multiSig.confirmTransaction(txId, { from: owners[1] });
|
||||
const isConfirmed = await multiSig.isConfirmed.call(txId);
|
||||
expect(isConfirmed).to.be.true();
|
||||
|
||||
@@ -92,7 +105,7 @@ contract('MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress', (accounts: s
|
||||
};
|
||||
const res = await multiSigWrapper.submitTransactionAsync(validDestination, owners[0], dataParams);
|
||||
const txId = res.logs[0].args.transactionId.toString();
|
||||
await multiSig.confirmTransaction(txId, {from: owners[1]});
|
||||
await multiSig.confirmTransaction(txId, { from: owners[1] });
|
||||
const isConfirmed = await multiSig.isConfirmed.call(txId);
|
||||
expect(isConfirmed).to.be.true();
|
||||
|
||||
@@ -107,7 +120,7 @@ contract('MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress', (accounts: s
|
||||
};
|
||||
const res = await multiSigWrapper.submitTransactionAsync(validDestination, owners[0], dataParams);
|
||||
const txId = res.logs[0].args.transactionId.toString();
|
||||
await multiSig.confirmTransaction(txId, {from: owners[1]});
|
||||
await multiSig.confirmTransaction(txId, { from: owners[1] });
|
||||
const isConfirmed = await multiSig.isConfirmed.call(txId);
|
||||
expect(isConfirmed).to.be.true();
|
||||
await multiSig.executeRemoveAuthorizedAddress(txId);
|
||||
@@ -124,7 +137,7 @@ contract('MultiSigWalletWithTimeLockExceptRemoveAuthorizedAddress', (accounts: s
|
||||
};
|
||||
const res = await multiSigWrapper.submitTransactionAsync(validDestination, owners[0], dataParams);
|
||||
const txId = res.logs[0].args.transactionId.toString();
|
||||
await multiSig.confirmTransaction(txId, {from: owners[1]});
|
||||
await multiSig.confirmTransaction(txId, { from: owners[1] });
|
||||
const isConfirmed = await multiSig.isConfirmed.call(txId);
|
||||
expect(isConfirmed).to.be.true();
|
||||
await multiSig.executeRemoveAuthorizedAddress(txId);
|
||||
|
||||
@@ -1,16 +1,16 @@
|
||||
import {ZeroEx} from '0x.js';
|
||||
import { ZeroEx } from '0x.js';
|
||||
import * as chai from 'chai';
|
||||
import ethUtil = require('ethereumjs-util');
|
||||
import * as _ from 'lodash';
|
||||
|
||||
import {Artifacts} from '../../util/artifacts';
|
||||
import {constants} from '../../util/constants';
|
||||
import {TokenRegWrapper} from '../../util/token_registry_wrapper';
|
||||
import {ContractInstance} from '../../util/types';
|
||||
import { Artifacts } from '../../util/artifacts';
|
||||
import { constants } from '../../util/constants';
|
||||
import { TokenRegWrapper } from '../../util/token_registry_wrapper';
|
||||
import { ContractInstance } from '../../util/types';
|
||||
|
||||
import {chaiSetup} from './utils/chai_setup';
|
||||
import { chaiSetup } from './utils/chai_setup';
|
||||
|
||||
const {TokenRegistry} = new Artifacts(artifacts);
|
||||
const { TokenRegistry } = new Artifacts(artifacts);
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
|
||||
@@ -79,18 +79,22 @@ contract('TokenRegistry', (accounts: string[]) => {
|
||||
|
||||
it('should throw if name already exists', async () => {
|
||||
await tokenRegWrapper.addTokenAsync(token1, owner);
|
||||
const duplicateNameToken = _.assign({}, token2, {name: token1.name});
|
||||
const duplicateNameToken = _.assign({}, token2, { name: token1.name });
|
||||
|
||||
return expect(tokenRegWrapper.addTokenAsync(duplicateNameToken, owner))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenRegWrapper.addTokenAsync(duplicateNameToken, owner)).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
it('should throw if symbol already exists', async () => {
|
||||
await tokenRegWrapper.addTokenAsync(token1, owner);
|
||||
const duplicateSymbolToken = _.assign({}, token2, {symbol: token1.symbol});
|
||||
const duplicateSymbolToken = _.assign({}, token2, {
|
||||
symbol: token1.symbol,
|
||||
});
|
||||
|
||||
return expect(tokenRegWrapper.addTokenAsync(duplicateSymbolToken, owner))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenRegWrapper.addTokenAsync(duplicateSymbolToken, owner)).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
@@ -115,19 +119,22 @@ contract('TokenRegistry', (accounts: string[]) => {
|
||||
|
||||
describe('setTokenName', () => {
|
||||
it('should throw when not called by owner', async () => {
|
||||
return expect(tokenReg.setTokenName(token1.address, token2.name, {from: notOwner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
tokenReg.setTokenName(token1.address, token2.name, { from: notOwner }),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should change the token name when called by owner', async () => {
|
||||
const res = await tokenReg.setTokenName(token1.address, token2.name, {from: owner});
|
||||
const res = await tokenReg.setTokenName(token1.address, token2.name, {
|
||||
from: owner,
|
||||
});
|
||||
expect(res.logs).to.have.length(1);
|
||||
const [newData, oldData] = await Promise.all([
|
||||
tokenRegWrapper.getTokenByNameAsync(token2.name),
|
||||
tokenRegWrapper.getTokenByNameAsync(token1.name),
|
||||
]);
|
||||
|
||||
const expectedNewData = _.assign({}, token1, {name: token2.name});
|
||||
const expectedNewData = _.assign({}, token1, { name: token2.name });
|
||||
const expectedOldData = nullToken;
|
||||
expect(newData).to.be.deep.equal(expectedNewData);
|
||||
expect(oldData).to.be.deep.equal(expectedOldData);
|
||||
@@ -136,31 +143,36 @@ contract('TokenRegistry', (accounts: string[]) => {
|
||||
it('should throw if the name already exists', async () => {
|
||||
await tokenRegWrapper.addTokenAsync(token2, owner);
|
||||
|
||||
return expect(tokenReg.setTokenName(token1.address, token2.name, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenReg.setTokenName(token1.address, token2.name, { from: owner })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
it('should throw if token does not exist', async () => {
|
||||
return expect(tokenReg.setTokenName(nullToken.address, token2.name, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
tokenReg.setTokenName(nullToken.address, token2.name, { from: owner }),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
});
|
||||
|
||||
describe('setTokenSymbol', () => {
|
||||
it('should throw when not called by owner', async () => {
|
||||
return expect(tokenReg.setTokenSymbol(token1.address, token2.symbol, {from: notOwner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
tokenReg.setTokenSymbol(token1.address, token2.symbol, {
|
||||
from: notOwner,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should change the token symbol when called by owner', async () => {
|
||||
const res = await tokenReg.setTokenSymbol(token1.address, token2.symbol, {from: owner});
|
||||
const res = await tokenReg.setTokenSymbol(token1.address, token2.symbol, { from: owner });
|
||||
expect(res.logs).to.have.length(1);
|
||||
const [newData, oldData] = await Promise.all([
|
||||
tokenRegWrapper.getTokenBySymbolAsync(token2.symbol),
|
||||
tokenRegWrapper.getTokenBySymbolAsync(token1.symbol),
|
||||
]);
|
||||
|
||||
const expectedNewData = _.assign({}, token1, {symbol: token2.symbol});
|
||||
const expectedNewData = _.assign({}, token1, { symbol: token2.symbol });
|
||||
const expectedOldData = nullToken;
|
||||
expect(newData).to.be.deep.equal(expectedNewData);
|
||||
expect(oldData).to.be.deep.equal(expectedOldData);
|
||||
@@ -169,26 +181,35 @@ contract('TokenRegistry', (accounts: string[]) => {
|
||||
it('should throw if the symbol already exists', async () => {
|
||||
await tokenRegWrapper.addTokenAsync(token2, owner);
|
||||
|
||||
return expect(tokenReg.setTokenSymbol(token1.address, token2.symbol, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
tokenReg.setTokenSymbol(token1.address, token2.symbol, {
|
||||
from: owner,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should throw if token does not exist', async () => {
|
||||
return expect(tokenReg.setTokenSymbol(nullToken.address, token2.symbol, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
tokenReg.setTokenSymbol(nullToken.address, token2.symbol, {
|
||||
from: owner,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
});
|
||||
|
||||
describe('removeToken', () => {
|
||||
it('should throw if not called by owner', async () => {
|
||||
const index = 0;
|
||||
return expect(tokenReg.removeToken(token1.address, index, {from: notOwner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenReg.removeToken(token1.address, index, { from: notOwner })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
it('should remove token metadata when called by owner', async () => {
|
||||
const index = 0;
|
||||
const res = await tokenReg.removeToken(token1.address, index, {from: owner});
|
||||
const res = await tokenReg.removeToken(token1.address, index, {
|
||||
from: owner,
|
||||
});
|
||||
expect(res.logs).to.have.length(1);
|
||||
const tokenData = await tokenRegWrapper.getTokenMetaDataAsync(token1.address);
|
||||
expect(tokenData).to.be.deep.equal(nullToken);
|
||||
@@ -196,17 +217,18 @@ contract('TokenRegistry', (accounts: string[]) => {
|
||||
|
||||
it('should throw if token does not exist', async () => {
|
||||
const index = 0;
|
||||
return expect(tokenReg.removeToken(nullToken.address, index, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenReg.removeToken(nullToken.address, index, { from: owner })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
it('should throw if token at given index does not match address', async () => {
|
||||
await tokenRegWrapper.addTokenAsync(token2, owner);
|
||||
const incorrectIndex = 0;
|
||||
return expect(tokenReg.removeToken(token2.address, incorrectIndex, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenReg.removeToken(token2.address, incorrectIndex, { from: owner })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
import * as chai from 'chai';
|
||||
|
||||
import {constants} from '../../../util/constants';
|
||||
import {ContractInstance} from '../../../util/types';
|
||||
import {chaiSetup} from '../utils/chai_setup';
|
||||
import { constants } from '../../../util/constants';
|
||||
import { ContractInstance } from '../../../util/types';
|
||||
import { chaiSetup } from '../utils/chai_setup';
|
||||
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
@@ -22,12 +22,15 @@ contract('TokenTransferProxy', (accounts: string[]) => {
|
||||
|
||||
describe('addAuthorizedAddress', () => {
|
||||
it('should throw if not called by owner', async () => {
|
||||
return expect(tokenTransferProxy.addAuthorizedAddress(notOwner, {from: notOwner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenTransferProxy.addAuthorizedAddress(notOwner, { from: notOwner })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
it('should allow owner to add an authorized address', async () => {
|
||||
await tokenTransferProxy.addAuthorizedAddress(notAuthorized, {from: owner});
|
||||
await tokenTransferProxy.addAuthorizedAddress(notAuthorized, {
|
||||
from: owner,
|
||||
});
|
||||
authorized = notAuthorized;
|
||||
notAuthorized = null;
|
||||
const isAuthorized = await tokenTransferProxy.authorized.call(authorized);
|
||||
@@ -35,19 +38,25 @@ contract('TokenTransferProxy', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should throw if owner attempts to authorize a duplicate address', async () => {
|
||||
return expect(tokenTransferProxy.addAuthorizedAddress(authorized, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(tokenTransferProxy.addAuthorizedAddress(authorized, { from: owner })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
describe('removeAuthorizedAddress', () => {
|
||||
it('should throw if not called by owner', async () => {
|
||||
return expect(tokenTransferProxy.removeAuthorizedAddress(authorized, {from: notOwner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
tokenTransferProxy.removeAuthorizedAddress(authorized, {
|
||||
from: notOwner,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should allow owner to remove an authorized address', async () => {
|
||||
await tokenTransferProxy.removeAuthorizedAddress(authorized, {from: owner});
|
||||
await tokenTransferProxy.removeAuthorizedAddress(authorized, {
|
||||
from: owner,
|
||||
});
|
||||
notAuthorized = authorized;
|
||||
authorized = null;
|
||||
|
||||
@@ -56,8 +65,11 @@ contract('TokenTransferProxy', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should throw if owner attempts to remove an address that is not authorized', async () => {
|
||||
return expect(tokenTransferProxy.removeAuthorizedAddress(notAuthorized, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
tokenTransferProxy.removeAuthorizedAddress(notAuthorized, {
|
||||
from: owner,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
});
|
||||
|
||||
@@ -65,7 +77,9 @@ contract('TokenTransferProxy', (accounts: string[]) => {
|
||||
it('should return all authorized addresses', async () => {
|
||||
const initial = await tokenTransferProxy.getAuthorizedAddresses();
|
||||
expect(initial).to.have.length(1);
|
||||
await tokenTransferProxy.addAuthorizedAddress(notAuthorized, {from: owner});
|
||||
await tokenTransferProxy.addAuthorizedAddress(notAuthorized, {
|
||||
from: owner,
|
||||
});
|
||||
|
||||
authorized = notAuthorized;
|
||||
notAuthorized = null;
|
||||
@@ -73,7 +87,9 @@ contract('TokenTransferProxy', (accounts: string[]) => {
|
||||
expect(afterAdd).to.have.length(2);
|
||||
expect(afterAdd).to.include(authorized);
|
||||
|
||||
await tokenTransferProxy.removeAuthorizedAddress(authorized, {from: owner});
|
||||
await tokenTransferProxy.removeAuthorizedAddress(authorized, {
|
||||
from: owner,
|
||||
});
|
||||
notAuthorized = authorized;
|
||||
authorized = null;
|
||||
const afterRemove = await tokenTransferProxy.getAuthorizedAddresses();
|
||||
|
||||
@@ -1,18 +1,14 @@
|
||||
import * as chai from 'chai';
|
||||
|
||||
import {Artifacts} from '../../../util/artifacts';
|
||||
import {Balances} from '../../../util/balances';
|
||||
import {constants} from '../../../util/constants';
|
||||
import {ContractInstance} from '../../../util/types';
|
||||
import {chaiSetup} from '../utils/chai_setup';
|
||||
import { Artifacts } from '../../../util/artifacts';
|
||||
import { Balances } from '../../../util/balances';
|
||||
import { constants } from '../../../util/constants';
|
||||
import { ContractInstance } from '../../../util/types';
|
||||
import { chaiSetup } from '../utils/chai_setup';
|
||||
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
const {
|
||||
TokenTransferProxy,
|
||||
DummyToken,
|
||||
TokenRegistry,
|
||||
} = new Artifacts(artifacts);
|
||||
const { TokenTransferProxy, DummyToken, TokenRegistry } = new Artifacts(artifacts);
|
||||
|
||||
contract('TokenTransferProxy', (accounts: string[]) => {
|
||||
const INIT_BAL = 100000000;
|
||||
@@ -36,32 +32,42 @@ contract('TokenTransferProxy', (accounts: string[]) => {
|
||||
|
||||
dmyBalances = new Balances([rep], [accounts[0], accounts[1]]);
|
||||
await Promise.all([
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, {from: accounts[0]}),
|
||||
rep.setBalance(accounts[0], INIT_BAL, {from: owner}),
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, {from: accounts[1]}),
|
||||
rep.setBalance(accounts[1], INIT_BAL, {from: owner}),
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, {
|
||||
from: accounts[0],
|
||||
}),
|
||||
rep.setBalance(accounts[0], INIT_BAL, { from: owner }),
|
||||
rep.approve(TokenTransferProxy.address, INIT_ALLOW, {
|
||||
from: accounts[1],
|
||||
}),
|
||||
rep.setBalance(accounts[1], INIT_BAL, { from: owner }),
|
||||
]);
|
||||
});
|
||||
|
||||
describe('transferFrom', () => {
|
||||
it('should throw when called by an unauthorized address', async () => {
|
||||
expect(tokenTransferProxy.transferFrom(rep.address, accounts[0], accounts[1], 1000, {from: notAuthorized}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
expect(
|
||||
tokenTransferProxy.transferFrom(rep.address, accounts[0], accounts[1], 1000, { from: notAuthorized }),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should allow an authorized address to transfer', async () => {
|
||||
const balances = await dmyBalances.getAsync();
|
||||
|
||||
await tokenTransferProxy.addAuthorizedAddress(notAuthorized, {from: owner});
|
||||
await tokenTransferProxy.addAuthorizedAddress(notAuthorized, {
|
||||
from: owner,
|
||||
});
|
||||
const transferAmt = 10000;
|
||||
await tokenTransferProxy.transferFrom(rep.address, accounts[0], accounts[1],
|
||||
transferAmt, {from: notAuthorized});
|
||||
await tokenTransferProxy.transferFrom(rep.address, accounts[0], accounts[1], transferAmt, {
|
||||
from: notAuthorized,
|
||||
});
|
||||
|
||||
const newBalances = await dmyBalances.getAsync();
|
||||
expect(newBalances[accounts[0]][rep.address])
|
||||
.to.be.bignumber.equal(balances[accounts[0]][rep.address].minus(transferAmt));
|
||||
expect(newBalances[accounts[1]][rep.address])
|
||||
.to.be.bignumber.equal(balances[accounts[1]][rep.address].add(transferAmt));
|
||||
expect(newBalances[accounts[0]][rep.address]).to.be.bignumber.equal(
|
||||
balances[accounts[0]][rep.address].minus(transferAmt),
|
||||
);
|
||||
expect(newBalances[accounts[1]][rep.address]).to.be.bignumber.equal(
|
||||
balances[accounts[1]][rep.address].add(transferAmt),
|
||||
);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
@@ -1,15 +1,15 @@
|
||||
import {ZeroEx} from '0x.js';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { ZeroEx } from '0x.js';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import * as Web3 from 'web3';
|
||||
|
||||
import {Artifacts} from '../../util/artifacts';
|
||||
import {constants} from '../../util/constants';
|
||||
import {ContractInstance} from '../../util/types';
|
||||
import { Artifacts } from '../../util/artifacts';
|
||||
import { constants } from '../../util/constants';
|
||||
import { ContractInstance } from '../../util/types';
|
||||
|
||||
import {chaiSetup} from './utils/chai_setup';
|
||||
import { chaiSetup } from './utils/chai_setup';
|
||||
|
||||
const {DummyToken} = new Artifacts(artifacts);
|
||||
const { DummyToken } = new Artifacts(artifacts);
|
||||
const web3: Web3 = (global as any).web3;
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
@@ -27,8 +27,8 @@ contract('UnlimitedAllowanceToken', (accounts: string[]) => {
|
||||
let token: ContractInstance;
|
||||
|
||||
beforeEach(async () => {
|
||||
token = await DummyToken.new({from: owner});
|
||||
await token.mint(MAX_MINT_VALUE, {from: owner});
|
||||
token = await DummyToken.new({ from: owner });
|
||||
await token.mint(MAX_MINT_VALUE, { from: owner });
|
||||
tokenAddress = token.address;
|
||||
});
|
||||
|
||||
@@ -48,7 +48,9 @@ contract('UnlimitedAllowanceToken', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should return true on a 0 value transfer', async () => {
|
||||
const didReturnTrue = await token.transfer.call(spender, 0, {from: owner});
|
||||
const didReturnTrue = await token.transfer.call(spender, 0, {
|
||||
from: owner,
|
||||
});
|
||||
expect(didReturnTrue).to.be.true();
|
||||
});
|
||||
});
|
||||
@@ -58,7 +60,7 @@ contract('UnlimitedAllowanceToken', (accounts: string[]) => {
|
||||
const ownerBalance = await zeroEx.token.getBalanceAsync(tokenAddress, owner);
|
||||
const amountToTransfer = ownerBalance.plus(1);
|
||||
await zeroEx.token.setAllowanceAsync(tokenAddress, owner, spender, amountToTransfer);
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, {from: spender});
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, { from: spender });
|
||||
expect(didReturnTrue).to.be.false();
|
||||
});
|
||||
|
||||
@@ -70,13 +72,13 @@ contract('UnlimitedAllowanceToken', (accounts: string[]) => {
|
||||
const spenderAllowanceIsInsufficient = spenderAllowance.cmp(amountToTransfer) < 0;
|
||||
expect(spenderAllowanceIsInsufficient).to.be.true();
|
||||
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, {from: spender});
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, { from: spender });
|
||||
expect(didReturnTrue).to.be.false();
|
||||
});
|
||||
|
||||
it('should return true on a 0 value transfer', async () => {
|
||||
const amountToTransfer = 0;
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, {from: spender});
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, { from: spender });
|
||||
expect(didReturnTrue).to.be.true();
|
||||
});
|
||||
|
||||
|
||||
@@ -1,15 +1,15 @@
|
||||
import {ZeroEx} from '0x.js';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { ZeroEx } from '0x.js';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import * as Web3 from 'web3';
|
||||
|
||||
import {Artifacts} from '../../util/artifacts';
|
||||
import {constants} from '../../util/constants';
|
||||
import {ContractInstance} from '../../util/types';
|
||||
import { Artifacts } from '../../util/artifacts';
|
||||
import { constants } from '../../util/constants';
|
||||
import { ContractInstance } from '../../util/types';
|
||||
|
||||
import {chaiSetup} from './utils/chai_setup';
|
||||
import { chaiSetup } from './utils/chai_setup';
|
||||
|
||||
const {DummyTokenV2} = new Artifacts(artifacts);
|
||||
const { DummyTokenV2 } = new Artifacts(artifacts);
|
||||
const web3: Web3 = (global as any).web3;
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
@@ -27,8 +27,8 @@ contract('UnlimitedAllowanceTokenV2', (accounts: string[]) => {
|
||||
let token: ContractInstance;
|
||||
|
||||
beforeEach(async () => {
|
||||
token = await DummyTokenV2.new({from: owner});
|
||||
await token.mint(MAX_MINT_VALUE, {from: owner});
|
||||
token = await DummyTokenV2.new({ from: owner });
|
||||
await token.mint(MAX_MINT_VALUE, { from: owner });
|
||||
tokenAddress = token.address;
|
||||
});
|
||||
|
||||
@@ -36,8 +36,9 @@ contract('UnlimitedAllowanceTokenV2', (accounts: string[]) => {
|
||||
it('should throw if owner has insufficient balance', async () => {
|
||||
const ownerBalance = await zeroEx.token.getBalanceAsync(tokenAddress, owner);
|
||||
const amountToTransfer = ownerBalance.plus(1);
|
||||
return expect(token.transfer.call(spender, amountToTransfer, {from: owner}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(token.transfer.call(spender, amountToTransfer, { from: owner })).to.be.rejectedWith(
|
||||
constants.REVERT,
|
||||
);
|
||||
});
|
||||
|
||||
it('should transfer balance from sender to receiver', async () => {
|
||||
@@ -55,7 +56,9 @@ contract('UnlimitedAllowanceTokenV2', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should return true on a 0 value transfer', async () => {
|
||||
const didReturnTrue = await token.transfer.call(spender, 0, {from: owner});
|
||||
const didReturnTrue = await token.transfer.call(spender, 0, {
|
||||
from: owner,
|
||||
});
|
||||
expect(didReturnTrue).to.be.true();
|
||||
});
|
||||
});
|
||||
@@ -65,8 +68,11 @@ contract('UnlimitedAllowanceTokenV2', (accounts: string[]) => {
|
||||
const ownerBalance = await zeroEx.token.getBalanceAsync(tokenAddress, owner);
|
||||
const amountToTransfer = ownerBalance.plus(1);
|
||||
await zeroEx.token.setAllowanceAsync(tokenAddress, owner, spender, amountToTransfer);
|
||||
return expect(token.transferFrom.call(owner, spender, amountToTransfer, {from: spender}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
token.transferFrom.call(owner, spender, amountToTransfer, {
|
||||
from: spender,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should throw if spender has insufficient allowance', async () => {
|
||||
@@ -77,13 +83,16 @@ contract('UnlimitedAllowanceTokenV2', (accounts: string[]) => {
|
||||
const spenderAllowanceIsInsufficient = spenderAllowance.cmp(amountToTransfer) < 0;
|
||||
expect(spenderAllowanceIsInsufficient).to.be.true();
|
||||
|
||||
return expect(token.transferFrom.call(owner, spender, amountToTransfer, {from: spender}))
|
||||
.to.be.rejectedWith(constants.REVERT);
|
||||
return expect(
|
||||
token.transferFrom.call(owner, spender, amountToTransfer, {
|
||||
from: spender,
|
||||
}),
|
||||
).to.be.rejectedWith(constants.REVERT);
|
||||
});
|
||||
|
||||
it('should return true on a 0 value transfer', async () => {
|
||||
const amountToTransfer = 0;
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, {from: spender});
|
||||
const didReturnTrue = await token.transferFrom.call(owner, spender, amountToTransfer, { from: spender });
|
||||
expect(didReturnTrue).to.be.true();
|
||||
});
|
||||
|
||||
|
||||
@@ -1,17 +1,17 @@
|
||||
import {ZeroEx} from '0x.js';
|
||||
import {BigNumber} from 'bignumber.js';
|
||||
import { ZeroEx } from '0x.js';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import * as chai from 'chai';
|
||||
import Web3 = require('web3');
|
||||
|
||||
import {Artifacts} from '../../util/artifacts';
|
||||
import {constants} from '../../util/constants';
|
||||
import {ContractInstance} from '../../util/types';
|
||||
import { Artifacts } from '../../util/artifacts';
|
||||
import { constants } from '../../util/constants';
|
||||
import { ContractInstance } from '../../util/types';
|
||||
|
||||
import {chaiSetup} from './utils/chai_setup';
|
||||
import { chaiSetup } from './utils/chai_setup';
|
||||
|
||||
chaiSetup.configure();
|
||||
const expect = chai.expect;
|
||||
const {Exchange, ZRXToken} = new Artifacts(artifacts);
|
||||
const { Exchange, ZRXToken } = new Artifacts(artifacts);
|
||||
const web3: Web3 = (global as any).web3;
|
||||
|
||||
contract('ZRXToken', (accounts: string[]) => {
|
||||
@@ -85,7 +85,9 @@ contract('ZRXToken', (accounts: string[]) => {
|
||||
});
|
||||
|
||||
it('should return true on a 0 value transfer', async () => {
|
||||
const didReturnTrue = await zrx.transfer.call(spender, 0, {from: owner});
|
||||
const didReturnTrue = await zrx.transfer.call(spender, 0, {
|
||||
from: owner,
|
||||
});
|
||||
expect(didReturnTrue).to.be.true();
|
||||
});
|
||||
});
|
||||
@@ -98,7 +100,7 @@ contract('ZRXToken', (accounts: string[]) => {
|
||||
gasLimit: constants.MAX_TOKEN_APPROVE_GAS,
|
||||
});
|
||||
await zeroEx.awaitTransactionMinedAsync(txHash);
|
||||
const didReturnTrue = await zrx.transferFrom.call(owner, spender, amountToTransfer, {from: spender});
|
||||
const didReturnTrue = await zrx.transferFrom.call(owner, spender, amountToTransfer, { from: spender });
|
||||
expect(didReturnTrue).to.be.false();
|
||||
});
|
||||
|
||||
@@ -110,13 +112,13 @@ contract('ZRXToken', (accounts: string[]) => {
|
||||
const spenderAllowanceIsInsufficient = spenderAllowance.cmp(amountToTransfer) < 0;
|
||||
expect(spenderAllowanceIsInsufficient).to.be.true();
|
||||
|
||||
const didReturnTrue = await zrx.transferFrom.call(owner, spender, amountToTransfer, {from: spender});
|
||||
const didReturnTrue = await zrx.transferFrom.call(owner, spender, amountToTransfer, { from: spender });
|
||||
expect(didReturnTrue).to.be.false();
|
||||
});
|
||||
|
||||
it('should return true on a 0 value transfer', async () => {
|
||||
const amountToTransfer = 0;
|
||||
const didReturnTrue = await zrx.transferFrom.call(owner, spender, amountToTransfer, {from: spender});
|
||||
const didReturnTrue = await zrx.transferFrom.call(owner, spender, amountToTransfer, { from: spender });
|
||||
expect(didReturnTrue).to.be.true();
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user