244 lines
9.5 KiB
TypeScript
244 lines
9.5 KiB
TypeScript
import { ZeroEx } from '0x.js';
|
|
import { BlockchainLifecycle, devConstants, web3Factory } from '@0xproject/dev-utils';
|
|
import { Web3Wrapper } from '@0xproject/web3-wrapper';
|
|
import * as chai from 'chai';
|
|
import ethUtil = require('ethereumjs-util');
|
|
import * as _ from 'lodash';
|
|
import * as Web3 from 'web3';
|
|
|
|
import { constants } from '../util/constants';
|
|
import { TokenRegWrapper } from '../util/token_registry_wrapper';
|
|
import { ContractName } from '../util/types';
|
|
|
|
import { chaiSetup } from './utils/chai_setup';
|
|
import { deployer } from './utils/deployer';
|
|
|
|
chaiSetup.configure();
|
|
const expect = chai.expect;
|
|
const web3 = web3Factory.create();
|
|
const web3Wrapper = new Web3Wrapper(web3.currentProvider);
|
|
const blockchainLifecycle = new BlockchainLifecycle(devConstants.RPC_URL);
|
|
|
|
describe('TokenRegistry', () => {
|
|
let owner: string;
|
|
let notOwner: string;
|
|
let tokenReg: Web3.ContractInstance;
|
|
let tokenRegWrapper: TokenRegWrapper;
|
|
before(async () => {
|
|
const accounts = await web3Wrapper.getAvailableAddressesAsync();
|
|
owner = accounts[0];
|
|
notOwner = accounts[1];
|
|
tokenReg = await deployer.deployAsync(ContractName.TokenRegistry);
|
|
tokenRegWrapper = new TokenRegWrapper(tokenReg);
|
|
});
|
|
beforeEach(async () => {
|
|
await blockchainLifecycle.startAsync();
|
|
});
|
|
afterEach(async () => {
|
|
await blockchainLifecycle.revertAsync();
|
|
});
|
|
|
|
const tokenAddress1 = `0x${ethUtil.setLength(ethUtil.toBuffer('0x1'), 20, false).toString('hex')}`;
|
|
const tokenAddress2 = `0x${ethUtil.setLength(ethUtil.toBuffer('0x2'), 20, false).toString('hex')}`;
|
|
|
|
const token1 = {
|
|
address: tokenAddress1,
|
|
name: 'testToken1',
|
|
symbol: 'TT1',
|
|
decimals: 18,
|
|
ipfsHash: `0x${ethUtil.sha3('ipfs1').toString('hex')}`,
|
|
swarmHash: `0x${ethUtil.sha3('swarm1').toString('hex')}`,
|
|
};
|
|
|
|
const token2 = {
|
|
address: tokenAddress2,
|
|
name: 'testToken2',
|
|
symbol: 'TT2',
|
|
decimals: 18,
|
|
ipfsHash: `0x${ethUtil.sha3('ipfs2').toString('hex')}`,
|
|
swarmHash: `0x${ethUtil.sha3('swarm2').toString('hex')}`,
|
|
};
|
|
|
|
const nullToken = {
|
|
address: ZeroEx.NULL_ADDRESS,
|
|
name: '',
|
|
symbol: '',
|
|
decimals: 0,
|
|
ipfsHash: constants.NULL_BYTES,
|
|
swarmHash: constants.NULL_BYTES,
|
|
};
|
|
|
|
describe('addToken', () => {
|
|
it('should throw when not called by owner', async () => {
|
|
return expect(tokenRegWrapper.addTokenAsync(token1, notOwner)).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
|
|
it('should add token metadata when called by owner', async () => {
|
|
await tokenRegWrapper.addTokenAsync(token1, owner);
|
|
const tokenData = await tokenRegWrapper.getTokenMetaDataAsync(token1.address);
|
|
expect(tokenData).to.be.deep.equal(token1);
|
|
});
|
|
|
|
it('should throw if token already exists', async () => {
|
|
await tokenRegWrapper.addTokenAsync(token1, owner);
|
|
|
|
return expect(tokenRegWrapper.addTokenAsync(token1, owner)).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
|
|
it('should throw if token address is null', async () => {
|
|
return expect(tokenRegWrapper.addTokenAsync(nullToken, owner)).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
|
|
it('should throw if name already exists', async () => {
|
|
await tokenRegWrapper.addTokenAsync(token1, owner);
|
|
const duplicateNameToken = _.assign({}, token2, { name: token1.name });
|
|
|
|
return expect(tokenRegWrapper.addTokenAsync(duplicateNameToken, owner)).to.be.rejectedWith(
|
|
constants.REVERT,
|
|
);
|
|
});
|
|
|
|
it('should throw if symbol already exists', async () => {
|
|
await tokenRegWrapper.addTokenAsync(token1, owner);
|
|
const duplicateSymbolToken = _.assign({}, token2, {
|
|
symbol: token1.symbol,
|
|
});
|
|
|
|
return expect(tokenRegWrapper.addTokenAsync(duplicateSymbolToken, owner)).to.be.rejectedWith(
|
|
constants.REVERT,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('after addToken', () => {
|
|
beforeEach(async () => {
|
|
await tokenRegWrapper.addTokenAsync(token1, owner);
|
|
});
|
|
|
|
describe('getTokenByName', () => {
|
|
it('should return token metadata when given the token name', async () => {
|
|
const tokenData = await tokenRegWrapper.getTokenByNameAsync(token1.name);
|
|
expect(tokenData).to.be.deep.equal(token1);
|
|
});
|
|
});
|
|
|
|
describe('getTokenBySymbol', () => {
|
|
it('should return token metadata when given the token symbol', async () => {
|
|
const tokenData = await tokenRegWrapper.getTokenBySymbolAsync(token1.symbol);
|
|
expect(tokenData).to.be.deep.equal(token1);
|
|
});
|
|
});
|
|
|
|
describe('setTokenName', () => {
|
|
it('should throw when not called by owner', async () => {
|
|
return expect(
|
|
tokenReg.setTokenName(token1.address, token2.name, { from: notOwner }),
|
|
).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
|
|
it('should change the token name when called by owner', async () => {
|
|
await tokenReg.setTokenName(token1.address, token2.name, {
|
|
from: owner,
|
|
});
|
|
const [newData, oldData] = await Promise.all([
|
|
tokenRegWrapper.getTokenByNameAsync(token2.name),
|
|
tokenRegWrapper.getTokenByNameAsync(token1.name),
|
|
]);
|
|
|
|
const expectedNewData = _.assign({}, token1, { name: token2.name });
|
|
const expectedOldData = nullToken;
|
|
expect(newData).to.be.deep.equal(expectedNewData);
|
|
expect(oldData).to.be.deep.equal(expectedOldData);
|
|
});
|
|
|
|
it('should throw if the name already exists', async () => {
|
|
await tokenRegWrapper.addTokenAsync(token2, owner);
|
|
|
|
return expect(tokenReg.setTokenName(token1.address, token2.name, { from: owner })).to.be.rejectedWith(
|
|
constants.REVERT,
|
|
);
|
|
});
|
|
|
|
it('should throw if token does not exist', async () => {
|
|
return expect(
|
|
tokenReg.setTokenName(nullToken.address, token2.name, { from: owner }),
|
|
).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
});
|
|
|
|
describe('setTokenSymbol', () => {
|
|
it('should throw when not called by owner', async () => {
|
|
return expect(
|
|
tokenReg.setTokenSymbol(token1.address, token2.symbol, {
|
|
from: notOwner,
|
|
}),
|
|
).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
|
|
it('should change the token symbol when called by owner', async () => {
|
|
await tokenReg.setTokenSymbol(token1.address, token2.symbol, { from: owner });
|
|
const [newData, oldData] = await Promise.all([
|
|
tokenRegWrapper.getTokenBySymbolAsync(token2.symbol),
|
|
tokenRegWrapper.getTokenBySymbolAsync(token1.symbol),
|
|
]);
|
|
|
|
const expectedNewData = _.assign({}, token1, { symbol: token2.symbol });
|
|
const expectedOldData = nullToken;
|
|
expect(newData).to.be.deep.equal(expectedNewData);
|
|
expect(oldData).to.be.deep.equal(expectedOldData);
|
|
});
|
|
|
|
it('should throw if the symbol already exists', async () => {
|
|
await tokenRegWrapper.addTokenAsync(token2, owner);
|
|
|
|
return expect(
|
|
tokenReg.setTokenSymbol(token1.address, token2.symbol, {
|
|
from: owner,
|
|
}),
|
|
).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
|
|
it('should throw if token does not exist', async () => {
|
|
return expect(
|
|
tokenReg.setTokenSymbol(nullToken.address, token2.symbol, {
|
|
from: owner,
|
|
}),
|
|
).to.be.rejectedWith(constants.REVERT);
|
|
});
|
|
});
|
|
|
|
describe('removeToken', () => {
|
|
it('should throw if not called by owner', async () => {
|
|
const index = 0;
|
|
return expect(tokenReg.removeToken(token1.address, index, { from: notOwner })).to.be.rejectedWith(
|
|
constants.REVERT,
|
|
);
|
|
});
|
|
|
|
it('should remove token metadata when called by owner', async () => {
|
|
const index = 0;
|
|
await tokenReg.removeToken(token1.address, index, {
|
|
from: owner,
|
|
});
|
|
const tokenData = await tokenRegWrapper.getTokenMetaDataAsync(token1.address);
|
|
expect(tokenData).to.be.deep.equal(nullToken);
|
|
});
|
|
|
|
it('should throw if token does not exist', async () => {
|
|
const index = 0;
|
|
return expect(tokenReg.removeToken(nullToken.address, index, { from: owner })).to.be.rejectedWith(
|
|
constants.REVERT,
|
|
);
|
|
});
|
|
|
|
it('should throw if token at given index does not match address', async () => {
|
|
await tokenRegWrapper.addTokenAsync(token2, owner);
|
|
const incorrectIndex = 0;
|
|
return expect(tokenReg.removeToken(token2.address, incorrectIndex, { from: owner })).to.be.rejectedWith(
|
|
constants.REVERT,
|
|
);
|
|
});
|
|
});
|
|
});
|
|
});
|