123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252 |
- const { BN, constants, expectEvent } = require('@openzeppelin/test-helpers');
- const { ZERO_ADDRESS } = constants;
- const { expect } = require('chai');
- const { expectRevertCustomError } = require('../../helpers/customError');
- const { shouldBehaveLikeERC1155 } = require('./ERC1155.behavior');
- const ERC1155Mock = artifacts.require('$ERC1155');
- contract('ERC1155', function (accounts) {
- const [operator, tokenHolder, tokenBatchHolder, ...otherAccounts] = accounts;
- const initialURI = 'https://token-cdn-domain/{id}.json';
- beforeEach(async function () {
- this.token = await ERC1155Mock.new(initialURI);
- });
- shouldBehaveLikeERC1155(otherAccounts);
- describe('internal functions', function () {
- const tokenId = new BN(1990);
- const mintAmount = new BN(9001);
- const burnAmount = new BN(3000);
- const tokenBatchIds = [new BN(2000), new BN(2010), new BN(2020)];
- const mintAmounts = [new BN(5000), new BN(10000), new BN(42195)];
- const burnAmounts = [new BN(5000), new BN(9001), new BN(195)];
- const data = '0x12345678';
- describe('_mint', function () {
- it('reverts with a zero destination address', async function () {
- await expectRevertCustomError(
- this.token.$_mint(ZERO_ADDRESS, tokenId, mintAmount, data),
- 'ERC1155InvalidReceiver',
- [ZERO_ADDRESS],
- );
- });
- context('with minted tokens', function () {
- beforeEach(async function () {
- this.receipt = await this.token.$_mint(tokenHolder, tokenId, mintAmount, data, { from: operator });
- });
- it('emits a TransferSingle event', function () {
- expectEvent(this.receipt, 'TransferSingle', {
- operator,
- from: ZERO_ADDRESS,
- to: tokenHolder,
- id: tokenId,
- value: mintAmount,
- });
- });
- it('credits the minted amount of tokens', async function () {
- expect(await this.token.balanceOf(tokenHolder, tokenId)).to.be.bignumber.equal(mintAmount);
- });
- });
- });
- describe('_mintBatch', function () {
- it('reverts with a zero destination address', async function () {
- await expectRevertCustomError(
- this.token.$_mintBatch(ZERO_ADDRESS, tokenBatchIds, mintAmounts, data),
- 'ERC1155InvalidReceiver',
- [ZERO_ADDRESS],
- );
- });
- it('reverts if length of inputs do not match', async function () {
- await expectRevertCustomError(
- this.token.$_mintBatch(tokenBatchHolder, tokenBatchIds, mintAmounts.slice(1), data),
- 'ERC1155InvalidArrayLength',
- [tokenBatchIds.length, mintAmounts.length - 1],
- );
- await expectRevertCustomError(
- this.token.$_mintBatch(tokenBatchHolder, tokenBatchIds.slice(1), mintAmounts, data),
- 'ERC1155InvalidArrayLength',
- [tokenBatchIds.length - 1, mintAmounts.length],
- );
- });
- context('with minted batch of tokens', function () {
- beforeEach(async function () {
- this.receipt = await this.token.$_mintBatch(tokenBatchHolder, tokenBatchIds, mintAmounts, data, {
- from: operator,
- });
- });
- it('emits a TransferBatch event', function () {
- expectEvent(this.receipt, 'TransferBatch', {
- operator,
- from: ZERO_ADDRESS,
- to: tokenBatchHolder,
- });
- });
- it('credits the minted batch of tokens', async function () {
- const holderBatchBalances = await this.token.balanceOfBatch(
- new Array(tokenBatchIds.length).fill(tokenBatchHolder),
- tokenBatchIds,
- );
- for (let i = 0; i < holderBatchBalances.length; i++) {
- expect(holderBatchBalances[i]).to.be.bignumber.equal(mintAmounts[i]);
- }
- });
- });
- });
- describe('_burn', function () {
- it("reverts when burning the zero account's tokens", async function () {
- await expectRevertCustomError(this.token.$_burn(ZERO_ADDRESS, tokenId, mintAmount), 'ERC1155InvalidSender', [
- ZERO_ADDRESS,
- ]);
- });
- it('reverts when burning a non-existent token id', async function () {
- await expectRevertCustomError(
- this.token.$_burn(tokenHolder, tokenId, mintAmount),
- 'ERC1155InsufficientBalance',
- [tokenHolder, 0, mintAmount, tokenId],
- );
- });
- it('reverts when burning more than available tokens', async function () {
- await this.token.$_mint(tokenHolder, tokenId, mintAmount, data, { from: operator });
- await expectRevertCustomError(
- this.token.$_burn(tokenHolder, tokenId, mintAmount.addn(1)),
- 'ERC1155InsufficientBalance',
- [tokenHolder, mintAmount, mintAmount.addn(1), tokenId],
- );
- });
- context('with minted-then-burnt tokens', function () {
- beforeEach(async function () {
- await this.token.$_mint(tokenHolder, tokenId, mintAmount, data);
- this.receipt = await this.token.$_burn(tokenHolder, tokenId, burnAmount, { from: operator });
- });
- it('emits a TransferSingle event', function () {
- expectEvent(this.receipt, 'TransferSingle', {
- operator,
- from: tokenHolder,
- to: ZERO_ADDRESS,
- id: tokenId,
- value: burnAmount,
- });
- });
- it('accounts for both minting and burning', async function () {
- expect(await this.token.balanceOf(tokenHolder, tokenId)).to.be.bignumber.equal(mintAmount.sub(burnAmount));
- });
- });
- });
- describe('_burnBatch', function () {
- it("reverts when burning the zero account's tokens", async function () {
- await expectRevertCustomError(
- this.token.$_burnBatch(ZERO_ADDRESS, tokenBatchIds, burnAmounts),
- 'ERC1155InvalidSender',
- [ZERO_ADDRESS],
- );
- });
- it('reverts if length of inputs do not match', async function () {
- await expectRevertCustomError(
- this.token.$_burnBatch(tokenBatchHolder, tokenBatchIds, burnAmounts.slice(1)),
- 'ERC1155InvalidArrayLength',
- [tokenBatchIds.length, burnAmounts.length - 1],
- );
- await expectRevertCustomError(
- this.token.$_burnBatch(tokenBatchHolder, tokenBatchIds.slice(1), burnAmounts),
- 'ERC1155InvalidArrayLength',
- [tokenBatchIds.length - 1, burnAmounts.length],
- );
- });
- it('reverts when burning a non-existent token id', async function () {
- await expectRevertCustomError(
- this.token.$_burnBatch(tokenBatchHolder, tokenBatchIds, burnAmounts),
- 'ERC1155InsufficientBalance',
- [tokenBatchHolder, 0, tokenBatchIds[0], burnAmounts[0]],
- );
- });
- context('with minted-then-burnt tokens', function () {
- beforeEach(async function () {
- await this.token.$_mintBatch(tokenBatchHolder, tokenBatchIds, mintAmounts, data);
- this.receipt = await this.token.$_burnBatch(tokenBatchHolder, tokenBatchIds, burnAmounts, { from: operator });
- });
- it('emits a TransferBatch event', function () {
- expectEvent(this.receipt, 'TransferBatch', {
- operator,
- from: tokenBatchHolder,
- to: ZERO_ADDRESS,
- // ids: tokenBatchIds,
- // values: burnAmounts,
- });
- });
- it('accounts for both minting and burning', async function () {
- const holderBatchBalances = await this.token.balanceOfBatch(
- new Array(tokenBatchIds.length).fill(tokenBatchHolder),
- tokenBatchIds,
- );
- for (let i = 0; i < holderBatchBalances.length; i++) {
- expect(holderBatchBalances[i]).to.be.bignumber.equal(mintAmounts[i].sub(burnAmounts[i]));
- }
- });
- });
- });
- });
- describe('ERC1155MetadataURI', function () {
- const firstTokenID = new BN('42');
- const secondTokenID = new BN('1337');
- it('emits no URI event in constructor', async function () {
- await expectEvent.notEmitted.inConstruction(this.token, 'URI');
- });
- it('sets the initial URI for all token types', async function () {
- expect(await this.token.uri(firstTokenID)).to.be.equal(initialURI);
- expect(await this.token.uri(secondTokenID)).to.be.equal(initialURI);
- });
- describe('_setURI', function () {
- const newURI = 'https://token-cdn-domain/{locale}/{id}.json';
- it('emits no URI event', async function () {
- const receipt = await this.token.$_setURI(newURI);
- expectEvent.notEmitted(receipt, 'URI');
- });
- it('sets the new URI for all token types', async function () {
- await this.token.$_setURI(newURI);
- expect(await this.token.uri(firstTokenID)).to.be.equal(newURI);
- expect(await this.token.uri(secondTokenID)).to.be.equal(newURI);
- });
- });
- });
- });
|