From dcd08e40e61f5d98f03d71dc588e379f44817758 Mon Sep 17 00:00:00 2001 From: Leonid Logvinov Date: Thu, 22 Jun 2017 23:36:43 +0200 Subject: Add kovan integration tests --- package.json | 1 + src/globals.d.ts | 8 ++++++++ test/artifacts_test.ts | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++ yarn.lock | 40 +++++++++++++++++++++++++++++++++---- 4 files changed, 99 insertions(+), 4 deletions(-) create mode 100644 test/artifacts_test.ts diff --git a/package.json b/package.json index d26ec6791..f8e2a37cb 100644 --- a/package.json +++ b/package.json @@ -79,6 +79,7 @@ "shx": "^0.2.2", "sinon": "^2.3.2", "source-map-support": "^0.4.15", + "truffle-hdwallet-provider": "^0.0.3", "tslint": "^5.3.2", "tslint-config-0xproject": "^0.0.2", "typedoc": "^0.7.1", diff --git a/src/globals.d.ts b/src/globals.d.ts index 15ebe03d0..84f634193 100644 --- a/src/globals.d.ts +++ b/src/globals.d.ts @@ -86,3 +86,11 @@ declare module 'es6-promisify' { declare module 'ethereumjs-abi' { const soliditySHA3: (argTypes: string[], args: any[]) => Buffer; } + +declare class HDWalletProvider { + constructor(mnemonic: string, rpcUrl: string); +} + +declare module 'truffle-hdwallet-provider' { + export = HDWalletProvider; +} diff --git a/test/artifacts_test.ts b/test/artifacts_test.ts new file mode 100644 index 000000000..937d2674d --- /dev/null +++ b/test/artifacts_test.ts @@ -0,0 +1,54 @@ +import * as _ from 'lodash'; +import * as chai from 'chai'; +import * as BigNumber from 'bignumber.js'; +import HDWalletProvider = require('truffle-hdwallet-provider'); +import {chaiSetup} from './utils/chai_setup'; +import {ZeroEx, Order} from '../src'; +import {web3Factory} from './utils/web3_factory'; +import {FillScenarios} from './utils/fill_scenarios'; + +chaiSetup.configure(); +const expect = chai.expect; + +// Those tests are slower cause they're talking to a remote node +const TIMEOUT = 10000; + +describe('Artifacts', () => { + describe('contracts are deployed on kovan', () => { + const kovanRpcUrl = 'https://kovan.0xproject.com'; + const mnemonic = 'concert load couple harbor equip island argue ramp clarify fence smart topic'; + const web3Provider = new HDWalletProvider(mnemonic, kovanRpcUrl); + const zeroEx = new ZeroEx(web3Provider); + it('token registry contract is deployed', async () => { + const tokens = await zeroEx.tokenRegistry.getTokensAsync(); + }).timeout(TIMEOUT); + it('proxy contract is deployed', async () => { + const [token] = await zeroEx.tokenRegistry.getTokensAsync(); + const allowance = await zeroEx.token.getProxyAllowanceAsync(token.address, ZeroEx.NULL_ADDRESS); + expect(allowance).to.be.bignumber.equal(0); + }).timeout(TIMEOUT); + it('exchange contract is deployed', async () => { + const userAddreses = await zeroEx.getAvailableAddressesAsync(); + const tokens = await zeroEx.tokenRegistry.getTokensAsync(); + const makerTokenAddress = tokens[0].address; + const takerTokenAddress = tokens[1].address; + // Unused anyway + const zrxTokenAddress = ZeroEx.NULL_ADDRESS; + const fillScenarios = new FillScenarios(zeroEx, userAddreses, tokens, zrxTokenAddress); + const order: Order = { + maker: userAddreses[0], + taker: userAddreses[0], + makerFee: new BigNumber(0), + takerFee: new BigNumber(0), + makerTokenAmount: new BigNumber(0), + takerTokenAmount: new BigNumber(0), + makerTokenAddress, + takerTokenAddress, + salt: ZeroEx.generatePseudoRandomSalt(), + feeRecipient: ZeroEx.NULL_ADDRESS, + expirationUnixTimestampSec: new BigNumber(2524604400), + }; + const orderHash = await zeroEx.getOrderHashHexAsync(order); + }).timeout(TIMEOUT); + }); +}); diff --git a/yarn.lock b/yarn.lock index 674bb9246..94d3ad2db 100644 --- a/yarn.lock +++ b/yarn.lock @@ -42,10 +42,14 @@ version "2.2.41" resolved "https://registry.yarnpkg.com/@types/mocha/-/mocha-2.2.41.tgz#e27cf0817153eb9f2713b2d3f6c68f1e1c3ca608" -"@types/node@*", "@types/node@^7.0.22": +"@types/node@*": version "7.0.23" resolved "https://registry.yarnpkg.com/@types/node/-/node-7.0.23.tgz#ededfd92e61046c32fcad56ea7e1101733fad4a4" +"@types/node@^8.0.1": + version "8.0.1" + resolved "https://registry.yarnpkg.com/@types/node/-/node-8.0.1.tgz#89c271e0c3b9ebb6a3756dd601336970b6228b77" + "@types/shelljs@^0.7.0": version "0.7.1" resolved "https://registry.yarnpkg.com/@types/shelljs/-/shelljs-0.7.1.tgz#30fe144e3bdd37c11c174445bc54190cb7992a45" @@ -716,7 +720,7 @@ bindings@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/bindings/-/bindings-1.2.1.tgz#14ad6113812d2d37d72e67b4cacb4bb726505f11" -bip39@~2.2.0: +bip39@^2.2.0, bip39@~2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/bip39/-/bip39-2.2.0.tgz#40e73f70674c267f148cdbf8374f2a50be166b0d" dependencies: @@ -1548,7 +1552,7 @@ ethereumjs-vm@^2.0.2, ethereumjs-vm@~2.0.1: functional-red-black-tree "^1.0.1" merkle-patricia-tree "^2.1.2" -ethereumjs-wallet@~0.6.0: +ethereumjs-wallet@^0.6.0, ethereumjs-wallet@~0.6.0: version "0.6.0" resolved "https://registry.yarnpkg.com/ethereumjs-wallet/-/ethereumjs-wallet-0.6.0.tgz#82763b1697ee7a796be7155da9dfb49b2f98cfdb" dependencies: @@ -4247,6 +4251,15 @@ truffle-contract@^2.0.1: truffle-contract-schema "0.0.5" web3 "^0.18.0" +truffle-hdwallet-provider@^0.0.3: + version "0.0.3" + resolved "https://registry.yarnpkg.com/truffle-hdwallet-provider/-/truffle-hdwallet-provider-0.0.3.tgz#0e1de02104b73d3875e1cf7093305b4ea8a2d843" + dependencies: + bip39 "^2.2.0" + ethereumjs-wallet "^0.6.0" + web3 "^0.18.2" + web3-provider-engine "^8.4.0" + tslib@^1.7.1: version "1.7.1" resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.7.1.tgz#bc8004164691923a79fe8378bbeb3da2017538ec" @@ -4448,6 +4461,25 @@ web3-provider-engine@^13.0.1: xhr "^2.2.0" xtend "^4.0.1" +web3-provider-engine@^8.4.0: + version "8.6.1" + resolved "https://registry.yarnpkg.com/web3-provider-engine/-/web3-provider-engine-8.6.1.tgz#4d86e19e30caaf97df351511ec0f60136e5b30eb" + dependencies: + async "^2.1.2" + clone "^2.0.0" + ethereumjs-block "^1.2.2" + ethereumjs-tx "^1.2.0" + ethereumjs-util "^5.0.1" + ethereumjs-vm "^2.0.2" + isomorphic-fetch "^2.2.0" + request "^2.67.0" + semaphore "^1.0.3" + solc "^0.4.2" + tape "^4.4.0" + web3 "^0.16.0" + xhr "^2.2.0" + xtend "^4.0.1" + web3-provider-engine@~8.1.0: version "8.1.19" resolved "https://registry.yarnpkg.com/web3-provider-engine/-/web3-provider-engine-8.1.19.tgz#3ccae95adecef55632e2a73bf3bee64b7e62fcf7" @@ -4482,7 +4514,7 @@ web3@^0.16.0, web3@~0.16.0: utf8 "^2.1.1" xmlhttprequest "*" -web3@^0.18.0: +web3@^0.18.0, web3@^0.18.2: version "0.18.4" resolved "https://registry.yarnpkg.com/web3/-/web3-0.18.4.tgz#81ec1784145491f2eaa8955b31c06049e07c5e7d" dependencies: -- cgit v1.2.3 From 3f962585e9924a88082e91153cf3347922046941 Mon Sep 17 00:00:00 2001 From: Leonid Logvinov Date: Fri, 23 Jun 2017 12:03:40 +0200 Subject: Refactor KOVAN_URL to constants and fetch mnemonic from package.json --- test/artifacts_test.ts | 8 ++++++-- test/utils/constants.ts | 1 + 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/test/artifacts_test.ts b/test/artifacts_test.ts index 937d2674d..74705a525 100644 --- a/test/artifacts_test.ts +++ b/test/artifacts_test.ts @@ -1,3 +1,4 @@ +import * as fs from 'fs'; import * as _ from 'lodash'; import * as chai from 'chai'; import * as BigNumber from 'bignumber.js'; @@ -6,6 +7,7 @@ import {chaiSetup} from './utils/chai_setup'; import {ZeroEx, Order} from '../src'; import {web3Factory} from './utils/web3_factory'; import {FillScenarios} from './utils/fill_scenarios'; +import {constants} from './utils/constants'; chaiSetup.configure(); const expect = chai.expect; @@ -15,8 +17,10 @@ const TIMEOUT = 10000; describe('Artifacts', () => { describe('contracts are deployed on kovan', () => { - const kovanRpcUrl = 'https://kovan.0xproject.com'; - const mnemonic = 'concert load couple harbor equip island argue ramp clarify fence smart topic'; + const kovanRpcUrl = constants.KOVAN_URL; + const packageJSONContent = fs.readFileSync('package.json', 'utf-8'); + const packageJSON = JSON.parse(packageJSONContent); + const mnemonic = packageJSON.config.mnemonic; const web3Provider = new HDWalletProvider(mnemonic, kovanRpcUrl); const zeroEx = new ZeroEx(web3Provider); it('token registry contract is deployed', async () => { diff --git a/test/utils/constants.ts b/test/utils/constants.ts index aa1967f88..8211eea00 100644 --- a/test/utils/constants.ts +++ b/test/utils/constants.ts @@ -2,4 +2,5 @@ export const constants = { NULL_ADDRESS: '0x0000000000000000000000000000000000000000', RPC_HOST: 'localhost', RPC_PORT: 8545, + KOVAN_URL: 'https://kovan.0xproject.com', }; -- cgit v1.2.3 From 9a6a9fc28b6c59c6b74dbd47fd6f36a8597fe3fa Mon Sep 17 00:00:00 2001 From: Leonid Logvinov Date: Fri, 23 Jun 2017 12:05:48 +0200 Subject: Add comment before declarations --- src/globals.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/globals.d.ts b/src/globals.d.ts index 84f634193..4a0a3fb04 100644 --- a/src/globals.d.ts +++ b/src/globals.d.ts @@ -87,10 +87,10 @@ declare module 'ethereumjs-abi' { const soliditySHA3: (argTypes: string[], args: any[]) => Buffer; } +// truffle-hdwallet-provider declarations declare class HDWalletProvider { constructor(mnemonic: string, rpcUrl: string); } - declare module 'truffle-hdwallet-provider' { export = HDWalletProvider; } -- cgit v1.2.3 From 845aee35d36a1c9031096738d6144045c32263cb Mon Sep 17 00:00:00 2001 From: Leonid Logvinov Date: Fri, 23 Jun 2017 12:12:16 +0200 Subject: Simplify integration tests --- test/artifacts_test.ts | 38 ++++---------------------------------- 1 file changed, 4 insertions(+), 34 deletions(-) diff --git a/test/artifacts_test.ts b/test/artifacts_test.ts index 74705a525..1121ef951 100644 --- a/test/artifacts_test.ts +++ b/test/artifacts_test.ts @@ -1,17 +1,9 @@ import * as fs from 'fs'; -import * as _ from 'lodash'; -import * as chai from 'chai'; -import * as BigNumber from 'bignumber.js'; import HDWalletProvider = require('truffle-hdwallet-provider'); -import {chaiSetup} from './utils/chai_setup'; -import {ZeroEx, Order} from '../src'; +import {ZeroEx} from '../src'; import {web3Factory} from './utils/web3_factory'; -import {FillScenarios} from './utils/fill_scenarios'; import {constants} from './utils/constants'; -chaiSetup.configure(); -const expect = chai.expect; - // Those tests are slower cause they're talking to a remote node const TIMEOUT = 10000; @@ -24,35 +16,13 @@ describe('Artifacts', () => { const web3Provider = new HDWalletProvider(mnemonic, kovanRpcUrl); const zeroEx = new ZeroEx(web3Provider); it('token registry contract is deployed', async () => { - const tokens = await zeroEx.tokenRegistry.getTokensAsync(); + await (zeroEx.tokenRegistry as any)._getTokenRegistryContractAsync(); }).timeout(TIMEOUT); it('proxy contract is deployed', async () => { - const [token] = await zeroEx.tokenRegistry.getTokensAsync(); - const allowance = await zeroEx.token.getProxyAllowanceAsync(token.address, ZeroEx.NULL_ADDRESS); - expect(allowance).to.be.bignumber.equal(0); + await (zeroEx.token as any)._getProxyAddressAsync(); }).timeout(TIMEOUT); it('exchange contract is deployed', async () => { - const userAddreses = await zeroEx.getAvailableAddressesAsync(); - const tokens = await zeroEx.tokenRegistry.getTokensAsync(); - const makerTokenAddress = tokens[0].address; - const takerTokenAddress = tokens[1].address; - // Unused anyway - const zrxTokenAddress = ZeroEx.NULL_ADDRESS; - const fillScenarios = new FillScenarios(zeroEx, userAddreses, tokens, zrxTokenAddress); - const order: Order = { - maker: userAddreses[0], - taker: userAddreses[0], - makerFee: new BigNumber(0), - takerFee: new BigNumber(0), - makerTokenAmount: new BigNumber(0), - takerTokenAmount: new BigNumber(0), - makerTokenAddress, - takerTokenAddress, - salt: ZeroEx.generatePseudoRandomSalt(), - feeRecipient: ZeroEx.NULL_ADDRESS, - expirationUnixTimestampSec: new BigNumber(2524604400), - }; - const orderHash = await zeroEx.getOrderHashHexAsync(order); + await (zeroEx.exchange as any)._getExchangeContractAsync(); }).timeout(TIMEOUT); }); }); -- cgit v1.2.3 From 75ae305a6e95a775497c971b4d40c1757abba25f Mon Sep 17 00:00:00 2001 From: Leonid Logvinov Date: Fri, 23 Jun 2017 17:10:43 +0200 Subject: Rename KOVAN_URL to KOVAN_RPC_URL --- test/artifacts_test.ts | 2 +- test/utils/constants.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/test/artifacts_test.ts b/test/artifacts_test.ts index 1121ef951..d71b45567 100644 --- a/test/artifacts_test.ts +++ b/test/artifacts_test.ts @@ -9,7 +9,7 @@ const TIMEOUT = 10000; describe('Artifacts', () => { describe('contracts are deployed on kovan', () => { - const kovanRpcUrl = constants.KOVAN_URL; + const kovanRpcUrl = constants.KOVAN_RPC_URL; const packageJSONContent = fs.readFileSync('package.json', 'utf-8'); const packageJSON = JSON.parse(packageJSONContent); const mnemonic = packageJSON.config.mnemonic; diff --git a/test/utils/constants.ts b/test/utils/constants.ts index 8211eea00..9b150b5c1 100644 --- a/test/utils/constants.ts +++ b/test/utils/constants.ts @@ -2,5 +2,5 @@ export const constants = { NULL_ADDRESS: '0x0000000000000000000000000000000000000000', RPC_HOST: 'localhost', RPC_PORT: 8545, - KOVAN_URL: 'https://kovan.0xproject.com', + KOVAN_RPC_URL: 'https://kovan.0xproject.com', }; -- cgit v1.2.3