* make StandardToken state variables private
* simplify mocks
* document new internal functions
* fix link to ERC20 document
* revert order of Transfer and Mint events
* Revert "simplify mocks"
This reverts commit 371fe3e567.
* add tests for new internal functions
* add check for null account
* add checks for balances and allowance
* add inline docs to BurnableToken._burn
* remove redundant checks and clarify why
38 lines
1.1 KiB
JavaScript
38 lines
1.1 KiB
JavaScript
const { expectThrow } = require('../../helpers/expectThrow');
|
|
const expectEvent = require('../../helpers/expectEvent');
|
|
|
|
const BigNumber = web3.BigNumber;
|
|
|
|
require('chai')
|
|
.use(require('chai-bignumber')(BigNumber))
|
|
.should();
|
|
|
|
function shouldBehaveLikeCappedToken (minter, [anyone], cap) {
|
|
describe('capped token', function () {
|
|
const from = minter;
|
|
|
|
it('should start with the correct cap', async function () {
|
|
(await this.token.cap()).should.be.bignumber.equal(cap);
|
|
});
|
|
|
|
it('should mint when amount is less than cap', async function () {
|
|
const { logs } = await this.token.mint(anyone, cap.sub(1), { from });
|
|
expectEvent.inLogs(logs, 'Mint');
|
|
});
|
|
|
|
it('should fail to mint if the ammount exceeds the cap', async function () {
|
|
await this.token.mint(anyone, cap.sub(1), { from });
|
|
await expectThrow(this.token.mint(anyone, 100, { from }));
|
|
});
|
|
|
|
it('should fail to mint after cap is reached', async function () {
|
|
await this.token.mint(anyone, cap, { from });
|
|
await expectThrow(this.token.mint(anyone, 1, { from }));
|
|
});
|
|
});
|
|
}
|
|
|
|
module.exports = {
|
|
shouldBehaveLikeCappedToken,
|
|
};
|