From b7e8c409ffe43dfa3e8d19e4373b894502ec88e3 Mon Sep 17 00:00:00 2001 From: diana Date: Thu, 23 May 2024 17:36:54 -0400 Subject: [PATCH] Protocolfees tests (#701) * protocol fees tests * more tests * underscore for internal var * protocol fees tests * re-add view * gas snapshot * slot0 verify * shorten * comments * extra comment * fix snapshot * fix failing test --- test/ProtocolFeesImplementation.t.sol | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/test/ProtocolFeesImplementation.t.sol b/test/ProtocolFeesImplementation.t.sol index 05d624492..822254c07 100644 --- a/test/ProtocolFeesImplementation.t.sol +++ b/test/ProtocolFeesImplementation.t.sol @@ -123,8 +123,6 @@ contract ProtocolFeesTest is Test, GasSnapshot, Deployers { function test_fuzz_collectProtocolFees(address recipient, uint256 amount, uint256 feesAccrued) public { vm.assume(feesAccrued <= currency0.balanceOf(address(protocolFees))); - vm.assume(amount <= feesAccrued); - vm.assume(recipient != address(protocolFees)); uint256 recipientBalanceBefore = currency0.balanceOf(recipient); uint256 senderBalanceBefore = currency0.balanceOf(address(protocolFees)); @@ -138,12 +136,21 @@ contract ProtocolFeesTest is Test, GasSnapshot, Deployers { protocolFees.setProtocolFeeController(feeController); vm.prank(address(feeController)); + if (amount > feesAccrued) { + vm.expectRevert(); + } uint256 amountCollected = protocolFees.collectProtocolFees(recipient, currency0, amount); - assertEq(protocolFees.protocolFeesAccrued(currency0), feesAccrued - amount); - assertEq(currency0.balanceOf(recipient), recipientBalanceBefore + amount); - assertEq(currency0.balanceOf(address(protocolFees)), senderBalanceBefore - amount); - assertEq(amountCollected, amount); + if (amount <= feesAccrued) { + if (recipient == address(protocolFees)) { + assertEq(currency0.balanceOf(recipient), recipientBalanceBefore); + } else { + assertEq(currency0.balanceOf(recipient), recipientBalanceBefore + amount); + assertEq(currency0.balanceOf(address(protocolFees)), senderBalanceBefore - amount); + } + assertEq(protocolFees.protocolFeesAccrued(currency0), feesAccrued - amount); + assertEq(amountCollected, amount); + } } function test_updateProtocolFees_succeeds() public {