diff options
author | Fabio Berger <me@fabioberger.com> | 2017-06-03 02:39:02 +0800 |
---|---|---|
committer | Fabio Berger <me@fabioberger.com> | 2017-06-03 02:39:02 +0800 |
commit | 36e937f8de348cfdb35ff8f72504aed1dfab07b2 (patch) | |
tree | e8e0ba5b603f07bddf6cd01329e001b06b5987dd /test/utils | |
parent | c6ceb44682a19c9f53505803547fcb2012691b5b (diff) | |
parent | 5925f81fe185a90efaa82dd90bd8d65d74326f11 (diff) | |
download | dexon-sol-tools-36e937f8de348cfdb35ff8f72504aed1dfab07b2.tar dexon-sol-tools-36e937f8de348cfdb35ff8f72504aed1dfab07b2.tar.gz dexon-sol-tools-36e937f8de348cfdb35ff8f72504aed1dfab07b2.tar.bz2 dexon-sol-tools-36e937f8de348cfdb35ff8f72504aed1dfab07b2.tar.lz dexon-sol-tools-36e937f8de348cfdb35ff8f72504aed1dfab07b2.tar.xz dexon-sol-tools-36e937f8de348cfdb35ff8f72504aed1dfab07b2.tar.zst dexon-sol-tools-36e937f8de348cfdb35ff8f72504aed1dfab07b2.zip |
Merge branch 'master' into remainingTokenMethods
# Conflicts:
# src/contract_wrappers/token_wrapper.ts
Diffstat (limited to 'test/utils')
-rw-r--r-- | test/utils/fill_scenarios.ts | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/test/utils/fill_scenarios.ts b/test/utils/fill_scenarios.ts index a44d6b18a..d186593b9 100644 --- a/test/utils/fill_scenarios.ts +++ b/test/utils/fill_scenarios.ts @@ -51,6 +51,24 @@ export class FillScenarios { makerFillableAmount, takerFillableAmount, feeRecepient, expirationUnixTimestampSec, ); } + public async createPartiallyFilledSignedOrderAsync(makerTokenAddress: string, takerTokenAddress: string, + takerAddress: string, fillableAmount: BigNumber.BigNumber, + partialFillAmount: BigNumber.BigNumber) { + const prevSenderAccount = await this.zeroEx.getTransactionSenderAccountIfExistsAsync(); + const [makerAddress] = this.userAddresses; + const signedOrder = await this.createAsymmetricFillableSignedOrderAsync( + makerTokenAddress, takerTokenAddress, makerAddress, takerAddress, + fillableAmount, fillableAmount, + ); + + this.zeroEx.setTransactionSenderAccount(takerAddress); + const shouldCheckTransfer = false; + await this.zeroEx.exchange.fillOrderAsync(signedOrder, partialFillAmount, shouldCheckTransfer); + + // Re-set sender account so as to avoid introducing side-effects + this.zeroEx.setTransactionSenderAccount(prevSenderAccount as string); + return signedOrder; + } private async createAsymmetricFillableSignedOrderWithFeesAsync( makerTokenAddress: string, takerTokenAddress: string, makerFee: BigNumber.BigNumber, takerFee: BigNumber.BigNumber, |