ERC721Pausable.test.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. const { shouldBehaveLikeERC721PausedToken } = require('./ERC721PausedToken.behavior');
  2. const { shouldBehaveLikeERC721 } = require('./ERC721.behavior');
  3. const { shouldBehaveLikePublicRole } = require('../../access/roles/PublicRole.behavior');
  4. const ERC721PausableMock = artifacts.require('ERC721PausableMock.sol');
  5. require('../../helpers/setup');
  6. contract('ERC721Pausable', function ([
  7. _,
  8. creator,
  9. owner,
  10. operator,
  11. otherPauser,
  12. ...accounts
  13. ]) {
  14. beforeEach(async function () {
  15. this.token = await ERC721PausableMock.new({ from: creator });
  16. });
  17. describe('pauser role', function () {
  18. beforeEach(async function () {
  19. this.contract = this.token;
  20. await this.contract.addPauser(otherPauser, { from: creator });
  21. });
  22. shouldBehaveLikePublicRole(creator, otherPauser, accounts, 'pauser');
  23. });
  24. context('when token is paused', function () {
  25. beforeEach(async function () {
  26. await this.token.pause({ from: creator });
  27. });
  28. shouldBehaveLikeERC721PausedToken(creator, accounts);
  29. });
  30. context('when token is not paused yet', function () {
  31. shouldBehaveLikeERC721(creator, creator, accounts);
  32. });
  33. context('when token is paused and then unpaused', function () {
  34. beforeEach(async function () {
  35. await this.token.pause({ from: creator });
  36. await this.token.unpause({ from: creator });
  37. });
  38. shouldBehaveLikeERC721(creator, creator, accounts);
  39. });
  40. });