Compare commits

...

3 Commits

Author SHA1 Message Date
David E. Perez Negron R. 7df29a2461 Adding format with fmt, env example and deploy.sh script 2024-04-24 20:10:02 -06:00
David E. Perez Negron R. 3e448767d9 Fixing script and adding auto minting to airdrops accounts 2024-04-24 20:05:27 -06:00
David E. Perez Negron R. 065607af5d Update with .env and Cleanup tests 2024-04-24 18:21:13 -06:00
7 changed files with 184 additions and 189 deletions

5
deploy.sh Executable file
View File

@ -0,0 +1,5 @@
#!/bin/sh
. ./.env
forge script script/DCO2s.s.sol:DCO2sScript \
--fork-url $PROVIDER_URL \
--private-key $PK0 --broadcast

73
env.example Normal file
View File

@ -0,0 +1,73 @@
# Deploy
PROVIDER_URL="HTTP://127.0.0.1:8545"
PRIVATE_KEY="0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80"
# ERC721 Constructor
DEFAULT_ADMIN="0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266"
MINTER="0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266"
NAME="DCO2s"
SYMBOL="DCO2"
## BaseURI (IPFS Gateway)
BASE_URI="https://gateway.decentralizedscience.org/ipfs/"
# Airdrop addresses
airdrops="0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266
0x70997970C51812dc3A010C7d01b50e0d17dc79C8
0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC
0x90F79bf6EB2c4f870365E785982E1f101E93b906
0x15d34AAf54267DB7D7c367839AAf71A00a2C6A65
0x9965507D1a55bcC2695C58ba16FB37d819B0A4dc
0x976EA74026E726554dB657fA54763abd0C3a0aa9
0x14dC79964da2C08b23698B3D3cc7Ca32193d9955
0x23618e81E3f5cdF7f54C3d65f7FBc0aBf5B21E8f
0xa0Ee7A142d267C1f36714E4a8F75612F20a79720"
# Dapps Testing URIs
nfts="bafkreibc6p3y36yjmeqqnttqfrpb2yttxa6aonoywxwdxl7nqym4jj3jwa
bafkreidcf5baqb5wevs6avyd7dtd3j7rzrq65uyqasj4dbkcy6na4ig3ay
bafkreibffiehtv4ntajq5vjwpl7q44i6cjbg54lm5hkoa665ue2taspiyu
bafkreifqztiwfutjik4wfs3gyfdyrff7cugi4mcctluunrrbp5cgareisq
bafkreiglyvpxwrxdvruit3oiw2lvkxqqxn7ojquw4gl7ck6szewz6t6cam
bafkreiakd4xtuw3toe4wnez2ndmdadqv3oszaoffoha4tw2hqr3sjnsmge
bafkreigx2isd63yflf6toeg7nfqw33hf6vvllcxfnzn7ymd7u4okflivbi
bafkreidrsjlcajbz35crgs6dpog6ophcochrgrrqgejxfye4m6lbw5mdde
bafkreihwi7xoak3p3mmofdln4pc4wqkkbdwyyz2yxbpfvpzvvxa2ogbaxi
bafkreiclhcy3n5iq3ka2jwxhvedpdewonwoujgu77y7rgnkddheioemcsi
bafkreic3vdshhst65qtzkwfbqzfpmuqbsyizxguarixobrp3scwaiq5jre
bafkreifv5xyis2kuveyfoc662zxeol2zdyiue4h3sznosef7ihrsmjexwm
bafkreifqyk6255h2ppobog33fzifsosbcnn2tanqi3ezjcwis6gya4sfoi
bafkreigend4j42oanbjxltwuyizmufdhqbngf6fbe5hgnlxs3yhzgpvay4
bafkreiextgvmtg23rx3lq2s6psebqln6ojlgosc544jch72baq3yt3dryu
bafkreihlkfwt5ntpnwf3c37d4lsf4y6czxojyffqet5ujvzw374x7ainoi
bafkreievuhvdru7p3lxht3of67xdri6urrrsjxr2e6rzulwg2574ye3dji"
# Anvil Accounts
ACC0="0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266"
ACC1="0x70997970C51812dc3A010C7d01b50e0d17dc79C8"
ACC2="0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC"
ACC3="0x90F79bf6EB2c4f870365E785982E1f101E93b906"
ACC4="0x15d34AAf54267DB7D7c367839AAf71A00a2C6A65"
ACC5="0x9965507D1a55bcC2695C58ba16FB37d819B0A4dc"
ACC6="0x976EA74026E726554dB657fA54763abd0C3a0aa9"
ACC7="0x14dC79964da2C08b23698B3D3cc7Ca32193d9955"
ACC8="0x23618e81E3f5cdF7f54C3d65f7FBc0aBf5B21E8f"
ACC9="0xa0Ee7A142d267C1f36714E4a8F75612F20a79720"
# Anvil Private Keys
PK0="0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80"
PK1="0x59c6995e998f97a5a0044966f0945389dc9e86dae88c7a8412f4603b6b78690d"
PK2="0x5de4111afa1a4b94908f83103eb1f1706367c2e68ca870fc3fb9a804cdab365a"
PK3="0x7c852118294e51e653712a81e05800f419141751be58f605c371e15141b007a6"
PK4="0x47e179ec197488593b187f80a00eb0da91f1b9d0b13f8733639f19c30a34926a"
PK5="0x8b3a350cf5c34c9194ca85829a2df0ec3153be0318b5e2d3348e872092edffba"
PK6="0x92db14e403b83dfe3df233f83dfa3a0d7096f21ca9b0d6d6b8d88b2b4ec1564e"
PK7="0x4bbbf85ce3377467afe5d46f804f221813b2bb87f24d81f60f1fcdbf7cbf4356"
PK8="0xdbda1821b80551c9d65939329250298aa3472ba22feea921c0cf5d620ea67b97"
PK9="0x2a871d0798f97d79848a013d4936a73bf4cc922c825d33c1cf7073dff6d409c6"
# https://book.getfoundry.sh/tutorials/solidity-scripting?highlight=Private%20key#environment-configuration
# GOERLI_RPC_URL=
# ETHERSCAN_API_KEY=

