aboutsummaryrefslogtreecommitdiffstats
path: root/test/utils/fill_scenarios.ts
diff options
context:
space:
mode:
authorFabio Berger <me@fabioberger.com>2017-06-02 03:14:30 +0800
committerFabio Berger <me@fabioberger.com>2017-06-02 03:14:30 +0800
commit3e0c2ad7530927fa1c9019bbc311a88d327e2306 (patch)
tree435dd8a0efe6c057958d348bc0e9bfd3dcbba6cc /test/utils/fill_scenarios.ts
parentaade6891e834dda7e80d76740882facdb45bc014 (diff)
parentf663a15c9b000d639bd0d58d0c177e6de9d47346 (diff)
downloaddexon-0x-contracts-3e0c2ad7530927fa1c9019bbc311a88d327e2306.tar
dexon-0x-contracts-3e0c2ad7530927fa1c9019bbc311a88d327e2306.tar.gz
dexon-0x-contracts-3e0c2ad7530927fa1c9019bbc311a88d327e2306.tar.bz2
dexon-0x-contracts-3e0c2ad7530927fa1c9019bbc311a88d327e2306.tar.lz
dexon-0x-contracts-3e0c2ad7530927fa1c9019bbc311a88d327e2306.tar.xz
dexon-0x-contracts-3e0c2ad7530927fa1c9019bbc311a88d327e2306.tar.zst
dexon-0x-contracts-3e0c2ad7530927fa1c9019bbc311a88d327e2306.zip
Merge branch 'fillOrderAsync' into unavailableFilledCancelled
Diffstat (limited to 'test/utils/fill_scenarios.ts')
-rw-r--r--test/utils/fill_scenarios.ts29
1 files changed, 29 insertions, 0 deletions
diff --git a/test/utils/fill_scenarios.ts b/test/utils/fill_scenarios.ts
new file mode 100644
index 000000000..ac233ad50
--- /dev/null
+++ b/test/utils/fill_scenarios.ts
@@ -0,0 +1,29 @@
+import * as BigNumber from 'bignumber.js';
+import {ZeroEx} from '../../src/0x.js';
+import {Token, SignedOrder} from '../../src/types';
+import {orderFactory} from '../utils/order_factory';
+
+export class FillScenarios {
+ private zeroEx: ZeroEx;
+ private userAddresses: string[];
+ private tokens: Token[];
+ constructor(zeroEx: ZeroEx, userAddresses: string[], tokens: Token[]) {
+ this.zeroEx = zeroEx;
+ this.userAddresses = userAddresses;
+ this.tokens = tokens;
+ }
+ public async createAFillableSignedOrderAsync(makerTokenAddress: string, takerTokenAddress: string,
+ takerAddress: string, fillableAmount: BigNumber.BigNumber,
+ expirationUnixTimestampSec?: BigNumber.BigNumber):
+ Promise<SignedOrder> {
+ const [makerAddress] = this.userAddresses;
+ await this.zeroEx.token.setProxyAllowanceAsync(makerTokenAddress, makerAddress, fillableAmount);
+ await this.zeroEx.token.transferAsync(takerTokenAddress, makerAddress, takerAddress, fillableAmount);
+ await this.zeroEx.token.setProxyAllowanceAsync(takerTokenAddress, takerAddress, fillableAmount);
+
+ const signedOrder = await orderFactory.createSignedOrderAsync(this.zeroEx, makerAddress,
+ takerAddress, fillableAmount, makerTokenAddress, fillableAmount, takerTokenAddress,
+ expirationUnixTimestampSec);
+ return signedOrder;
+ }
+}