* Sketch * Migrate all tests to test-env * Finish migration to test-env * Add config * Work on GSN tests * Migrate to newer test-env version and loader syntax * Add GSN setup * Finish test-env migration * Setup coverage using test-env * Migrate to npm package * Fix package.json * Add compile step to CI * Add comment on coverage setup * Remove dependency on @truffle/contract * Fix package-lock merge * Fix linter errors * Upgrade test-environment, depend locally on ganche-coverage * Improve coverage script * Improve sign.js API * Move accounts destructuring to describe block * Switch to prebuilt ethereumjs-vm package * Upgrade test-enviroment version * use workspace in circleci config * remove unnecessary npx
47 lines
1.5 KiB
JavaScript
47 lines
1.5 KiB
JavaScript
const { accounts, contract } = require('@openzeppelin/test-environment');
|
|
|
|
require('@openzeppelin/test-helpers');
|
|
const { shouldBehaveLikeERC721PausedToken } = require('./ERC721PausedToken.behavior');
|
|
const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
|
|
const { shouldBehaveLikePublicRole } = require('../../behaviors/access/roles/PublicRole.behavior');
|
|
|
|
const ERC721PausableMock = contract.fromArtifact('ERC721PausableMock');
|
|
|
|
describe('ERC721Pausable', function () {
|
|
const [ creator, otherPauser, ...otherAccounts ] = 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, otherAccounts, 'pauser');
|
|
});
|
|
|
|
context('when token is paused', function () {
|
|
beforeEach(async function () {
|
|
await this.token.pause({ from: creator });
|
|
});
|
|
|
|
shouldBehaveLikeERC721PausedToken(creator, otherAccounts);
|
|
});
|
|
|
|
context('when token is not paused yet', function () {
|
|
shouldBehaveLikeERC721(creator, creator, otherAccounts);
|
|
});
|
|
|
|
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, otherAccounts);
|
|
});
|
|
});
|