View File

@ -2,31 +2,52 @@
pragma solidity ^0.8.23;
import {Script, console2} from "forge-std/Script.sol";
import { DCO2s } from "src/DCO2s.sol";
import {DCO2s} from "src/DCO2s.sol";
contract DCO2sScript is Script {
DCO2s public dco2sc;
address public defaultAdmin;
address public minter;
address[] public airdrops;
string public baseURI;
string public name;
string public symbol;
string[] public nfts;
function setUp() public {
baseURI = "https://gateway.decentralizedscience.org/ipfs/";
dco2sc = new DCO2s(0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266,
0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266,
baseURI,
"DCO2s",
"DCO2");
console2.log("The DCO2s contract address is: ", address(dco2sc));
baseURI = vm.envString("BASE_URI");
defaultAdmin = vm.envAddress("DEFAULT_ADMIN");
minter = vm.envAddress("MINTER");
name = vm.envString("NAME");
symbol = vm.envString("SYMBOL");
// Import nfts array from .env and split by ' '
nfts = vm.envString("nfts", " ");
airdrops = vm.envAddress("airdrops", "\n");
}
// run is the entry point
function run() public {
// startBroadcast and stopBraodcast will let us execute transactions anything between them
vm.startBroadcast();
uint256 deployerPrivateKey = vm.envUint("PK0");
vm.startBroadcast(deployerPrivateKey);
// here we just need to deploy a new contract
string memory URI = "bafkreibc6p3y36yjmeqqnttqfrpb2yttxa6aonoywxwdxl7nqym4jj3jwa";
dco2sc.safeMint(0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266, URI);
string memory tokenURI = dco2sc.tokenURI(0);
dco2sc = new DCO2s(defaultAdmin, minter, baseURI, name, symbol);
console2.log("The DCO2s contract address is: ", address(dco2sc));
// minting all nfts to airdrops accounts
// @notice: uses module for airdrops accounts to distribute the nfts
for (uint256 i; i < nfts.length; i++) {
dco2sc.safeMint(airdrops[i % airdrops.length], nfts[i]);
string memory tokenURI = dco2sc.tokenURI(i);
console2.log("Token0 URI is:", tokenURI);
}
// minting NFT0 to the contract admin
//string memory URI = nfts[0];
//dco2sc.safeMint(defaultAdmin, URI);
//string memory tokenURI = dco2sc.tokenURI(0);
//console2.log("Token0 URI is:", tokenURI);
vm.stopBroadcast();
}
}

