1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- const { shouldBehaveLikeERC721PausedToken } = require('./ERC721PausedToken.behavior');
- const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
- const { shouldBehaveLikePublicRole } = require('../../access/roles/PublicRole.behavior');
- const ERC721PausableMock = artifacts.require('ERC721PausableMock.sol');
- require('../../helpers/setup');
- contract('ERC721Pausable', function ([
- _,
- creator,
- owner,
- operator,
- otherPauser,
- ...accounts
- ]) {
- beforeEach(async function () {
- this.token = await ERC721PausableMock.new({ from: creator });
- });
- describe('pauser role', function () {
- beforeEach(async function () {
- this.contract = this.token;
- await this.contract.addPauser(otherPauser, { from: creator });
- });
- shouldBehaveLikePublicRole(creator, otherPauser, accounts, 'pauser');
- });
- context('when token is paused', function () {
- beforeEach(async function () {
- await this.token.pause({ from: creator });
- });
- shouldBehaveLikeERC721PausedToken(creator, accounts);
- });
- context('when token is not paused yet', function () {
- shouldBehaveLikeERC721(creator, creator, accounts);
- });
- context('when token is paused and then unpaused', function () {
- beforeEach(async function () {
- await this.token.pause({ from: creator });
- await this.token.unpause({ from: creator });
- });
- shouldBehaveLikeERC721(creator, creator, accounts);
- });
- });
|