Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
33c4d65
Initial forge tests
drinkcoffee Jan 10, 2025
35ba4ac
Added initial test
drinkcoffee Jan 10, 2025
84bad32
Create initial performance tests
drinkcoffee Jan 13, 2025
5c9f3a9
Mint at 15K per block to max out the blocks
drinkcoffee Jan 13, 2025
80bce5d
Added more tests
drinkcoffee Jan 14, 2025
0f14037
Add more tests
drinkcoffee Jan 14, 2025
bf0837f
Revise import order
drinkcoffee Jan 15, 2025
f70f480
Initial compiling version of PsiV2
drinkcoffee Jan 16, 2025
011ccb4
Resolved issues with PsiV2
drinkcoffee Jan 17, 2025
47c0079
Fixed issue with determing existance of an NFT
drinkcoffee Jan 17, 2025
f72216a
Improve documentation. Prefill by 160K
drinkcoffee Jan 20, 2025
dedbc6b
Migrate ERC721 tests to forge
drinkcoffee Jan 29, 2025
5861530
Improve ERC 721 test coverage
drinkcoffee Jan 29, 2025
e48d49c
Added more tests
drinkcoffee Jan 31, 2025
a74fa1b
Add more tests and remove dead code
drinkcoffee Feb 3, 2025
f5c0f86
Added documentation for ERC721PsiV2
drinkcoffee Feb 4, 2025
3f56c1b
Added more tests
drinkcoffee Feb 5, 2025
540e221
Change solidity version
drinkcoffee Feb 6, 2025
c53427a
Merge branch 'main' into peter-solidity-version
drinkcoffee Feb 6, 2025
bea8ee7
Merge branch 'peter-solidity-version' into peter-erc721-perf
drinkcoffee Feb 6, 2025
ce033e3
Add more tests
drinkcoffee Feb 6, 2025
36c41e7
Added transferFrom tests
drinkcoffee Feb 6, 2025
59b6c1a
Added more tests
drinkcoffee Feb 7, 2025
6912c29
Rename files
drinkcoffee Feb 7, 2025
4045cac
Merge branch 'main' into peter-erc721-perf
drinkcoffee Feb 7, 2025
0f31fa1
Add documentation for ERC 721 contracts
drinkcoffee Feb 7, 2025
2be5039
Fix prettier issues
drinkcoffee Feb 9, 2025
c5f3ec5
Fix solidity version and remove dead code
drinkcoffee Feb 10, 2025
0cc0e1b
Add solhint support for PsiV2
drinkcoffee Feb 10, 2025
e7e359c
Fixed last Slither warning
drinkcoffee Feb 10, 2025
df57fa4
Remove temporary file
drinkcoffee Feb 10, 2025
a6f485c
Remove dead code
drinkcoffee Feb 10, 2025
78bf98b
Improve test coverage
drinkcoffee Feb 10, 2025
af2bca0
Resolve solhint issues
drinkcoffee Feb 10, 2025
45ea3cd
Merge from peter-erc721-perf
drinkcoffee Feb 25, 2025
b7684d7
Remove mention of invariant tests
drinkcoffee Feb 25, 2025
2606a37
Fixed copyright notices
drinkcoffee Feb 27, 2025
34965c8
Added Mermaid diagram source code
drinkcoffee Feb 28, 2025
3bcd1a1
Fixed up incorrect documentation
drinkcoffee Feb 28, 2025
e321e7a
Add audit report
drinkcoffee Mar 3, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Added more tests
  • Loading branch information
drinkcoffee committed Jan 31, 2025
commit e48d49ce07a2c0c786a4ec36b1af53392112d51c
Original file line number Diff line number Diff line change
Expand Up @@ -38,4 +38,11 @@ interface IImmutableERC721ByQuantity is IImmutableERC721 {
*
*/
function exists(uint256 tokenId) external view returns (bool);

/**
* @notice returns the threshold that divides tokens that are minted by id and
* minted by quantity
*/
function mintBatchByQuantityThreshold() external pure returns (uint256);

}
2 changes: 2 additions & 0 deletions test/token/erc721/ERC721Base.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ import {DeployOperatorAllowlist} from "../../utils/DeployAllowlistProxy.sol";
* Base contract for all ERC 721 tests.
*/
abstract contract ERC721BaseTest is Test {
event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);

