* 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
80 lines
2.5 KiB
JavaScript
80 lines
2.5 KiB
JavaScript
const { accounts, contract } = require('@openzeppelin/test-environment');
|
|
|
|
const { BN, constants, expectEvent, expectRevert } = require('@openzeppelin/test-helpers');
|
|
const { ZERO_ADDRESS } = constants;
|
|
|
|
const { expect } = require('chai');
|
|
|
|
const ERC721BurnableMock = contract.fromArtifact('ERC721BurnableMock');
|
|
|
|
describe('ERC721Burnable', function () {
|
|
const [owner, approved] = accounts;
|
|
|
|
const firstTokenId = new BN(1);
|
|
const secondTokenId = new BN(2);
|
|
const unknownTokenId = new BN(3);
|
|
|
|
beforeEach(async function () {
|
|
this.token = await ERC721BurnableMock.new();
|
|
});
|
|
|
|
describe('like a burnable ERC721', function () {
|
|
beforeEach(async function () {
|
|
await this.token.mint(owner, firstTokenId);
|
|
await this.token.mint(owner, secondTokenId);
|
|
});
|
|
|
|
describe('burn', function () {
|
|
const tokenId = firstTokenId;
|
|
let logs = null;
|
|
|
|
describe('when successful', function () {
|
|
beforeEach(async function () {
|
|
const result = await this.token.burn(tokenId, { from: owner });
|
|
logs = result.logs;
|
|
});
|
|
|
|
it('burns the given token ID and adjusts the balance of the owner', async function () {
|
|
await expectRevert(
|
|
this.token.ownerOf(tokenId),
|
|
'ERC721: owner query for nonexistent token'
|
|
);
|
|
expect(await this.token.balanceOf(owner)).to.be.bignumber.equal('1');
|
|
});
|
|
|
|
it('emits a burn event', async function () {
|
|
expectEvent.inLogs(logs, 'Transfer', {
|
|
from: owner,
|
|
to: ZERO_ADDRESS,
|
|
tokenId: tokenId,
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when there is a previous approval burned', function () {
|
|
beforeEach(async function () {
|
|
await this.token.approve(approved, tokenId, { from: owner });
|
|
const result = await this.token.burn(tokenId, { from: owner });
|
|
logs = result.logs;
|
|
});
|
|
|
|
context('getApproved', function () {
|
|
it('reverts', async function () {
|
|
await expectRevert(
|
|
this.token.getApproved(tokenId), 'ERC721: approved query for nonexistent token'
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when the given token ID was not tracked by this contract', function () {
|
|
it('reverts', async function () {
|
|
await expectRevert(
|
|
this.token.burn(unknownTokenId, { from: owner }), 'ERC721: operator query for nonexistent token'
|
|
);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|