Improved ERC721 granularity (#1304)
* Split enumerable and metadata implementations. * Renamed ERC721Basic to ERC721, and ERC721 to ERC721Full. * Fixed linter errors.
This commit is contained in:
committed by
Francisco Giordano
parent
bafdcf0701
commit
4b33eaefa2
@ -11,7 +11,7 @@ require('chai')
|
||||
.use(require('chai-bignumber')(BigNumber))
|
||||
.should();
|
||||
|
||||
function shouldBehaveLikeERC721Basic (
|
||||
function shouldBehaveLikeERC721 (
|
||||
creator,
|
||||
minter,
|
||||
[owner, approved, anotherApproved, operator, anyone]
|
||||
@ -22,7 +22,7 @@ function shouldBehaveLikeERC721Basic (
|
||||
const ZERO_ADDRESS = '0x0000000000000000000000000000000000000000';
|
||||
const RECEIVER_MAGIC_VALUE = '0x150b7a02';
|
||||
|
||||
describe('like an ERC721Basic', function () {
|
||||
describe('like an ERC721', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.mint(owner, firstTokenId, { from: minter });
|
||||
await this.token.mint(owner, secondTokenId, { from: minter });
|
||||
@ -520,5 +520,5 @@ function shouldBehaveLikeERC721Basic (
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
shouldBehaveLikeERC721Basic,
|
||||
shouldBehaveLikeERC721,
|
||||
};
|
||||
@ -1,8 +1,4 @@
|
||||
const { assertRevert } = require('../../helpers/assertRevert');
|
||||
const { shouldBehaveLikeERC721Basic } = require('./ERC721Basic.behavior');
|
||||
const { shouldBehaveLikeMintAndBurnERC721 } = require('./ERC721MintBurn.behavior');
|
||||
const { shouldSupportInterfaces } = require('../../introspection/SupportsInterface.behavior');
|
||||
const _ = require('lodash');
|
||||
const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
|
||||
|
||||
const BigNumber = web3.BigNumber;
|
||||
const ERC721 = artifacts.require('ERC721Mock.sol');
|
||||
@ -11,218 +7,10 @@ require('chai')
|
||||
.use(require('chai-bignumber')(BigNumber))
|
||||
.should();
|
||||
|
||||
contract('ERC721', function ([
|
||||
creator,
|
||||
...accounts
|
||||
]) {
|
||||
const name = 'Non Fungible Token';
|
||||
const symbol = 'NFT';
|
||||
const firstTokenId = 100;
|
||||
const secondTokenId = 200;
|
||||
const thirdTokenId = 300;
|
||||
const nonExistentTokenId = 999;
|
||||
|
||||
const minter = creator;
|
||||
|
||||
const [
|
||||
owner,
|
||||
newOwner,
|
||||
another,
|
||||
anyone,
|
||||
] = accounts;
|
||||
|
||||
contract('ERC721', function ([_, creator, ...accounts]) {
|
||||
beforeEach(async function () {
|
||||
this.token = await ERC721.new(name, symbol, { from: creator });
|
||||
this.token = await ERC721.new({ from: creator });
|
||||
});
|
||||
|
||||
describe('like a full ERC721', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.mint(owner, firstTokenId, { from: minter });
|
||||
await this.token.mint(owner, secondTokenId, { from: minter });
|
||||
});
|
||||
|
||||
describe('mint', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.mint(newOwner, thirdTokenId, { from: minter });
|
||||
});
|
||||
|
||||
it('adjusts owner tokens by index', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(newOwner, 0)).toNumber().should.be.equal(thirdTokenId);
|
||||
});
|
||||
|
||||
it('adjusts all tokens list', async function () {
|
||||
(await this.token.tokenByIndex(2)).toNumber().should.be.equal(thirdTokenId);
|
||||
});
|
||||
});
|
||||
|
||||
describe('burn', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.burn(firstTokenId, { from: owner });
|
||||
});
|
||||
|
||||
it('removes that token from the token list of the owner', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(owner, 0)).toNumber().should.be.equal(secondTokenId);
|
||||
});
|
||||
|
||||
it('adjusts all tokens list', async function () {
|
||||
(await this.token.tokenByIndex(0)).toNumber().should.be.equal(secondTokenId);
|
||||
});
|
||||
|
||||
it('burns all tokens', async function () {
|
||||
await this.token.burn(secondTokenId, { from: owner });
|
||||
(await this.token.totalSupply()).toNumber().should.be.equal(0);
|
||||
await assertRevert(this.token.tokenByIndex(0));
|
||||
});
|
||||
});
|
||||
|
||||
describe('removeTokenFrom', function () {
|
||||
it('reverts if the correct owner is not passed', async function () {
|
||||
await assertRevert(
|
||||
this.token.removeTokenFrom(anyone, firstTokenId, { from: owner })
|
||||
);
|
||||
});
|
||||
|
||||
context('once removed', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.removeTokenFrom(owner, firstTokenId, { from: owner });
|
||||
});
|
||||
|
||||
it('has been removed', async function () {
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(owner, 1));
|
||||
});
|
||||
|
||||
it('adjusts token list', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(owner, 0)).toNumber().should.be.equal(secondTokenId);
|
||||
});
|
||||
|
||||
it('adjusts owner count', async function () {
|
||||
(await this.token.balanceOf(owner)).toNumber().should.be.equal(1);
|
||||
});
|
||||
|
||||
it('does not adjust supply', async function () {
|
||||
(await this.token.totalSupply()).toNumber().should.be.equal(2);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('metadata', function () {
|
||||
const sampleUri = 'mock://mytoken';
|
||||
|
||||
it('has a name', async function () {
|
||||
(await this.token.name()).should.be.equal(name);
|
||||
});
|
||||
|
||||
it('has a symbol', async function () {
|
||||
(await this.token.symbol()).should.be.equal(symbol);
|
||||
});
|
||||
|
||||
it('sets and returns metadata for a token id', async function () {
|
||||
await this.token.setTokenURI(firstTokenId, sampleUri);
|
||||
(await this.token.tokenURI(firstTokenId)).should.be.equal(sampleUri);
|
||||
});
|
||||
|
||||
it('reverts when setting metadata for non existent token id', async function () {
|
||||
await assertRevert(this.token.setTokenURI(nonExistentTokenId, sampleUri));
|
||||
});
|
||||
|
||||
it('can burn token with metadata', async function () {
|
||||
await this.token.setTokenURI(firstTokenId, sampleUri);
|
||||
await this.token.burn(firstTokenId, { from: owner });
|
||||
(await this.token.exists(firstTokenId)).should.equal(false);
|
||||
});
|
||||
|
||||
it('returns empty metadata for token', async function () {
|
||||
(await this.token.tokenURI(firstTokenId)).should.be.equal('');
|
||||
});
|
||||
|
||||
it('reverts when querying metadata for non existent token id', async function () {
|
||||
await assertRevert(this.token.tokenURI(nonExistentTokenId));
|
||||
});
|
||||
});
|
||||
|
||||
describe('totalSupply', function () {
|
||||
it('returns total token supply', async function () {
|
||||
(await this.token.totalSupply()).should.be.bignumber.equal(2);
|
||||
});
|
||||
});
|
||||
|
||||
describe('tokenOfOwnerByIndex', function () {
|
||||
describe('when the given index is lower than the amount of tokens owned by the given address', function () {
|
||||
it('returns the token ID placed at the given index', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(owner, 0)).should.be.bignumber.equal(firstTokenId);
|
||||
});
|
||||
});
|
||||
|
||||
describe('when the index is greater than or equal to the total tokens owned by the given address', function () {
|
||||
it('reverts', async function () {
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(owner, 2));
|
||||
});
|
||||
});
|
||||
|
||||
describe('when the given address does not own any token', function () {
|
||||
it('reverts', async function () {
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(another, 0));
|
||||
});
|
||||
});
|
||||
|
||||
describe('after transferring all tokens to another user', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.transferFrom(owner, another, firstTokenId, { from: owner });
|
||||
await this.token.transferFrom(owner, another, secondTokenId, { from: owner });
|
||||
});
|
||||
|
||||
it('returns correct token IDs for target', async function () {
|
||||
(await this.token.balanceOf(another)).toNumber().should.be.equal(2);
|
||||
const tokensListed = await Promise.all(_.range(2).map(i => this.token.tokenOfOwnerByIndex(another, i)));
|
||||
tokensListed.map(t => t.toNumber()).should.have.members([firstTokenId, secondTokenId]);
|
||||
});
|
||||
|
||||
it('returns empty collection for original owner', async function () {
|
||||
(await this.token.balanceOf(owner)).toNumber().should.be.equal(0);
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(owner, 0));
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('tokenByIndex', function () {
|
||||
it('should return all tokens', async function () {
|
||||
const tokensListed = await Promise.all(_.range(2).map(i => this.token.tokenByIndex(i)));
|
||||
tokensListed.map(t => t.toNumber()).should.have.members([firstTokenId, secondTokenId]);
|
||||
});
|
||||
|
||||
it('should revert if index is greater than supply', async function () {
|
||||
await assertRevert(this.token.tokenByIndex(2));
|
||||
});
|
||||
|
||||
[firstTokenId, secondTokenId].forEach(function (tokenId) {
|
||||
it(`should return all tokens after burning token ${tokenId} and minting new tokens`, async function () {
|
||||
const newTokenId = 300;
|
||||
const anotherNewTokenId = 400;
|
||||
|
||||
await this.token.burn(tokenId, { from: owner });
|
||||
await this.token.mint(newOwner, newTokenId, { from: minter });
|
||||
await this.token.mint(newOwner, anotherNewTokenId, { from: minter });
|
||||
|
||||
(await this.token.totalSupply()).toNumber().should.be.equal(3);
|
||||
|
||||
const tokensListed = await Promise.all(_.range(3).map(i => this.token.tokenByIndex(i)));
|
||||
const expectedTokens = _.filter(
|
||||
[firstTokenId, secondTokenId, newTokenId, anotherNewTokenId],
|
||||
x => (x !== tokenId)
|
||||
);
|
||||
tokensListed.map(t => t.toNumber()).should.have.members(expectedTokens);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
shouldBehaveLikeERC721Basic(creator, minter, accounts);
|
||||
shouldBehaveLikeMintAndBurnERC721(creator, minter, accounts);
|
||||
|
||||
shouldSupportInterfaces([
|
||||
'ERC165',
|
||||
'ERC721',
|
||||
'ERC721Enumerable',
|
||||
'ERC721Metadata',
|
||||
]);
|
||||
shouldBehaveLikeERC721(creator, creator, accounts);
|
||||
});
|
||||
|
||||
@ -1,16 +0,0 @@
|
||||
const { shouldBehaveLikeERC721Basic } = require('./ERC721Basic.behavior');
|
||||
|
||||
const BigNumber = web3.BigNumber;
|
||||
const ERC721Basic = artifacts.require('ERC721BasicMock.sol');
|
||||
|
||||
require('chai')
|
||||
.use(require('chai-bignumber')(BigNumber))
|
||||
.should();
|
||||
|
||||
contract('ERC721Basic', function ([_, creator, ...accounts]) {
|
||||
beforeEach(async function () {
|
||||
this.token = await ERC721Basic.new({ from: creator });
|
||||
});
|
||||
|
||||
shouldBehaveLikeERC721Basic(creator, creator, accounts);
|
||||
});
|
||||
@ -1,4 +1,4 @@
|
||||
const { shouldBehaveLikeERC721Basic } = require('./ERC721Basic.behavior');
|
||||
const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
|
||||
const {
|
||||
shouldBehaveLikeMintAndBurnERC721,
|
||||
} = require('./ERC721MintBurn.behavior');
|
||||
@ -17,6 +17,6 @@ contract('ERC721Burnable', function ([_, creator, ...accounts]) {
|
||||
this.token = await ERC721Burnable.new({ from: creator });
|
||||
});
|
||||
|
||||
shouldBehaveLikeERC721Basic(creator, minter, accounts);
|
||||
shouldBehaveLikeERC721(creator, minter, accounts);
|
||||
shouldBehaveLikeMintAndBurnERC721(creator, minter, accounts);
|
||||
});
|
||||
|
||||
228
test/token/ERC721/ERC721Full.test.js
Normal file
228
test/token/ERC721/ERC721Full.test.js
Normal file
@ -0,0 +1,228 @@
|
||||
const { assertRevert } = require('../../helpers/assertRevert');
|
||||
const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
|
||||
const { shouldBehaveLikeMintAndBurnERC721 } = require('./ERC721MintBurn.behavior');
|
||||
const { shouldSupportInterfaces } = require('../../introspection/SupportsInterface.behavior');
|
||||
const _ = require('lodash');
|
||||
|
||||
const BigNumber = web3.BigNumber;
|
||||
const ERC721FullMock = artifacts.require('ERC721FullMock.sol');
|
||||
|
||||
require('chai')
|
||||
.use(require('chai-bignumber')(BigNumber))
|
||||
.should();
|
||||
|
||||
contract('ERC721Full', function ([
|
||||
creator,
|
||||
...accounts
|
||||
]) {
|
||||
const name = 'Non Fungible Token';
|
||||
const symbol = 'NFT';
|
||||
const firstTokenId = 100;
|
||||
const secondTokenId = 200;
|
||||
const thirdTokenId = 300;
|
||||
const nonExistentTokenId = 999;
|
||||
|
||||
const minter = creator;
|
||||
|
||||
const [
|
||||
owner,
|
||||
newOwner,
|
||||
another,
|
||||
anyone,
|
||||
] = accounts;
|
||||
|
||||
beforeEach(async function () {
|
||||
this.token = await ERC721FullMock.new(name, symbol, { from: creator });
|
||||
});
|
||||
|
||||
describe('like a full ERC721', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.mint(owner, firstTokenId, { from: minter });
|
||||
await this.token.mint(owner, secondTokenId, { from: minter });
|
||||
});
|
||||
|
||||
describe('mint', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.mint(newOwner, thirdTokenId, { from: minter });
|
||||
});
|
||||
|
||||
it('adjusts owner tokens by index', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(newOwner, 0)).toNumber().should.be.equal(thirdTokenId);
|
||||
});
|
||||
|
||||
it('adjusts all tokens list', async function () {
|
||||
(await this.token.tokenByIndex(2)).toNumber().should.be.equal(thirdTokenId);
|
||||
});
|
||||
});
|
||||
|
||||
describe('burn', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.burn(firstTokenId, { from: owner });
|
||||
});
|
||||
|
||||
it('removes that token from the token list of the owner', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(owner, 0)).toNumber().should.be.equal(secondTokenId);
|
||||
});
|
||||
|
||||
it('adjusts all tokens list', async function () {
|
||||
(await this.token.tokenByIndex(0)).toNumber().should.be.equal(secondTokenId);
|
||||
});
|
||||
|
||||
it('burns all tokens', async function () {
|
||||
await this.token.burn(secondTokenId, { from: owner });
|
||||
(await this.token.totalSupply()).toNumber().should.be.equal(0);
|
||||
await assertRevert(this.token.tokenByIndex(0));
|
||||
});
|
||||
});
|
||||
|
||||
describe('removeTokenFrom', function () {
|
||||
it('reverts if the correct owner is not passed', async function () {
|
||||
await assertRevert(
|
||||
this.token.removeTokenFrom(anyone, firstTokenId, { from: owner })
|
||||
);
|
||||
});
|
||||
|
||||
context('once removed', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.removeTokenFrom(owner, firstTokenId, { from: owner });
|
||||
});
|
||||
|
||||
it('has been removed', async function () {
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(owner, 1));
|
||||
});
|
||||
|
||||
it('adjusts token list', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(owner, 0)).toNumber().should.be.equal(secondTokenId);
|
||||
});
|
||||
|
||||
it('adjusts owner count', async function () {
|
||||
(await this.token.balanceOf(owner)).toNumber().should.be.equal(1);
|
||||
});
|
||||
|
||||
it('does not adjust supply', async function () {
|
||||
(await this.token.totalSupply()).toNumber().should.be.equal(2);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('metadata', function () {
|
||||
const sampleUri = 'mock://mytoken';
|
||||
|
||||
it('has a name', async function () {
|
||||
(await this.token.name()).should.be.equal(name);
|
||||
});
|
||||
|
||||
it('has a symbol', async function () {
|
||||
(await this.token.symbol()).should.be.equal(symbol);
|
||||
});
|
||||
|
||||
it('sets and returns metadata for a token id', async function () {
|
||||
await this.token.setTokenURI(firstTokenId, sampleUri);
|
||||
(await this.token.tokenURI(firstTokenId)).should.be.equal(sampleUri);
|
||||
});
|
||||
|
||||
it('reverts when setting metadata for non existent token id', async function () {
|
||||
await assertRevert(this.token.setTokenURI(nonExistentTokenId, sampleUri));
|
||||
});
|
||||
|
||||
it('can burn token with metadata', async function () {
|
||||
await this.token.setTokenURI(firstTokenId, sampleUri);
|
||||
await this.token.burn(firstTokenId, { from: owner });
|
||||
(await this.token.exists(firstTokenId)).should.equal(false);
|
||||
});
|
||||
|
||||
it('returns empty metadata for token', async function () {
|
||||
(await this.token.tokenURI(firstTokenId)).should.be.equal('');
|
||||
});
|
||||
|
||||
it('reverts when querying metadata for non existent token id', async function () {
|
||||
await assertRevert(this.token.tokenURI(nonExistentTokenId));
|
||||
});
|
||||
});
|
||||
|
||||
describe('totalSupply', function () {
|
||||
it('returns total token supply', async function () {
|
||||
(await this.token.totalSupply()).should.be.bignumber.equal(2);
|
||||
});
|
||||
});
|
||||
|
||||
describe('tokenOfOwnerByIndex', function () {
|
||||
describe('when the given index is lower than the amount of tokens owned by the given address', function () {
|
||||
it('returns the token ID placed at the given index', async function () {
|
||||
(await this.token.tokenOfOwnerByIndex(owner, 0)).should.be.bignumber.equal(firstTokenId);
|
||||
});
|
||||
});
|
||||
|
||||
describe('when the index is greater than or equal to the total tokens owned by the given address', function () {
|
||||
it('reverts', async function () {
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(owner, 2));
|
||||
});
|
||||
});
|
||||
|
||||
describe('when the given address does not own any token', function () {
|
||||
it('reverts', async function () {
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(another, 0));
|
||||
});
|
||||
});
|
||||
|
||||
describe('after transferring all tokens to another user', function () {
|
||||
beforeEach(async function () {
|
||||
await this.token.transferFrom(owner, another, firstTokenId, { from: owner });
|
||||
await this.token.transferFrom(owner, another, secondTokenId, { from: owner });
|
||||
});
|
||||
|
||||
it('returns correct token IDs for target', async function () {
|
||||
(await this.token.balanceOf(another)).toNumber().should.be.equal(2);
|
||||
const tokensListed = await Promise.all(_.range(2).map(i => this.token.tokenOfOwnerByIndex(another, i)));
|
||||
tokensListed.map(t => t.toNumber()).should.have.members([firstTokenId, secondTokenId]);
|
||||
});
|
||||
|
||||
it('returns empty collection for original owner', async function () {
|
||||
(await this.token.balanceOf(owner)).toNumber().should.be.equal(0);
|
||||
await assertRevert(this.token.tokenOfOwnerByIndex(owner, 0));
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('tokenByIndex', function () {
|
||||
it('should return all tokens', async function () {
|
||||
const tokensListed = await Promise.all(_.range(2).map(i => this.token.tokenByIndex(i)));
|
||||
tokensListed.map(t => t.toNumber()).should.have.members([firstTokenId, secondTokenId]);
|
||||
});
|
||||
|
||||
it('should revert if index is greater than supply', async function () {
|
||||
await assertRevert(this.token.tokenByIndex(2));
|
||||
});
|
||||
|
||||
[firstTokenId, secondTokenId].forEach(function (tokenId) {
|
||||
it(`should return all tokens after burning token ${tokenId} and minting new tokens`, async function () {
|
||||
const newTokenId = 300;
|
||||
const anotherNewTokenId = 400;
|
||||
|
||||
await this.token.burn(tokenId, { from: owner });
|
||||
await this.token.mint(newOwner, newTokenId, { from: minter });
|
||||
await this.token.mint(newOwner, anotherNewTokenId, { from: minter });
|
||||
|
||||
(await this.token.totalSupply()).toNumber().should.be.equal(3);
|
||||
|
||||
const tokensListed = await Promise.all(_.range(3).map(i => this.token.tokenByIndex(i)));
|
||||
const expectedTokens = _.filter(
|
||||
[firstTokenId, secondTokenId, newTokenId, anotherNewTokenId],
|
||||
x => (x !== tokenId)
|
||||
);
|
||||
tokensListed.map(t => t.toNumber()).should.have.members(expectedTokens);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
shouldBehaveLikeERC721(creator, minter, accounts);
|
||||
shouldBehaveLikeMintAndBurnERC721(creator, minter, accounts);
|
||||
|
||||
shouldSupportInterfaces([
|
||||
'ERC165',
|
||||
'ERC721',
|
||||
'ERC721Enumerable',
|
||||
'ERC721Metadata',
|
||||
]);
|
||||
});
|
||||
@ -1,4 +1,4 @@
|
||||
const { shouldBehaveLikeERC721Basic } = require('./ERC721Basic.behavior');
|
||||
const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
|
||||
const {
|
||||
shouldBehaveLikeMintAndBurnERC721,
|
||||
} = require('./ERC721MintBurn.behavior');
|
||||
@ -19,6 +19,6 @@ contract('ERC721Mintable', function ([_, creator, ...accounts]) {
|
||||
});
|
||||
});
|
||||
|
||||
shouldBehaveLikeERC721Basic(creator, minter, accounts);
|
||||
shouldBehaveLikeERC721(creator, minter, accounts);
|
||||
shouldBehaveLikeMintAndBurnERC721(creator, minter, accounts);
|
||||
});
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
const { shouldBehaveLikeERC721PausedToken } = require('./ERC721PausedToken.behavior');
|
||||
const { shouldBehaveLikeERC721Basic } = require('./ERC721Basic.behavior');
|
||||
const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
|
||||
const { shouldBehaveLikePublicRole } = require('../../access/roles/PublicRole.behavior');
|
||||
|
||||
const BigNumber = web3.BigNumber;
|
||||
@ -39,7 +39,7 @@ contract('ERC721Pausable', function ([
|
||||
});
|
||||
|
||||
context('when token is not paused yet', function () {
|
||||
shouldBehaveLikeERC721Basic(creator, creator, accounts);
|
||||
shouldBehaveLikeERC721(creator, creator, accounts);
|
||||
});
|
||||
|
||||
context('when token is paused and then unpaused', function () {
|
||||
@ -48,6 +48,6 @@ contract('ERC721Pausable', function ([
|
||||
await this.token.unpause({ from: creator });
|
||||
});
|
||||
|
||||
shouldBehaveLikeERC721Basic(creator, creator, accounts);
|
||||
shouldBehaveLikeERC721(creator, creator, accounts);
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user