string public constant BASE_URI = "https://baseURI.com/";
string public constant CONTRACT_URI = "https://contractURI.com";
string public constant NAME = "ERC721Preset";
Expand Down
238 changes: 120 additions & 118 deletions test/token/erc721/ERC721OperationalBase.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -157,158 +157,160 @@ abstract contract ERC721OperationalBaseTest is ERC721BaseTest {
}

function testBurn() public {
vm.prank(minter);
erc721.mint(user1, 1);
vm.prank(minter);
erc721.mint(user1, 2);
assertEq(erc721.balanceOf(user1), 2);
assertEq(erc721.totalSupply(), 2);
mintSomeTokens();

vm.prank(user1);
erc721.burn(1);
assertEq(erc721.balanceOf(user1), 1);
assertEq(erc721.totalSupply(), 1);
assertEq(erc721.balanceOf(user1), 2);
assertEq(erc721.totalSupply(), 4);
}

function testSafeBurn() public {
vm.prank(minter);
erc721.mint(user1, 1);
vm.prank(minter);
erc721.mint(user1, 2);
assertEq(erc721.balanceOf(user1), 2);
assertEq(erc721.totalSupply(), 2);
mintSomeTokens();

vm.prank(user1);
erc721.safeBurn(user1, 1);
assertEq(erc721.balanceOf(user1), 1);
assertEq(erc721.totalSupply(), 1);
assertEq(erc721.balanceOf(user1), 2);
assertEq(erc721.totalSupply(), 4);
}

function testSafeBurnTokenNotOwned() public {
vm.prank(minter);
erc721.mint(user1, 1);
vm.prank(minter);
erc721.mint(user1, 2);
mintSomeTokens();

vm.prank(user2);
vm.expectRevert(abi.encodeWithSelector(IImmutableERC721Errors.IImmutableERC721MismatchedTokenOwner.selector, 2, user1));
erc721.safeBurn(user2, 2);
}

function testSafeBurnIncorrectOwner() public {
vm.prank(minter);
erc721.mint(user1, 1);
vm.prank(minter);
erc721.mint(user1, 2);
mintSomeTokens();

vm.prank(user1);
vm.expectRevert(abi.encodeWithSelector(IImmutableERC721Errors.IImmutableERC721MismatchedTokenOwner.selector, 2, user1));
erc721.safeBurn(user2, 2);
}

function testSafeBurnNonExistentToken() public {
mintSomeTokens();

vm.prank(user1);
vm.expectRevert("ERC721: invalid token ID");
erc721.safeBurn(user1, 999);
}

function testBurnBatch() public {
mintSomeTokens();

uint256[] memory tokenIds1 = new uint256[](2);
tokenIds1[0] = 2;
tokenIds1[1] = 3;

vm.prank(user1);
erc721.burnBatch(tokenIds1);
}

function testBurnBatchIncorrectOwner() public {
mintSomeTokens();

uint256[] memory tokenIds1 = new uint256[](2);
tokenIds1[0] = 2;
tokenIds1[1] = 3;

vm.prank(user2);
vm.expectRevert(notOwnedRevertError(2));
erc721.burnBatch(tokenIds1);
}

function testBurnBatchNonExistentToken() public {
mintSomeTokens();

uint256[] memory tokenIds1 = new uint256[](2);
tokenIds1[0] = 2;
tokenIds1[1] = 11;

vm.prank(user1);
vm.expectRevert("ERC721: invalid token ID");
erc721.burnBatch(tokenIds1);
}

function testSafeBurnBatch() public {
mintSomeTokens();

uint256[] memory tokenIds1 = new uint256[](2);
tokenIds1[0] = 2;
tokenIds1[1] = 3;
IImmutableERC721.IDBurn[] memory burnRequests = new IImmutableERC721.IDBurn[](1);
burnRequests[0].owner = user1;
burnRequests[0].tokenIds = tokenIds1;

vm.prank(user1);
erc721.safeBurnBatch(burnRequests);
}

function testSafeBurnBatchIncorrectOwner() public {
mintSomeTokens();

uint256[] memory tokenIds1 = new uint256[](2);
tokenIds1[0] = 2;
tokenIds1[1] = 3;
IImmutableERC721.IDBurn[] memory burnRequests = new IImmutableERC721.IDBurn[](1);
burnRequests[0].owner = user1;
burnRequests[0].tokenIds = tokenIds1;

vm.prank(user2);
vm.expectRevert(notOwnedRevertError(2));
erc721.safeBurnBatch(burnRequests);
}