View File

@ -1,22 +1,20 @@
// SPDX-License-Identifier: GPL-3.0
pragma solidity ^0.8.23;
import { Ownable } from "@openzeppelin/contracts/access/Ownable.sol";
import { DCO2s } from "./DCO2s.sol";
import {Ownable} from "@openzeppelin/contracts/access/Ownable.sol";
import {DCO2s} from "./DCO2s.sol";
contract AA is Ownable {
DCO2s public dco2sc;
string[] nfts;
mapping (address => bool) public airdropped;
mapping (address => bool) public eligible;
mapping(address => bool) public airdropped;
mapping(address => bool) public eligible;
constructor(string memory name,
string memory symbol,
string memory baseURI,
string [] memory nftURIs
) Ownable(msg.sender) {
dco2sc = new DCO2s(address(this),address(this), baseURI, name, symbol);
constructor(string memory name, string memory symbol, string memory baseURI, string[] memory nftURIs)
Ownable(msg.sender)
{
dco2sc = new DCO2s(address(this), address(this), baseURI, name, symbol);
nfts = nftURIs;
}
@ -28,7 +26,7 @@ contract AA is Ownable {
// Mint Function
// Simplify
function mintNFT(address to, uint index) external onlyOwner {
function mintNFT(address to, uint256 index) external onlyOwner {
require(!airdropped[to], "account already airdropped");
dco2sc.safeMint(to, nfts[index]);
removeNFTAt(index);
@ -71,20 +69,16 @@ contract AA is Ownable {
eligible[supporter] = true;
}
// @notice Returns a randon number calculated from previews block randao
// @dev This only works after the merge
function getRandomNumber() public view returns (uint randomNumber) {
function getRandomNumber() public view returns (uint256 randomNumber) {
randomNumber = block.prevrandao;
}
// @notice removes NFT URI from index
function removeNFTAt(uint index) public {
function removeNFTAt(uint256 index) public {
require(index < nfts.length, "nft index out of bounds");
nfts[index] = nfts[nfts.length - 1];
nfts.pop();
}
}

View File

@ -12,12 +12,9 @@ contract DCO2s is ERC721, ERC721Enumerable, ERC721URIStorage, AccessControl {
uint256 private _nextTokenId;
string bURI;
constructor(
address defaultAdmin,
address minter,
string memory baseURI,
string memory name, string memory symbol)
ERC721(name, symbol) {
constructor(address defaultAdmin, address minter, string memory baseURI, string memory name, string memory symbol)
ERC721(name, symbol)
{
_grantRole(DEFAULT_ADMIN_ROLE, defaultAdmin);
_grantRole(MINTER_ROLE, minter);
bURI = baseURI;
@ -43,19 +40,11 @@ contract DCO2s is ERC721, ERC721Enumerable, ERC721URIStorage, AccessControl {
return super._update(to, tokenId, auth);
}
function _increaseBalance(address account, uint128 value)
internal
override(ERC721, ERC721Enumerable)
{
function _increaseBalance(address account, uint128 value) internal override(ERC721, ERC721Enumerable) {
super._increaseBalance(account, value);
}
function tokenURI(uint256 tokenId)
public
view
override(ERC721, ERC721URIStorage)
returns (string memory)
{
function tokenURI(uint256 tokenId) public view override(ERC721, ERC721URIStorage) returns (string memory) {
return super.tokenURI(tokenId);
}

View File

@ -13,7 +13,7 @@ contract AATest is Test {
function setUp() public {
baseURI = "https://gateway.decentralizedscience.org/ipfs/";
// Import nfts array from .env and split by ' '
nfts = vm.envString("nfts", ' ');
nfts = vm.envString("nfts", " ");
aaContract = new AA("DCO2s", "DCO2", baseURI, nfts);
}
@ -22,7 +22,7 @@ contract AATest is Test {
address to = address(0x1);
aaContract.mintNFT(to, 0);
address dco2scAddress = address(aaContract.dco2sc());
console.log("{}",dco2scAddress);
console.log("{}", dco2scAddress);
//assertEq(aaContract.ownerOf(0), to, "Token should be minted to specified address.");
}

View File

@ -3,38 +3,40 @@ pragma solidity ^0.8.23;
import {Test, console} from "forge-std/Test.sol";
import {DCO2s} from "../src/DCO2s.sol";
//import {nfts} from "../.env";
contract DCO2sTest is Test {
DCO2s public dco2sc;
string public name;
string public symbol;
string public baseURI;
string[] public nfts;
function setUp() public {
baseURI = "https://gateway.decentralizedscience.org/ipfs/";
dco2sc = new DCO2s(address(this), address(this), baseURI, "DCO2s", "DCO2");
baseURI = vm.envString("BASE_URI");
name = vm.envString("NAME");
symbol = vm.envString("SYMBOL");
dco2sc = new DCO2s(address(this), address(this), baseURI, name, symbol);
// Import nfts array from .env and split by ' '
nfts = vm.envString("nfts", ' ');
nfts = vm.envString("nfts", " ");
}
// @notice this code safe mints an NFT to address 0x1
function testMint() public {
address to = address(0x1);
dco2sc.safeMint(to,nfts[0]);
dco2sc.safeMint(to, nfts[0]);
assertEq(dco2sc.ownerOf(0), to, "Token should be minted to specified address.");
}
// @notice: here we test getting the Base and full URIS
function testGetURI68() public {
dco2sc.safeMint(address(0x1), nfts[68]);
function testGetURI15() public {
dco2sc.safeMint(address(0x1), nfts[15]);
string memory tokenURI = dco2sc.tokenURI(0);
//console.log(tokenURI);
assertEq(tokenURI, string.concat(baseURI, nfts[68]));
assertEq(tokenURI, string.concat(baseURI, nfts[15]));
}
// @notice: checkFailed token Index
function testFailTokenIndex() view public {
function testFailTokenIndex() public view {
dco2sc.tokenURI(0);
}
@ -50,165 +52,76 @@ contract DCO2sTest is Test {
function testEnumerableTotalSupply() public {
string[5] memory mintedNFTs;
for(uint i = 0; i < 5; i++){
for (uint256 i = 0; i < 5; i++) {
mintedNFTs[i] = nfts[i];
}
// mint 5 nfts
for(uint i = 0; i < mintedNFTs.length; i++){
for (uint256 i = 0; i < mintedNFTs.length; i++) {
dco2sc.safeMint(address(1), mintedNFTs[i]);
}
assertEq(mintedNFTs.length, dco2sc.totalSupply());
}
// @notice use the basic Enumerable property tokenByIndex
// @notice: use the basic Enumerable property tokenByIndex
// @notice: All nfts in the .env
function testEnumerableTokenByIndex() public {
string[5] memory nftsSlice;
for(uint i = 0; i < 5; i++){
nftsSlice[i] = nfts[i];
for (uint256 i; i < nfts.length; i++) {
dco2sc.safeMint(address(1), nfts[i]);
}
for(uint i; i < nftsSlice.length; i++){
dco2sc.safeMint(address(1), nftsSlice[i]);
}
assertEq(nftsSlice.length, dco2sc.totalSupply());
assertEq(nfts.length, dco2sc.totalSupply());
// Test for token By Index 4
uint tokenID = dco2sc.tokenByIndex(4);
assertEq(nftsSlice[4], nftsSlice[tokenID]);
uint256 tokenID = dco2sc.tokenByIndex(4);
assertEq(nfts[4], nfts[tokenID]);
// Test for token By Index 3
tokenID = dco2sc.tokenByIndex(3);
assertEq(nftsSlice[3], nftsSlice[tokenID]);
assertEq(nfts[3], nfts[tokenID]);
}
// @notice use the basic Enumerable property TokenOfOwnerByIndex
// @notice: All nfts in the .env
function testEnumerableTokenOfOwnerByIndex() public {
string[5] memory nftsSlice;
for(uint i = 0; i < 5; i++){
nftsSlice[i] = nfts[i];
}
for(uint i; i < nftsSlice.length; i++){
if(i % 2 == 0) {
dco2sc.safeMint(address(1), nftsSlice[i]);
// mints pair to address 1
for (uint256 i; i < nfts.length; i++) {
if (i % 2 == 0) {
dco2sc.safeMint(address(1), nfts[i]);
} else {
dco2sc.safeMint(address(2), nftsSlice[i]);
dco2sc.safeMint(address(2), nfts[i]);
}
}
// Get the balance of NFTs of the account 1
uint account1_balance = dco2sc.balanceOf(address(1));
assertEq(account1_balance, 3);
// Get the balance of NFTs of the account 1 pairs are 8
uint256 account1_balance = dco2sc.balanceOf(address(1));
assertEq(account1_balance, 8);
for(uint i; i < account1_balance; i++){
for (uint256 i; i < account1_balance; i++) {
// get the TokenID from account NFTs Index
uint token_id = dco2sc.tokenOfOwnerByIndex(address(1), i);
// console.log("Token ID ", token_id, " has URI: ", dco2sc.tokenURI(token_id));
assertEq(dco2sc.tokenURI(token_id), string.concat(baseURI, nftsSlice[token_id]));
uint256 token_id = dco2sc.tokenOfOwnerByIndex(address(1), i);
assertEq(dco2sc.tokenURI(token_id), string.concat(baseURI, nfts[token_id]));
}
}
// @notice: testFailMintToZeroAddress test that cannot safe mint to address 0
function testFailMintToZeroAddress() public {
dco2sc.safeMint(address(0), nfts[0]);
}
// // @notice testMintAll mints all the NFTs URIS and distribute to wallets
// // then it assertEq that it is properly minted to the wallet and the correct URI
// function testMintAll() public {
// string[68] memory mintedNFTs;
// for(uint i = 0; i < 68; i++){
// mintedNFTs[i] = nfts[i];
// }
// //= ["bafkreibc6p3y36yjmeqqnttqfrpb2yttxa6aonoywxwdxl7nqym4jj3jwa",
// // "bafkreidcf5baqb5wevs6avyd7dtd3j7rzrq65uyqasj4dbkcy6na4ig3ay",
// // "bafkreibffiehtv4ntajq5vjwpl7q44i6cjbg54lm5hkoa665ue2taspiyu",
// // "bafkreifqztiwfutjik4wfs3gyfdyrff7cugi4mcctluunrrbp5cgareisq",
// // "bafkreiglyvpxwrxdvruit3oiw2lvkxqqxn7ojquw4gl7ck6szewz6t6cam",
// // "bafkreiakd4xtuw3toe4wnez2ndmdadqv3oszaoffoha4tw2hqr3sjnsmge",
// // "bafkreigx2isd63yflf6toeg7nfqw33hf6vvllcxfnzn7ymd7u4okflivbi",
// // "bafkreidrsjlcajbz35crgs6dpog6ophcochrgrrqgejxfye4m6lbw5mdde",
// // "bafkreihwi7xoak3p3mmofdln4pc4wqkkbdwyyz2yxbpfvpzvvxa2ogbaxi",
// // "bafkreiclhcy3n5iq3ka2jwxhvedpdewonwoujgu77y7rgnkddheioemcsi",
// // "bafkreic3vdshhst65qtzkwfbqzfpmuqbsyizxguarixobrp3scwaiq5jre",
// // "bafkreifv5xyis2kuveyfoc662zxeol2zdyiue4h3sznosef7ihrsmjexwm",
// // "bafkreifqyk6255h2ppobog33fzifsosbcnn2tanqi3ezjcwis6gya4sfoi",
// // "bafkreigend4j42oanbjxltwuyizmufdhqbngf6fbe5hgnlxs3yhzgpvay4",
// // "bafkreiextgvmtg23rx3lq2s6psebqln6ojlgosc544jch72baq3yt3dryu",
// // "bafkreihlkfwt5ntpnwf3c37d4lsf4y6czxojyffqet5ujvzw374x7ainoi",
// // "bafkreievuhvdru7p3lxht3of67xdri6urrrsjxr2e6rzulwg2574ye3dji",
// // "bafkreidqa6xuekp34iu7cqmngdbe7knzia47s7gwn3zczr5vwso57nrtx4",
// // "bafkreiglo5jhcem4ogswylqi37bx2wmn65cy6blwbwxcvuzklpfr6vhmke",
// // "bafkreibz353bqq76gjvswt7eebyffi3nkke5bzrvsjzem3is6x4ptpnqvi",
// // "bafkreif2dohcblqea4t4z5qjfxtdzz6vmtxs4325yuf6jz6e2sdxf366ni",
// // "bafkreib265gzsjgprktabq4c3glrdl5noebegibwupchwuwbswohum3ap4",
// // "bafkreicfaqdpgnrnebvqxyvg7s7eqgipbw5bg3hdticvghcpivjmvjx364",
// // "bafkreiabmontlvf2ah3vngpaf3cmg5ejinyqe6yl5pcl4lfrtvduwnuqcq",
// // "bafkreidvyf5txqmcizexdexdaqsbr4fxclcpfn6npgkngm6rclaszjll4q",
// // "bafkreib4wysvkug2bbzfpuey7hazqkezqtstv2n3yzccw7z77n2urcb6ye",
// // "bafkreiailtryy3cg7anain2evahiaox6babpxd4dp4kl67jqeoabh6ndwi",
// // "bafkreid32knw3kptbognoamqxcu5a2r3hzlzcb5a4tbouzfob5j2hhww6y",
// // "bafkreifprm74saobjxnang72smgtrevwvsxyps46kbc6ehhk3veqqpprte",
// // "bafkreif6wbrqmlqihivdasweh5opjjixinupsqfqmyflo2he3tdibx26mq",
// // "bafkreig75yruw2hkfqdfhmjm7lfenojvgv6emxfgkwolajhnjsokcc3vv4",
// // "bafkreihxvojrjrzigupwtncsrwsswju4cwh2sz5z2evqt6qlgcd7siptqi",
// // "bafkreifmcjsvyou6ml6khq7d7iglchh4a4clqvzf7t4ky6sxyoml6ixvj4",
// // "bafkreieyrrsp4lgoqqfrynp64cdif2jrnnzwc3lv4j5wlm4glszhjltp24",
// // "bafkreicpw7ytfbzakmg23wkuhrpumcdtoh75po7j6fu627vru3hgl6kpay",
// // "bafkreifrdsfw2vazhleexjkcd6f6t73aqvrobq5nwyeqa2rmykqtsef2o4",
// // "bafkreicdmr2bet7omb3u5zrgvubq2nxwbzlo6kqkjy6swey4u5yavqsf3y",
// // "bafkreihupkyebtf3rybziatp7p242gbyza7rf7s6noj3wun6fwd2sr6qhq",
// // "bafkreibrlybbkiiutohvwj3q6j3drs7llaxliz7dhiflipq34e4guzcbhu",
// // "bafkreieuseajoxy4ouo2u2upxz7lssoivcb63r64ada6n6pbxtupwnp6fa",
// // "bafkreid53wwrea4erd5hm7gjgkgpp6oddjqnctffewf3nay2grs2nhmh5y",
// // "bafkreigzrzugp7aqn6u6yqyaeu7v5lou4ldvkc5gfstr3p3otaf4afg56y",
// // "bafkreibqdmemeh57bkszki7oypxelqlihuy26eaeoi664epsqr5543q3je",
// // "bafkreiga4wd7vxjn46eovsktpmg2ugrd545sckdu2ibytvyjmj44rxjo5a",
// // "bafkreibef52rjpwrhfoaewbb4x7w5nthexsxzanoh5g7l3wzikubw6t4j4",
// // "bafkreihbkxbmbxk5xcujr3vwoo3qnnkubqmrkytjml76f2be4rfdi3kwiy",
// // "bafkreibh5fgjwuzcnyrpdcyxzpcjndrppeelgrjccfq2s7jg52dvcmk4cy",
// // "bafkreiea7k7u6kq76a4zysht5ri62jabvbuf6uk2emptxua2lkfmpleqqu",
// // "bafkreibietep53mtdq5kpk442x5djcaiwkirgltemomaaa6in6j375agfe",
// // "bafkreifwho3vue5x3yus3bcl2vs46b2ehgnhokmk4363dyptcqkcjuwtwm",
// // "bafkreicb662izefhwuvv7u6yh4rav76od4r4nkm6h7mgkflb77bt5wkimm",
// // "bafkreihlls4pkcjtjaasxmvctafrslucawm5lrffz5ho57azdaiapo2evq",
// // "bafkreih4ncyemyptx3nxe5qvxn6keiv7m36avhg5t2z6uvohs22he6q5zi",
// // "bafkreibxx4deq65og67be3oliqz2u4j6tacczarf74lbusbblflnp3c46a",
// // "bafkreibyegb4yn3yzxsnq5rggwra2x4nnd4eojvzdtxnl6lixq4f7cbdmm",
// // "bafkreiaygw7455yt6siqsqjs5bfhrrbxa5ezlktcwdnyeqikuq66irm5me",
// // "bafkreiaqj7xiukqacs6genv7s5bewucuag3d2lnn6kwqmkcnsngtrn2p5i",
// // "bafkreigm4czjurpcdgqapwj3ilzg7o3qx6wiyfd74hitm5hklyxbx52ujy",
// // "bafkreifgtz7hpaeuendeah37ny363ppx3klctkycol665lk65nkolvtj7q",
// // "bafkreicje4abjqh52oz35ble2yvasjkxemsptjnvla73greqzz5jwfkhiu",
// // "bafkreiebelxzjwxdvyvvj6cmqcn6cdnetrfxnw4bf4zaqkbh4myvu3a6qu",
// // "bafkreibg5fatnupr4u66zp5xabgyav65aik3bwv7ms73xjig37qz7ffura",
// // "bafkreigkgv36pc4gc35vlm7axlrtvbpwxl54pnq6mjovvre7n6vsqyfrp4",
// // "bafkreiekiefyw55qxsoqvbv2zbrjhbvrybo5qsamhsvk6rst4kzxmrxioq",
// // "bafkreifv2zmtj54mezqqbdfcc6z2anexctcumvs64abo2cvqgo47d6qk4q",
// // "bafkreibjlhludpjooxikum7cjw7c6rczgwbekaiusjm4xu5nyodwr3zjnm",
// // "bafkreib5z3fllsfv32fjhgvkao3csi4r2dhsegji52aqmfp4x2s6qb7734",
// // "bafkreiajnquwgsapxpesee4yyjz3hbwkopbr5pkpydbhjo4iwcpxolzrfy"];
// //assign to 68 addresses
// for ( uint i = 0; i < mintedNFTs.length; i++) {
// dco2sc.safeMint(address(this), mintedNFTs[i]);
// }
// // assert that each NFT gets minted with the proper URI
// // and addrress
// for ( uint i; i < mintedNFTs.length; i++) {
// assertEq(mintedNFTs[i], dco2sc.tokenURI(token_id));
// }
// }
// @notice testMintAll mints all the NFTs URIS and distribute to wallets
// then it assertEq that it is properly minted to the wallet and the correct URI
function testMintAll() public {
//assign to nfts.lenght addresses each one 1 NFT
for (uint256 i; i < nfts.length; i++) {
dco2sc.safeMint(address(uint160(i + 1)), nfts[i]);
}
// assert that each NFT gets minted with the proper URI
// and address
for (uint256 i; i < nfts.length; i++) {
uint256 token_id = dco2sc.tokenOfOwnerByIndex(address(uint160(i + 1)), 0);
assertEq(string.concat(baseURI, nfts[i]), dco2sc.tokenURI(token_id));
}
}
}