123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- import { expect } from "chai"
- import { ethers } from "hardhat"
- import { loadFixture } from "@nomicfoundation/hardhat-toolbox/network-helpers"
- describe("BasicERC1155", () => {
- const setupFixture = async () => {
- const signers = await ethers.getSigners()
- const name = "ProtoToken"
- const symbol = "PT"
- const baseURI = "ipfs://base-uri/"
- const contractURI = "ipfs://contract-uri"
- const owner = signers[0].address
- const BasicERC1155 = await ethers.getContractFactory("BasicERC1155")
- const contract = await BasicERC1155.deploy(name, symbol, baseURI, contractURI, owner, {
- from: owner,
- })
- return {
- contract,
- contractAddress: await contract.getAddress(),
- deployer: owner,
- accounts: await ethers.getSigners(),
- contractConstructor: {
- name,
- symbol,
- baseURI,
- contractURI,
- owner,
- },
- }
- }
- it("Should Return Valid Contract Configurations Passed In Constructor", async () => {
- const { contractConstructor, contract } = await loadFixture(setupFixture)
- expect(await contract.name()).to.equal(contractConstructor.name)
- expect(await contract.symbol()).to.equal(contractConstructor.symbol)
- expect(await contract.contractURI()).to.equal(contractConstructor.contractURI)
- expect(await contract.owner()).to.equal(contractConstructor.owner)
- })
- describe("Minting Functionality", () => {
- it("Should Increase Supply When Minting", async () => {
- const { contract, deployer } = await loadFixture(setupFixture)
- expect(await contract["totalSupply(uint256)"](1)).to.equal(0)
- expect(await contract["totalSupply(uint256)"](2)).to.equal(0)
- await contract.mintBatch(deployer, [1, 2], [2000, 4000])
- expect(await contract["totalSupply(uint256)"](1)).to.equal(2000)
- expect(await contract["totalSupply(uint256)"](2)).to.equal(4000)
- expect(await contract.balanceOf(deployer, 1)).to.equal(2000)
- expect(await contract.balanceOf(deployer, 2)).to.equal(4000)
- })
- it("Should Allow Minting Only to Contract Owner - mint", async () => {
- const { contract, accounts } = await loadFixture(setupFixture)
- await expect(contract.connect(accounts[1]).mint(accounts[1].address, 1, 1000))
- .to.be.revertedWithCustomError(contract, "OwnableUnauthorizedAccount")
- .withArgs(await accounts[1].getAddress())
- })
- it("Should Allow Minting Only to Contract Owner - mintBatch", async () => {
- const { contract, accounts } = await loadFixture(setupFixture)
- await expect(contract.connect(accounts[1]).mintBatch(accounts[1].address, [1], [1000]))
- .to.be.revertedWithCustomError(contract, "OwnableUnauthorizedAccount")
- .withArgs(await accounts[1].getAddress())
- })
- })
- describe("Contract And Token Metadata", () => {
- it("Should Return Correct Token URI", async () => {
- const { contract, contractConstructor } = await loadFixture(setupFixture)
- expect(await contract.uri(1)).to.equal(`${contractConstructor.baseURI}1.json`)
- })
- it("Should Return Correct Contract URI", async () => {
- const { contract, contractConstructor } = await loadFixture(setupFixture)
- expect(await contract.contractURI()).to.equal(contractConstructor.contractURI)
- })
- })
- })
|