Files
openzeppelin-contracts/test/token/ERC721/ERC721Pausable.test.js
Nicolás Venturo 5f92adc2e7 Migrate from truffle to test-environment (#2007)
* 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
2019-11-28 15:46:42 -03:00

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);
});
});