* Initial migration to Solidity 0.6.x - v3.0 first steps (#2063) * Initial migration, missing GSN, 721, 777 and Crowdsales. * Add _beforeTokenOperation and _afterTokenOperation. * Add documentation for hooks. * Add hooks doc * Add missing drafts * Add back ERC721 with hooks * Bring back ERC777 * Notes on hooks * Bring back GSN * Make functions virtual * Make GSN overrides explicit * Fix ERC20Pausable tests * Remove virtual from some view functions * Update linter * Delete examples * Remove unnecessary virtual * Remove roles from Pausable * Remove roles * Remove users of roles * Adapt ERC20 tests * Fix ERC721 tests * Add all ERC721 hooks * Add ERC777 hooks * Fix remaining tests * Bump compiler version * Move 721BurnableMock into mocks directory * Remove _before hooks * Fix tests * Upgrade linter * Put modifiers last * Remove _beforeTokenApproval and _beforeOperatorApproval hooks
27 lines
810 B
JavaScript
27 lines
810 B
JavaScript
const { accounts, contract } = require('@openzeppelin/test-environment');
|
|
|
|
const { BN, ether, expectRevert } = require('@openzeppelin/test-helpers');
|
|
const { shouldBehaveLikeERC20Capped } = require('./behaviors/ERC20Capped.behavior');
|
|
|
|
const ERC20Capped = contract.fromArtifact('ERC20CappedMock');
|
|
|
|
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);
|
|
});
|
|
});
|