From 23107e732df787070f2be42c2ce0398a0e167312 Mon Sep 17 00:00:00 2001 From: 0xtekgrinder <0xtekgrinder@protonmail.com> Date: Mon, 5 Aug 2024 18:15:34 +0200 Subject: [PATCH] tests: add test with max balance --- test/foundry/AngeRouterMainnet.t.sol | 53 +++++++++++++++++++++++++++- 1 file changed, 52 insertions(+), 1 deletion(-) diff --git a/test/foundry/AngeRouterMainnet.t.sol b/test/foundry/AngeRouterMainnet.t.sol index 02ae28a..2807ecb 100644 --- a/test/foundry/AngeRouterMainnet.t.sol +++ b/test/foundry/AngeRouterMainnet.t.sol @@ -101,7 +101,12 @@ contract AngleRouterMainnetTest is BaseTest { assertEq(token.balanceOf(address(to)), 0); } - function testMint4626ForgotFunds(uint256 initShares, uint256 shares, uint256 maxAmount, uint256 gainOrLoss) public { + function testMint4626ForgotFunds( + uint256 initShares, + uint256 shares, + uint256 maxAmount, + uint256 gainOrLoss + ) public { address to = address(router); uint256 balanceUsers = BASE_TOKENS * 1 ether; deal(address(token), address(_alice), balanceUsers); @@ -189,6 +194,52 @@ contract AngleRouterMainnetTest is BaseTest { assertEq(token.balanceOf(address(to)), 0); } + function testDeposit4626MaxBalance( + uint256 initShares, + uint256 amount, + uint256 minSharesOut, + uint256 gainOrLoss + ) public { + address to = address(router); + + uint256 balanceUsers = BASE_TOKENS * 1 ether; + deal(address(token), address(_alice), balanceUsers); + + _randomizeSavingsRate(gainOrLoss, initShares); + + amount = bound(amount, 0, balanceUsers); + uint256 previewDeposit = savingsRate.previewDeposit(amount); + + PermitType[] memory paramsPermit = new PermitType[](0); + ActionType[] memory actionType = new ActionType[](2); + bytes[] memory data = new bytes[](2); + + actionType[0] = ActionType.transfer; + data[0] = abi.encode(token, router, amount); + actionType[1] = ActionType.deposit4626; + data[1] = abi.encode(token, savingsRate, type(uint256).max, to, minSharesOut); + + uint256 mintedShares = savingsRate.convertToShares(amount); + + vm.startPrank(_alice); + token.approve(address(router), type(uint256).max); + // as this is a mock vault, previewMint is exactly what is needed to mint + if (previewDeposit < minSharesOut) { + vm.expectRevert(BaseRouter.TooSmallAmountOut.selector); + router.mixer(paramsPermit, actionType, data); + return; + } else { + router.mixer(paramsPermit, actionType, data); + } + vm.stopPrank(); + + assertEq(savingsRate.balanceOf(address(to)), previewDeposit); + assertEq(savingsRate.balanceOf(address(to)), mintedShares); + + assertEq(token.balanceOf(address(router)), 0); + assertEq(token.balanceOf(address(_alice)), balanceUsers - amount); + } + function testDeposit4626ForgotFunds( uint256 initShares, uint256 amount,