Skip to content

Commit

Permalink
Test for testing gas usage
Browse files Browse the repository at this point in the history
  • Loading branch information
matejos committed Apr 24, 2024
1 parent 9fbc06b commit 5408081
Showing 1 changed file with 30 additions and 0 deletions.
30 changes: 30 additions & 0 deletions packages/contracts/evm-contracts/test/OrderbookDex.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ pragma solidity ^0.8.18;

import {CheatCodes} from "../test-lib/cheatcodes.sol";
import {CTest} from "../test-lib/ctest.sol";
import "../test-lib/console.sol";

import {Address} from "@openzeppelin/contracts/utils/Address.sol";
import {ERC1155Holder} from "@openzeppelin/contracts/token/ERC1155/utils/ERC1155Holder.sol";
Expand Down Expand Up @@ -503,5 +504,34 @@ contract OrderbookDexTest is CTest, ERC1155Holder {
dex.cancelBatchSellOrder(orderIds);
}

// Not really a test, was used to measure gas usage
function test_fillOrders_getGasUsage() public {
uint256 orderCount = 500;
uint256[] memory assetIds = new uint256[](orderCount);
uint256[] memory assetAmounts = new uint256[](orderCount);
uint256[] memory pricesPerAssets = new uint256[](orderCount);

for (uint256 i = 0; i < orderCount; ++i) {
assetAmounts[i] = i == 0 ? 1 : i;
pricesPerAssets[i] = i == 0 ? 1 : i;
assetIds[i] = asset.mint(assetAmounts[i], "");
}
uint256[] memory orderIds = dex.createBatchSellOrder(
assetIds,
assetAmounts,
pricesPerAssets
);

assertEq(orderIds.length, orderCount);

uint256 minimumAsset = 1;
uint256 value = type(uint256).max;
vm.deal(address(this), value);

uint256 startGas = gasleft();
dex.fillOrdersExactEth{value: value}(minimumAsset, orderIds);
console.log("fill orders gas used", startGas - gasleft());
}

receive() external payable {}
}

0 comments on commit 5408081

Please sign in to comment.