123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- const { BN, constants } = require('@openzeppelin/test-helpers');
- const { expect } = require('chai');
- const { expectRevertCustomError } = require('../../../helpers/customError');
- const ERC721Pausable = artifacts.require('$ERC721Pausable');
- contract('ERC721Pausable', function (accounts) {
- const [owner, receiver, operator] = accounts;
- const name = 'Non Fungible Token';
- const symbol = 'NFT';
- beforeEach(async function () {
- this.token = await ERC721Pausable.new(name, symbol);
- });
- context('when token is paused', function () {
- const firstTokenId = new BN(1);
- const secondTokenId = new BN(1337);
- const mockData = '0x42';
- beforeEach(async function () {
- await this.token.$_mint(owner, firstTokenId, { from: owner });
- await this.token.$_pause();
- });
- it('reverts when trying to transferFrom', async function () {
- await expectRevertCustomError(
- this.token.transferFrom(owner, receiver, firstTokenId, { from: owner }),
- 'EnforcedPause',
- [],
- );
- });
- it('reverts when trying to safeTransferFrom', async function () {
- await expectRevertCustomError(
- this.token.safeTransferFrom(owner, receiver, firstTokenId, { from: owner }),
- 'EnforcedPause',
- [],
- );
- });
- it('reverts when trying to safeTransferFrom with data', async function () {
- await expectRevertCustomError(
- this.token.methods['safeTransferFrom(address,address,uint256,bytes)'](owner, receiver, firstTokenId, mockData, {
- from: owner,
- }),
- 'EnforcedPause',
- [],
- );
- });
- it('reverts when trying to mint', async function () {
- await expectRevertCustomError(this.token.$_mint(receiver, secondTokenId), 'EnforcedPause', []);
- });
- it('reverts when trying to burn', async function () {
- await expectRevertCustomError(this.token.$_burn(firstTokenId), 'EnforcedPause', []);
- });
- describe('getApproved', function () {
- it('returns approved address', async function () {
- const approvedAccount = await this.token.getApproved(firstTokenId);
- expect(approvedAccount).to.equal(constants.ZERO_ADDRESS);
- });
- });
- describe('balanceOf', function () {
- it('returns the amount of tokens owned by the given address', async function () {
- const balance = await this.token.balanceOf(owner);
- expect(balance).to.be.bignumber.equal('1');
- });
- });
- describe('ownerOf', function () {
- it('returns the amount of tokens owned by the given address', async function () {
- const ownerOfToken = await this.token.ownerOf(firstTokenId);
- expect(ownerOfToken).to.equal(owner);
- });
- });
- describe('isApprovedForAll', function () {
- it('returns the approval of the operator', async function () {
- expect(await this.token.isApprovedForAll(owner, operator)).to.equal(false);
- });
- });
- });
- });
|