aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorFabio Berger <me@fabioberger.com>2017-05-30 18:37:25 +0800
committerGitHub <noreply@github.com>2017-05-30 18:37:25 +0800
commit911ab437b8f9371f70e835f680d799b7c62fb140 (patch)
tree658094383e06e2b4df944486f7caeb54550007ea /test
parent73ae3df172b1fdb7e6a3f5cbb866b09fb5f9d032 (diff)
parent02d7f808ab0a38e145c619b360738dc976898d54 (diff)
downloaddexon-sol-tools-911ab437b8f9371f70e835f680d799b7c62fb140.tar
dexon-sol-tools-911ab437b8f9371f70e835f680d799b7c62fb140.tar.gz
dexon-sol-tools-911ab437b8f9371f70e835f680d799b7c62fb140.tar.bz2
dexon-sol-tools-911ab437b8f9371f70e835f680d799b7c62fb140.tar.lz
dexon-sol-tools-911ab437b8f9371f70e835f680d799b7c62fb140.tar.xz
dexon-sol-tools-911ab437b8f9371f70e835f680d799b7c62fb140.tar.zst
dexon-sol-tools-911ab437b8f9371f70e835f680d799b7c62fb140.zip
Merge pull request #24 from 0xProject/tokenRegistry
TokenRegistryWrapper
Diffstat (limited to 'test')
-rw-r--r--test/token_registry_wrapper_test.ts43
1 files changed, 43 insertions, 0 deletions
diff --git a/test/token_registry_wrapper_test.ts b/test/token_registry_wrapper_test.ts
new file mode 100644
index 000000000..c91555d8b
--- /dev/null
+++ b/test/token_registry_wrapper_test.ts
@@ -0,0 +1,43 @@
+import * as _ from 'lodash';
+import 'mocha';
+import * as chai from 'chai';
+import chaiAsPromised = require('chai-as-promised');
+import * as Web3 from 'web3';
+import {web3Factory} from './utils/web3_factory';
+import {ZeroEx} from '../src/0x.js';
+import {BlockchainLifecycle} from './utils/blockchain_lifecycle';
+import {Token} from '../src/types';
+import {SchemaValidator} from '../src/utils/schema_validator';
+import {tokenSchema} from '../src/schemas/token_schema';
+
+const expect = chai.expect;
+chai.use(chaiAsPromised);
+const blockchainLifecycle = new BlockchainLifecycle();
+
+const TOKEN_REGISTRY_SIZE_AFTER_MIGRATION = 7;
+
+describe('TokenRegistryWrapper', () => {
+ let zeroEx: ZeroEx;
+ before(async () => {
+ const web3 = web3Factory.create();
+ zeroEx = new ZeroEx(web3);
+ });
+ beforeEach(async () => {
+ await blockchainLifecycle.startAsync();
+ });
+ afterEach(async () => {
+ await blockchainLifecycle.revertAsync();
+ });
+ describe('#getTokensAsync', () => {
+ it('should return all the tokens added to the tokenRegistry during the migration', async () => {
+ const tokens = await zeroEx.tokenRegistry.getTokensAsync();
+ expect(tokens).to.have.lengthOf(TOKEN_REGISTRY_SIZE_AFTER_MIGRATION);
+
+ const schemaValidator = new SchemaValidator();
+ _.each(tokens, token => {
+ const validationResult = schemaValidator.validate(token, tokenSchema);
+ expect(validationResult.errors).to.have.lengthOf(0);
+ });
+ });
+ });
+});