* update abi-gen with new method interfaces * wip: get all packages to build * wip: get all packages to build * Fix two contract wrapper calls * Export necessary types part of the contract wrapper public interfaces * Revive and fix wrapper_unit_tests * Remove duplicate type * Fix lib_exchange_rich_error_decoder tests * Fix remaining test failures in contracts-* packages * Prettier fixes * remove transactionHelper * lint and update changelogs * Fix prettier * Revert changes to reference docs * Add back changelog already published and add revert changelog entry * Add missing CHANGELOG entries * Add missing comma * Update mesh-rpc-client dep * Update Mesh RPC logic in @0x/orderbook to v6.0.1-beta * Align package versions
170 lines
7.2 KiB
TypeScript
170 lines
7.2 KiB
TypeScript
import { chaiSetup, expectTransactionFailedAsync, provider, txDefaults, web3Wrapper } from '@0x/contracts-test-utils';
|
|
import { BlockchainLifecycle } from '@0x/dev-utils';
|
|
import { RevertReason } from '@0x/types';
|
|
import { BigNumber } from '@0x/utils';
|
|
import * as chai from 'chai';
|
|
import * as _ from 'lodash';
|
|
|
|
import { artifacts } from './artifacts';
|
|
|
|
import { MixinAuthorizableContract } from './wrappers';
|
|
|
|
chaiSetup.configure();
|
|
const expect = chai.expect;
|
|
const blockchainLifecycle = new BlockchainLifecycle(web3Wrapper);
|
|
|
|
describe('Authorizable', () => {
|
|
let owner: string;
|
|
let notOwner: string;
|
|
let address: string;
|
|
let authorizable: MixinAuthorizableContract;
|
|
|
|
before(async () => {
|
|
await blockchainLifecycle.startAsync();
|
|
});
|
|
|
|
after(async () => {
|
|
await blockchainLifecycle.revertAsync();
|
|
});
|
|
|
|
before(async () => {
|
|
const accounts = await web3Wrapper.getAvailableAddressesAsync();
|
|
[owner, address, notOwner] = _.slice(accounts, 0, 3);
|
|
authorizable = await MixinAuthorizableContract.deployFrom0xArtifactAsync(
|
|
artifacts.MixinAuthorizable,
|
|
provider,
|
|
txDefaults,
|
|
artifacts,
|
|
);
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
await blockchainLifecycle.startAsync();
|
|
});
|
|
|
|
afterEach(async () => {
|
|
await blockchainLifecycle.revertAsync();
|
|
});
|
|
|
|
describe('addAuthorizedAddress', () => {
|
|
it('should revert if not called by owner', async () => {
|
|
await expectTransactionFailedAsync(
|
|
authorizable.addAuthorizedAddress(notOwner).sendTransactionAsync({ from: notOwner }),
|
|
RevertReason.OnlyContractOwner,
|
|
);
|
|
});
|
|
|
|
it('should allow owner to add an authorized address', async () => {
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
const isAuthorized = await authorizable.authorized(address).callAsync();
|
|
expect(isAuthorized).to.be.true();
|
|
});
|
|
|
|
it('should revert if owner attempts to authorize a duplicate address', async () => {
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
return expectTransactionFailedAsync(
|
|
authorizable.addAuthorizedAddress(address).sendTransactionAsync({ from: owner }),
|
|
RevertReason.TargetAlreadyAuthorized,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('removeAuthorizedAddress', () => {
|
|
it('should revert if not called by owner', async () => {
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
await expectTransactionFailedAsync(
|
|
authorizable.removeAuthorizedAddress(address).sendTransactionAsync({ from: notOwner }),
|
|
RevertReason.OnlyContractOwner,
|
|
);
|
|
});
|
|
|
|
it('should allow owner to remove an authorized address', async () => {
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
await authorizable.removeAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
const isAuthorized = await authorizable.authorized(address).callAsync();
|
|
expect(isAuthorized).to.be.false();
|
|
});
|
|
|
|
it('should revert if owner attempts to remove an address that is not authorized', async () => {
|
|
return expectTransactionFailedAsync(
|
|
authorizable.removeAuthorizedAddress(address).sendTransactionAsync({
|
|
from: owner,
|
|
}),
|
|
RevertReason.TargetNotAuthorized,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('removeAuthorizedAddressAtIndex', () => {
|
|
it('should revert if not called by owner', async () => {
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
const index = new BigNumber(0);
|
|
await expectTransactionFailedAsync(
|
|
authorizable.removeAuthorizedAddressAtIndex(address, index).sendTransactionAsync({
|
|
from: notOwner,
|
|
}),
|
|
RevertReason.OnlyContractOwner,
|
|
);
|
|
});
|
|
|
|
it('should revert if index is >= authorities.length', async () => {
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
const index = new BigNumber(1);
|
|
return expectTransactionFailedAsync(
|
|
authorizable.removeAuthorizedAddressAtIndex(address, index).sendTransactionAsync({
|
|
from: owner,
|
|
}),
|
|
RevertReason.IndexOutOfBounds,
|
|
);
|
|
});
|
|
|
|
it('should revert if owner attempts to remove an address that is not authorized', async () => {
|
|
const index = new BigNumber(0);
|
|
return expectTransactionFailedAsync(
|
|
authorizable.removeAuthorizedAddressAtIndex(address, index).sendTransactionAsync({
|
|
from: owner,
|
|
}),
|
|
RevertReason.TargetNotAuthorized,
|
|
);
|
|
});
|
|
|
|
it('should revert if address at index does not match target', async () => {
|
|
const address1 = address;
|
|
const address2 = notOwner;
|
|
await authorizable.addAuthorizedAddress(address1).awaitTransactionSuccessAsync({ from: owner });
|
|
await authorizable.addAuthorizedAddress(address2).awaitTransactionSuccessAsync({ from: owner });
|
|
const address1Index = new BigNumber(0);
|
|
return expectTransactionFailedAsync(
|
|
authorizable.removeAuthorizedAddressAtIndex(address2, address1Index).sendTransactionAsync({
|
|
from: owner,
|
|
}),
|
|
RevertReason.AuthorizedAddressMismatch,
|
|
);
|
|
});
|
|
|
|
it('should allow owner to remove an authorized address', async () => {
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
const index = new BigNumber(0);
|
|
await authorizable.removeAuthorizedAddressAtIndex(address, index).awaitTransactionSuccessAsync({
|
|
from: owner,
|
|
});
|
|
const isAuthorized = await authorizable.authorized(address).callAsync();
|
|
expect(isAuthorized).to.be.false();
|
|
});
|
|
});
|
|
|
|
describe('getAuthorizedAddresses', () => {
|
|
it('should return all authorized addresses', async () => {
|
|
const initial = await authorizable.getAuthorizedAddresses().callAsync();
|
|
expect(initial).to.have.length(0);
|
|
await authorizable.addAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
const afterAdd = await authorizable.getAuthorizedAddresses().callAsync();
|
|
expect(afterAdd).to.have.length(1);
|
|
expect(afterAdd).to.include(address);
|
|
await authorizable.removeAuthorizedAddress(address).awaitTransactionSuccessAsync({ from: owner });
|
|
const afterRemove = await authorizable.getAuthorizedAddresses().callAsync();
|
|
expect(afterRemove).to.have.length(0);
|
|
});
|
|
});
|
|
});
|