Rename assert sub-package and removed duplicate methods from 0x.js's assert module
This commit is contained in:
parent
cf29530dd0
commit
3e8e3478a3
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"private": true,
|
||||||
"name": "0x-assert",
|
"name": "0x-assert",
|
||||||
"version": "0.0.3",
|
"version": "0.0.3",
|
||||||
"description": "Provides a standard way of performing type and schema validation across 0x projects",
|
"description": "Provides a standard way of performing type and schema validation across 0x projects",
|
||||||
@ -40,6 +41,7 @@
|
|||||||
"bignumber.js": "~4.1.0",
|
"bignumber.js": "~4.1.0",
|
||||||
"ethereum-address": "^0.0.4",
|
"ethereum-address": "^0.0.4",
|
||||||
"lodash": "^4.17.4",
|
"lodash": "^4.17.4",
|
||||||
"valid-url": "^1.0.9"
|
"valid-url": "^1.0.9",
|
||||||
|
"0x-assert": "0.0.3"
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -12,6 +12,13 @@ export const assert = {
|
|||||||
const isBigNumber = _.isObject(value) && (value as any).isBigNumber;
|
const isBigNumber = _.isObject(value) && (value as any).isBigNumber;
|
||||||
this.assert(isBigNumber, this.typeAssertionMessage(variableName, 'BigNumber', value));
|
this.assert(isBigNumber, this.typeAssertionMessage(variableName, 'BigNumber', value));
|
||||||
},
|
},
|
||||||
|
isValidBaseUnitAmount(variableName: string, value: BigNumber) {
|
||||||
|
assert.isBigNumber(variableName, value);
|
||||||
|
const hasDecimals = value.decimalPlaces() !== 0;
|
||||||
|
this.assert(
|
||||||
|
!hasDecimals, `${variableName} should be in baseUnits (no decimals), found value: ${value.toNumber()}`,
|
||||||
|
);
|
||||||
|
},
|
||||||
isUndefined(value: any, variableName?: string): void {
|
isUndefined(value: any, variableName?: string): void {
|
||||||
this.assert(_.isUndefined(value), this.typeAssertionMessage(variableName, 'undefined', value));
|
this.assert(_.isUndefined(value), this.typeAssertionMessage(variableName, 'undefined', value));
|
||||||
},
|
},
|
@ -5,62 +5,20 @@ import {SchemaValidator, Schema} from '0x-json-schemas';
|
|||||||
import {Web3Wrapper} from '../web3_wrapper';
|
import {Web3Wrapper} from '../web3_wrapper';
|
||||||
import {signatureUtils} from '../utils/signature_utils';
|
import {signatureUtils} from '../utils/signature_utils';
|
||||||
import {ECSignature} from '../types';
|
import {ECSignature} from '../types';
|
||||||
|
import {assert as sharedAssert} from '0x-assert';
|
||||||
|
|
||||||
const HEX_REGEX = /^0x[0-9A-F]*$/i;
|
const HEX_REGEX = /^0x[0-9A-F]*$/i;
|
||||||
|
|
||||||
export const assert = {
|
export const assert = _.extend({}, sharedAssert, {
|
||||||
isBigNumber(variableName: string, value: BigNumber): void {
|
|
||||||
const isBigNumber = _.isObject(value) && (value as any).isBigNumber;
|
|
||||||
this.assert(isBigNumber, this.typeAssertionMessage(variableName, 'BigNumber', value));
|
|
||||||
},
|
|
||||||
isValidBaseUnitAmount(variableName: string, value: BigNumber) {
|
|
||||||
assert.isBigNumber(variableName, value);
|
|
||||||
const hasDecimals = value.decimalPlaces() !== 0;
|
|
||||||
this.assert(
|
|
||||||
!hasDecimals, `${variableName} should be in baseUnits (no decimals), found value: ${value.toNumber()}`,
|
|
||||||
);
|
|
||||||
},
|
|
||||||
isValidSignature(orderHash: string, ecSignature: ECSignature, signerAddress: string) {
|
isValidSignature(orderHash: string, ecSignature: ECSignature, signerAddress: string) {
|
||||||
const isValidSignature = signatureUtils.isValidSignature(orderHash, ecSignature, signerAddress);
|
const isValidSignature = signatureUtils.isValidSignature(orderHash, ecSignature, signerAddress);
|
||||||
this.assert(isValidSignature, `Expected order with hash '${orderHash}' to have a valid signature`);
|
this.assert(isValidSignature, `Expected order with hash '${orderHash}' to have a valid signature`);
|
||||||
},
|
},
|
||||||
isUndefined(value: any, variableName?: string): void {
|
|
||||||
this.assert(_.isUndefined(value), this.typeAssertionMessage(variableName, 'undefined', value));
|
|
||||||
},
|
|
||||||
isString(variableName: string, value: string): void {
|
|
||||||
this.assert(_.isString(value), this.typeAssertionMessage(variableName, 'string', value));
|
|
||||||
},
|
|
||||||
isFunction(variableName: string, value: any): void {
|
|
||||||
this.assert(_.isFunction(value), this.typeAssertionMessage(variableName, 'function', value));
|
|
||||||
},
|
|
||||||
isHexString(variableName: string, value: string): void {
|
|
||||||
this.assert(_.isString(value) && HEX_REGEX.test(value),
|
|
||||||
this.typeAssertionMessage(variableName, 'HexString', value));
|
|
||||||
},
|
|
||||||
isETHAddressHex(variableName: string, value: string): void {
|
|
||||||
const web3 = new Web3();
|
|
||||||
this.assert(web3.isAddress(value), this.typeAssertionMessage(variableName, 'ETHAddressHex', value));
|
|
||||||
this.assert(
|
|
||||||
web3.isAddress(value) && value.toLowerCase() === value,
|
|
||||||
`Checksummed addresses are not supported. Convert ${variableName} to lower case before passing`,
|
|
||||||
);
|
|
||||||
},
|
|
||||||
doesBelongToStringEnum(variableName: string, value: string,
|
|
||||||
stringEnum: any /* There is no base type for every string enum */): void {
|
|
||||||
const doesBelongToStringEnum = !_.isUndefined(stringEnum[value]);
|
|
||||||
const enumValues = _.keys(stringEnum);
|
|
||||||
const enumValuesAsStrings = _.map(enumValues, enumValue => `'${enumValue}'`);
|
|
||||||
const enumValuesAsString = enumValuesAsStrings.join(', ');
|
|
||||||
assert.assert(
|
|
||||||
doesBelongToStringEnum,
|
|
||||||
`Expected ${variableName} to be one of: ${enumValuesAsString}, encountered: ${value}`,
|
|
||||||
);
|
|
||||||
},
|
|
||||||
async isSenderAddressAsync(variableName: string, senderAddressHex: string,
|
async isSenderAddressAsync(variableName: string, senderAddressHex: string,
|
||||||
web3Wrapper: Web3Wrapper): Promise<void> {
|
web3Wrapper: Web3Wrapper): Promise<void> {
|
||||||
assert.isETHAddressHex(variableName, senderAddressHex);
|
sharedAssert.isETHAddressHex(variableName, senderAddressHex);
|
||||||
const isSenderAddressAvailable = await web3Wrapper.isSenderAddressAvailableAsync(senderAddressHex);
|
const isSenderAddressAvailable = await web3Wrapper.isSenderAddressAvailableAsync(senderAddressHex);
|
||||||
assert.assert(isSenderAddressAvailable,
|
sharedAssert.assert(isSenderAddressAvailable,
|
||||||
`Specified ${variableName} ${senderAddressHex} isn't available through the supplied web3 provider`,
|
`Specified ${variableName} ${senderAddressHex} isn't available through the supplied web3 provider`,
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
@ -68,34 +26,4 @@ export const assert = {
|
|||||||
const availableAddresses = await web3Wrapper.getAvailableAddressesAsync();
|
const availableAddresses = await web3Wrapper.getAvailableAddressesAsync();
|
||||||
this.assert(!_.isEmpty(availableAddresses), 'No addresses were available on the provided web3 provider');
|
this.assert(!_.isEmpty(availableAddresses), 'No addresses were available on the provided web3 provider');
|
||||||
},
|
},
|
||||||
hasAtMostOneUniqueValue(value: any[], errMsg: string): void {
|
});
|
||||||
this.assert(_.uniq(value).length <= 1, errMsg);
|
|
||||||
},
|
|
||||||
isNumber(variableName: string, value: number): void {
|
|
||||||
this.assert(_.isFinite(value), this.typeAssertionMessage(variableName, 'number', value));
|
|
||||||
},
|
|
||||||
isBoolean(variableName: string, value: boolean): void {
|
|
||||||
this.assert(_.isBoolean(value), this.typeAssertionMessage(variableName, 'boolean', value));
|
|
||||||
},
|
|
||||||
isWeb3Provider(variableName: string, value: Web3.Provider): void {
|
|
||||||
const isWeb3Provider = _.isFunction((value as any).send) || _.isFunction((value as any).sendAsync);
|
|
||||||
this.assert(isWeb3Provider, this.typeAssertionMessage(variableName, 'Web3.Provider', value));
|
|
||||||
},
|
|
||||||
doesConformToSchema(variableName: string, value: any, schema: Schema): void {
|
|
||||||
const schemaValidator = new SchemaValidator();
|
|
||||||
const validationResult = schemaValidator.validate(value, schema);
|
|
||||||
const hasValidationErrors = validationResult.errors.length > 0;
|
|
||||||
const msg = `Expected ${variableName} to conform to schema ${schema.id}
|
|
||||||
Encountered: ${JSON.stringify(value, null, '\t')}
|
|
||||||
Validation errors: ${validationResult.errors.join(', ')}`;
|
|
||||||
this.assert(!hasValidationErrors, msg);
|
|
||||||
},
|
|
||||||
assert(condition: boolean, message: string): void {
|
|
||||||
if (!condition) {
|
|
||||||
throw new Error(message);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
typeAssertionMessage(variableName: string, type: string, value: any): string {
|
|
||||||
return `Expected ${variableName} to be of type ${type}, encountered: ${value}`;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user