Wrap all event args in a newer version of BigNumber and test it
This commit is contained in:
parent
6e0edb8d8e
commit
0e54418dbb
@ -25,6 +25,8 @@ import {
|
|||||||
LogErrorContractEventArgs,
|
LogErrorContractEventArgs,
|
||||||
LogFillContractEventArgs,
|
LogFillContractEventArgs,
|
||||||
LogCancelContractEventArgs,
|
LogCancelContractEventArgs,
|
||||||
|
EventCallback,
|
||||||
|
ContractEventArg,
|
||||||
} from '../types';
|
} from '../types';
|
||||||
import {assert} from '../utils/assert';
|
import {assert} from '../utils/assert';
|
||||||
import {utils} from '../utils/utils';
|
import {utils} from '../utils/utils';
|
||||||
@ -583,14 +585,30 @@ export class ExchangeWrapper extends ContractWrapper {
|
|||||||
this._exchangeLogEventEmitters = [];
|
this._exchangeLogEventEmitters = [];
|
||||||
}
|
}
|
||||||
private _wrapEventEmitter(event: ContractEventObj): ContractEventEmitter {
|
private _wrapEventEmitter(event: ContractEventObj): ContractEventEmitter {
|
||||||
|
const watch = (eventCallback: EventCallback) => {
|
||||||
|
const bignumberWrappingEventCallback = this._wrapEventCallback(eventCallback);
|
||||||
|
event.watch(bignumberWrappingEventCallback);
|
||||||
|
};
|
||||||
const zeroExEvent = {
|
const zeroExEvent = {
|
||||||
watch: event.watch.bind(event),
|
watch,
|
||||||
stopWatchingAsync: async () => {
|
stopWatchingAsync: async () => {
|
||||||
await promisify(event.stopWatching, event)();
|
await promisify(event.stopWatching, event)();
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
return zeroExEvent;
|
return zeroExEvent;
|
||||||
}
|
}
|
||||||
|
private _wrapEventCallback(eventCallback: EventCallback): EventCallback {
|
||||||
|
const bignumberWrappingEventCallback = (err: Error, event: ContractEvent) => {
|
||||||
|
if (_.isNull(err)) {
|
||||||
|
const wrapIfBigNumber = (value: ContractEventArg): ContractEventArg => {
|
||||||
|
return value instanceof String ? value : new BigNumber(value);
|
||||||
|
};
|
||||||
|
event.args = _.mapValues(event.args, wrapIfBigNumber);
|
||||||
|
}
|
||||||
|
eventCallback(err, event);
|
||||||
|
};
|
||||||
|
return bignumberWrappingEventCallback;
|
||||||
|
}
|
||||||
private async _isValidSignatureUsingContractCallAsync(dataHex: string, ecSignature: ECSignature,
|
private async _isValidSignatureUsingContractCallAsync(dataHex: string, ecSignature: ECSignature,
|
||||||
signerAddressHex: string): Promise<boolean> {
|
signerAddressHex: string): Promise<boolean> {
|
||||||
assert.isHexString('dataHex', dataHex);
|
assert.isHexString('dataHex', dataHex);
|
||||||
|
@ -229,6 +229,7 @@ export interface LogErrorContractEventArgs {
|
|||||||
orderHash: string;
|
orderHash: string;
|
||||||
}
|
}
|
||||||
export type ContractEventArgs = LogFillContractEventArgs|LogCancelContractEventArgs|LogErrorContractEventArgs;
|
export type ContractEventArgs = LogFillContractEventArgs|LogCancelContractEventArgs|LogErrorContractEventArgs;
|
||||||
|
export type ContractEventArg = string|BigNumber.BigNumber;
|
||||||
|
|
||||||
export interface Order {
|
export interface Order {
|
||||||
maker: string;
|
maker: string;
|
||||||
|
@ -17,6 +17,7 @@ import {
|
|||||||
ExchangeContractErrs,
|
ExchangeContractErrs,
|
||||||
OrderCancellationRequest,
|
OrderCancellationRequest,
|
||||||
OrderFillRequest,
|
OrderFillRequest,
|
||||||
|
LogFillContractEventArgs,
|
||||||
} from '../src';
|
} from '../src';
|
||||||
import {DoneCallback} from '../src/types';
|
import {DoneCallback} from '../src/types';
|
||||||
import {FillScenarios} from './utils/fill_scenarios';
|
import {FillScenarios} from './utils/fill_scenarios';
|
||||||
@ -643,6 +644,12 @@ describe('ExchangeWrapper', () => {
|
|||||||
let makerAddress: string;
|
let makerAddress: string;
|
||||||
let fillableAmount: BigNumber.BigNumber;
|
let fillableAmount: BigNumber.BigNumber;
|
||||||
let signedOrder: SignedOrder;
|
let signedOrder: SignedOrder;
|
||||||
|
const subscriptionOpts: SubscriptionOpts = {
|
||||||
|
fromBlock: 0,
|
||||||
|
toBlock: 'latest',
|
||||||
|
};
|
||||||
|
const fillTakerAmountInBaseUnits = new BigNumber(1);
|
||||||
|
const cancelTakerAmountInBaseUnits = new BigNumber(1);
|
||||||
before(() => {
|
before(() => {
|
||||||
[coinbase, makerAddress, takerAddress] = userAddresses;
|
[coinbase, makerAddress, takerAddress] = userAddresses;
|
||||||
const [makerToken, takerToken] = tokens;
|
const [makerToken, takerToken] = tokens;
|
||||||
@ -665,10 +672,6 @@ describe('ExchangeWrapper', () => {
|
|||||||
// Source: https://github.com/mochajs/mocha/issues/2407
|
// Source: https://github.com/mochajs/mocha/issues/2407
|
||||||
it('Should receive the LogFill event when an order is filled', (done: DoneCallback) => {
|
it('Should receive the LogFill event when an order is filled', (done: DoneCallback) => {
|
||||||
(async () => {
|
(async () => {
|
||||||
const subscriptionOpts: SubscriptionOpts = {
|
|
||||||
fromBlock: 0,
|
|
||||||
toBlock: 'latest',
|
|
||||||
};
|
|
||||||
const zeroExEvent = await zeroEx.exchange.subscribeAsync(ExchangeEvents.LogFill, subscriptionOpts,
|
const zeroExEvent = await zeroEx.exchange.subscribeAsync(ExchangeEvents.LogFill, subscriptionOpts,
|
||||||
indexFilterValues);
|
indexFilterValues);
|
||||||
zeroExEvent.watch((err: Error, event: ContractEvent) => {
|
zeroExEvent.watch((err: Error, event: ContractEvent) => {
|
||||||
@ -676,7 +679,6 @@ describe('ExchangeWrapper', () => {
|
|||||||
expect(event).to.not.be.undefined();
|
expect(event).to.not.be.undefined();
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
const fillTakerAmountInBaseUnits = new BigNumber(1);
|
|
||||||
await zeroEx.exchange.fillOrderAsync(
|
await zeroEx.exchange.fillOrderAsync(
|
||||||
signedOrder, fillTakerAmountInBaseUnits, shouldCheckTransfer, takerAddress,
|
signedOrder, fillTakerAmountInBaseUnits, shouldCheckTransfer, takerAddress,
|
||||||
);
|
);
|
||||||
@ -684,10 +686,6 @@ describe('ExchangeWrapper', () => {
|
|||||||
});
|
});
|
||||||
it('Should receive the LogCancel event when an order is cancelled', (done: DoneCallback) => {
|
it('Should receive the LogCancel event when an order is cancelled', (done: DoneCallback) => {
|
||||||
(async () => {
|
(async () => {
|
||||||
const subscriptionOpts: SubscriptionOpts = {
|
|
||||||
fromBlock: 0,
|
|
||||||
toBlock: 'latest',
|
|
||||||
};
|
|
||||||
const zeroExEvent = await zeroEx.exchange.subscribeAsync(ExchangeEvents.LogCancel, subscriptionOpts,
|
const zeroExEvent = await zeroEx.exchange.subscribeAsync(ExchangeEvents.LogCancel, subscriptionOpts,
|
||||||
indexFilterValues);
|
indexFilterValues);
|
||||||
zeroExEvent.watch((err: Error, event: ContractEvent) => {
|
zeroExEvent.watch((err: Error, event: ContractEvent) => {
|
||||||
@ -695,16 +693,11 @@ describe('ExchangeWrapper', () => {
|
|||||||
expect(event).to.not.be.undefined();
|
expect(event).to.not.be.undefined();
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
const cancelTakerAmountInBaseUnits = new BigNumber(1);
|
|
||||||
await zeroEx.exchange.cancelOrderAsync(signedOrder, cancelTakerAmountInBaseUnits);
|
await zeroEx.exchange.cancelOrderAsync(signedOrder, cancelTakerAmountInBaseUnits);
|
||||||
})();
|
})();
|
||||||
});
|
});
|
||||||
it('Outstanding subscriptions are cancelled when zeroEx.setProviderAsync called', (done: DoneCallback) => {
|
it('Outstanding subscriptions are cancelled when zeroEx.setProviderAsync called', (done: DoneCallback) => {
|
||||||
(async () => {
|
(async () => {
|
||||||
const subscriptionOpts: SubscriptionOpts = {
|
|
||||||
fromBlock: 0,
|
|
||||||
toBlock: 'latest',
|
|
||||||
};
|
|
||||||
const eventSubscriptionToBeCancelled = await zeroEx.exchange.subscribeAsync(
|
const eventSubscriptionToBeCancelled = await zeroEx.exchange.subscribeAsync(
|
||||||
ExchangeEvents.LogFill, subscriptionOpts, indexFilterValues,
|
ExchangeEvents.LogFill, subscriptionOpts, indexFilterValues,
|
||||||
);
|
);
|
||||||
@ -723,8 +716,6 @@ describe('ExchangeWrapper', () => {
|
|||||||
expect(event).to.not.be.undefined();
|
expect(event).to.not.be.undefined();
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
const fillTakerAmountInBaseUnits = new BigNumber(1);
|
|
||||||
await zeroEx.exchange.fillOrderAsync(
|
await zeroEx.exchange.fillOrderAsync(
|
||||||
signedOrder, fillTakerAmountInBaseUnits, shouldCheckTransfer, takerAddress,
|
signedOrder, fillTakerAmountInBaseUnits, shouldCheckTransfer, takerAddress,
|
||||||
);
|
);
|
||||||
@ -732,10 +723,6 @@ describe('ExchangeWrapper', () => {
|
|||||||
});
|
});
|
||||||
it('Should stop watch for events when stopWatchingAsync called on the eventEmitter', (done: DoneCallback) => {
|
it('Should stop watch for events when stopWatchingAsync called on the eventEmitter', (done: DoneCallback) => {
|
||||||
(async () => {
|
(async () => {
|
||||||
const subscriptionOpts: SubscriptionOpts = {
|
|
||||||
fromBlock: 0,
|
|
||||||
toBlock: 'latest',
|
|
||||||
};
|
|
||||||
const eventSubscriptionToBeStopped = await zeroEx.exchange.subscribeAsync(
|
const eventSubscriptionToBeStopped = await zeroEx.exchange.subscribeAsync(
|
||||||
ExchangeEvents.LogFill, subscriptionOpts, indexFilterValues,
|
ExchangeEvents.LogFill, subscriptionOpts, indexFilterValues,
|
||||||
);
|
);
|
||||||
@ -743,13 +730,29 @@ describe('ExchangeWrapper', () => {
|
|||||||
done(new Error('Expected this subscription to have been stopped'));
|
done(new Error('Expected this subscription to have been stopped'));
|
||||||
});
|
});
|
||||||
await eventSubscriptionToBeStopped.stopWatchingAsync();
|
await eventSubscriptionToBeStopped.stopWatchingAsync();
|
||||||
const fillTakerAmountInBaseUnits = new BigNumber(1);
|
|
||||||
await zeroEx.exchange.fillOrderAsync(
|
await zeroEx.exchange.fillOrderAsync(
|
||||||
signedOrder, fillTakerAmountInBaseUnits, shouldCheckTransfer, takerAddress,
|
signedOrder, fillTakerAmountInBaseUnits, shouldCheckTransfer, takerAddress,
|
||||||
);
|
);
|
||||||
done();
|
done();
|
||||||
})();
|
})();
|
||||||
});
|
});
|
||||||
|
it('Should wrap all event args BigNumber instances in a newer version of BigNumber', (done: DoneCallback) => {
|
||||||
|
(async () => {
|
||||||
|
const zeroExEvent = await zeroEx.exchange.subscribeAsync(ExchangeEvents.LogFill, subscriptionOpts,
|
||||||
|
indexFilterValues);
|
||||||
|
zeroExEvent.watch((err: Error, event: ContractEvent) => {
|
||||||
|
const args = event.args as LogFillContractEventArgs;
|
||||||
|
expect(args.filledValueM.isBigNumber).to.be.true();
|
||||||
|
expect(args.filledValueT.isBigNumber).to.be.true();
|
||||||
|
expect(args.feeMPaid.isBigNumber).to.be.true();
|
||||||
|
expect(args.feeTPaid.isBigNumber).to.be.true();
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
await zeroEx.exchange.fillOrderAsync(
|
||||||
|
signedOrder, fillTakerAmountInBaseUnits, shouldCheckTransfer, takerAddress,
|
||||||
|
);
|
||||||
|
})();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
describe('#getOrderHashHexUsingContractCallAsync', () => {
|
describe('#getOrderHashHexUsingContractCallAsync', () => {
|
||||||
let makerTokenAddress: string;
|
let makerTokenAddress: string;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user