function testSafeBurnBatchNonExistentToken() public {
mintSomeTokens();

uint256[] memory tokenIds1 = new uint256[](2);
tokenIds1[0] = 2;
tokenIds1[1] = 11;
IImmutableERC721.IDBurn[] memory burnRequests = new IImmutableERC721.IDBurn[](1);
burnRequests[0].owner = user1;
burnRequests[0].tokenIds = tokenIds1;

vm.prank(user1);
vm.expectRevert("ERC721: invalid token ID");
erc721.safeBurnBatch(burnRequests);
}




function testPreventMintingBurnedTokens() public {
mintSomeTokens();

vm.prank(user1);
erc721.safeBurn(user1, 1);

// Try to mint the burned token
vm.prank(minter);
vm.expectRevert(
abi.encodeWithSelector(IImmutableERC721Errors.IImmutableERC721TokenAlreadyBurned.selector, 1)
);
erc721.mint(user3, 1);
}




function mintSomeTokens() internal {
vm.prank(minter);
erc721.mint(user1, 1);
vm.prank(minter);
erc721.mint(user1, 2);
vm.prank(minter);
erc721.mint(user1, 3);
vm.prank(minter);
erc721.mint(user2, 5);
vm.prank(minter);
erc721.mint(user2, 6);
assertEq(erc721.balanceOf(user1), 3);
assertEq(erc721.balanceOf(user2), 2);
assertEq(erc721.totalSupply(), 5);
}

// function test_RevertBatchBurnWithIncorrectOwners() public {
// // Setup: First mint tokens
// IImmutableERC721.IDMint[] memory requests = new IImmutableERC721.IDMint[](2);
// uint256[] memory tokenIds1 = new uint256[](3);
// tokenIds1[0] = 12;
// tokenIds1[1] = 13;
// tokenIds1[2] = 14;
// requests[0].to = owner;
// requests[0].tokenIds = tokenIds1;

// uint256[] memory tokenIds2 = new uint256[](3);
// tokenIds2[0] = 9;
// tokenIds2[1] = 10;
// tokenIds2[2] = 11;
// requests[0].to = user1;
// requests[0].tokenIds = tokenIds2;

// vm.prank(minter);
// erc721.mintBatch(requests);

// IImmutableERC721.IDBurn[] memory burns = new IImmutableERC721.IDBurn[](2);
// tokenIds1 = new uint256[](3);
// tokenIds1[0] = 12;
// tokenIds1[1] = 13;
// tokenIds1[2] = 14;
// burns[0].owner = owner;
// burns[0].tokenIds = tokenIds1;

// tokenIds2 = new uint256[](3);
// tokenIds2[0] = 9;
// tokenIds2[1] = 10;
// tokenIds2[2] = 11;
// burns[1].owner = owner;
// burns[1].tokenIds = tokenIds1;

// vm.prank(user1);
// vm.expectRevert(
// abi.encodeWithSignature(
// "IImmutableERC721MismatchedTokenOwner(uint256,address)",
// 12,
// owner
// )
// );
// erc721.safeBurnBatch(burns);
// }

// function test_PreventMintingBurnedTokens() public {
// // First mint and burn a token
// IImmutableERC721.IDMint[] memory requests = new IImmutableERC721.IDMint[](1);
// requests[0] = IImmutableERC721.IDMint({
// to: user1,
// tokenIds: new uint256[](2)
// });
// requests[0].tokenIds = [1, 2];

// vm.prank(minter);
// erc721.mintBatch(requests);

// vm.prank(user1);
// erc721.safeBurn(user1, 1);

// // Try to mint the burned token
// vm.prank(minter);
// vm.expectRevert(
// abi.encodeWithSignature(
// "IImmutableERC721TokenAlreadyBurned(uint256)",
// 1
// )
// );
// erc721.mintBatch(requests);
// }

// function test_RevertMintAboveThreshold() public {
// uint256 first = erc721.mintBatchByQuantityThreshold();

// IImmutableERC721.IDMint[] memory requests = new IImmutableERC721.IDMint[](1);
// requests[0] = IImmutableERC721.IDMint({
// to: user1,
// tokenIds: new uint256[](1)
// });
// requests[0].tokenIds[0] = first;

// vm.prank(minter);
// vm.expectRevert(
// abi.encodeWithSignature(
// "IImmutableERC721IDAboveThreshold(uint256)",
// first
// )
// );
// erc721.mintBatch(requests);
// }


// Additional test functions would follow...
}
Loading