ERC1155Burnable.test.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. const { accounts, contract } = require('@openzeppelin/test-environment');
  2. const { BN, expectRevert } = require('@openzeppelin/test-helpers');
  3. const { expect } = require('chai');
  4. const ERC1155BurnableMock = contract.fromArtifact('ERC1155BurnableMock');
  5. describe('ERC1155Burnable', function () {
  6. const [ holder, operator, other ] = accounts;
  7. const uri = 'https://token.com';
  8. const tokenIds = [new BN('42'), new BN('1137')];
  9. const amounts = [new BN('3000'), new BN('9902')];
  10. beforeEach(async function () {
  11. this.token = await ERC1155BurnableMock.new(uri);
  12. await this.token.mint(holder, tokenIds[0], amounts[0], '0x');
  13. await this.token.mint(holder, tokenIds[1], amounts[1], '0x');
  14. });
  15. describe('burn', function () {
  16. it('holder can burn their tokens', async function () {
  17. await this.token.burn(holder, tokenIds[0], amounts[0].subn(1), { from: holder });
  18. expect(await this.token.balanceOf(holder, tokenIds[0])).to.be.bignumber.equal('1');
  19. });
  20. it('approved operators can burn the holder\'s tokens', async function () {
  21. await this.token.setApprovalForAll(operator, true, { from: holder });
  22. await this.token.burn(holder, tokenIds[0], amounts[0].subn(1), { from: operator });
  23. expect(await this.token.balanceOf(holder, tokenIds[0])).to.be.bignumber.equal('1');
  24. });
  25. it('unapproved accounts cannot burn the holder\'s tokens', async function () {
  26. await expectRevert(
  27. this.token.burn(holder, tokenIds[0], amounts[0].subn(1), { from: other }),
  28. 'ERC1155: caller is not owner nor approved'
  29. );
  30. });
  31. });
  32. describe('burnBatch', function () {
  33. it('holder can burn their tokens', async function () {
  34. await this.token.burnBatch(holder, tokenIds, [ amounts[0].subn(1), amounts[1].subn(2) ], { from: holder });
  35. expect(await this.token.balanceOf(holder, tokenIds[0])).to.be.bignumber.equal('1');
  36. expect(await this.token.balanceOf(holder, tokenIds[1])).to.be.bignumber.equal('2');
  37. });
  38. it('approved operators can burn the holder\'s tokens', async function () {
  39. await this.token.setApprovalForAll(operator, true, { from: holder });
  40. await this.token.burnBatch(holder, tokenIds, [ amounts[0].subn(1), amounts[1].subn(2) ], { from: operator });
  41. expect(await this.token.balanceOf(holder, tokenIds[0])).to.be.bignumber.equal('1');
  42. expect(await this.token.balanceOf(holder, tokenIds[1])).to.be.bignumber.equal('2');
  43. });
  44. it('unapproved accounts cannot burn the holder\'s tokens', async function () {
  45. await expectRevert(
  46. this.token.burnBatch(holder, tokenIds, [ amounts[0].subn(1), amounts[1].subn(2) ], { from: other }),
  47. 'ERC1155: caller is not owner nor approved'
  48. );
  49. });
  50. });
  51. });