ERC1155Burnable.test.js 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. const { BN } = require('@openzeppelin/test-helpers');
  2. const { expect } = require('chai');
  3. const { expectRevertCustomError } = require('../../../helpers/customError');
  4. const ERC1155Burnable = artifacts.require('$ERC1155Burnable');
  5. contract('ERC1155Burnable', function (accounts) {
  6. const [holder, operator, other] = accounts;
  7. const uri = 'https://token.com';
  8. const tokenIds = [new BN('42'), new BN('1137')];
  9. const values = [new BN('3000'), new BN('9902')];
  10. beforeEach(async function () {
  11. this.token = await ERC1155Burnable.new(uri);
  12. await this.token.$_mint(holder, tokenIds[0], values[0], '0x');
  13. await this.token.$_mint(holder, tokenIds[1], values[1], '0x');
  14. });
  15. describe('burn', function () {
  16. it('holder can burn their tokens', async function () {
  17. await this.token.burn(holder, tokenIds[0], values[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], values[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 expectRevertCustomError(
  27. this.token.burn(holder, tokenIds[0], values[0].subn(1), { from: other }),
  28. 'ERC1155MissingApprovalForAll',
  29. [other, holder],
  30. );
  31. });
  32. });
  33. describe('burnBatch', function () {
  34. it('holder can burn their tokens', async function () {
  35. await this.token.burnBatch(holder, tokenIds, [values[0].subn(1), values[1].subn(2)], { from: holder });
  36. expect(await this.token.balanceOf(holder, tokenIds[0])).to.be.bignumber.equal('1');
  37. expect(await this.token.balanceOf(holder, tokenIds[1])).to.be.bignumber.equal('2');
  38. });
  39. it("approved operators can burn the holder's tokens", async function () {
  40. await this.token.setApprovalForAll(operator, true, { from: holder });
  41. await this.token.burnBatch(holder, tokenIds, [values[0].subn(1), values[1].subn(2)], { from: operator });
  42. expect(await this.token.balanceOf(holder, tokenIds[0])).to.be.bignumber.equal('1');
  43. expect(await this.token.balanceOf(holder, tokenIds[1])).to.be.bignumber.equal('2');
  44. });
  45. it("unapproved accounts cannot burn the holder's tokens", async function () {
  46. await expectRevertCustomError(
  47. this.token.burnBatch(holder, tokenIds, [values[0].subn(1), values[1].subn(2)], { from: other }),
  48. 'ERC1155MissingApprovalForAll',
  49. [other, holder],
  50. );
  51. });
  52. });
  53. });