* Sketch * Migrate all tests to test-env * Finish migration to test-env * Add config * Work on GSN tests * Migrate to newer test-env version and loader syntax * Add GSN setup * Finish test-env migration * Setup coverage using test-env * Migrate to npm package * Fix package.json * Add compile step to CI * Add comment on coverage setup * Remove dependency on @truffle/contract * Fix package-lock merge * Fix linter errors * Upgrade test-environment, depend locally on ganche-coverage * Improve coverage script * Improve sign.js API * Move accounts destructuring to describe block * Switch to prebuilt ethereumjs-vm package * Upgrade test-enviroment version * use workspace in circleci config * remove unnecessary npx
29 lines
953 B
JavaScript
29 lines
953 B
JavaScript
const { accounts, contract } = require('@openzeppelin/test-environment');
|
|
|
|
const { BN, ether, expectRevert } = require('@openzeppelin/test-helpers');
|
|
const { shouldBehaveLikeERC20Mintable } = require('./behaviors/ERC20Mintable.behavior');
|
|
const { shouldBehaveLikeERC20Capped } = require('./behaviors/ERC20Capped.behavior');
|
|
|
|
const ERC20Capped = contract.fromArtifact('ERC20Capped');
|
|
|
|
describe('ERC20Capped', function () {
|
|
const [ minter, ...otherAccounts ] = accounts;
|
|
|
|
const cap = ether('1000');
|
|
|
|
it('requires a non-zero cap', async function () {
|
|
await expectRevert(
|
|
ERC20Capped.new(new BN(0), { from: minter }), 'ERC20Capped: cap is 0'
|
|
);
|
|
});
|
|
|
|
context('once deployed', async function () {
|
|
beforeEach(async function () {
|
|
this.token = await ERC20Capped.new(cap, { from: minter });
|
|
});
|
|
|
|
shouldBehaveLikeERC20Capped(minter, otherAccounts, cap);
|
|
shouldBehaveLikeERC20Mintable(minter, otherAccounts);
|
|
});
|
|
});
|