From a20d3ad0b0fc822bb02ab906506b8fe8cdae398a Mon Sep 17 00:00:00 2001 From: Timepunk <45543880+0xTimepunk@users.noreply.github.com> Date: Wed, 9 Oct 2024 15:26:54 +0100 Subject: [PATCH 1/2] test: new scenario multi dst permit2 --- Makefile | 2 +- ...0.00.TokenInput.Slippage.AMB12.Permit2.sol | 77 +++++++++++++++++++ 2 files changed, 78 insertions(+), 1 deletion(-) create mode 100644 test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol diff --git a/Makefile b/Makefile index 38a81ceb5..62a759cf9 100644 --- a/Makefile +++ b/Makefile @@ -121,7 +121,7 @@ build-sizes: ## Builds the project and shows sizes .PHONY: test-vvv test-vvv: ## Runs tests with verbose output - forge test --match-contract SXSVDNormal4626MultiTokenInputFromBeraNoSlippageAMB23 --evm-version cancun -vvv + forge test --match-contract MDMVDMulti0000NoTokenInputSlippageAMB12Permit2 --evm-version cancun -vvv .PHONY: ftest ftest: ## Runs tests with cancun evm version diff --git a/test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol b/test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol new file mode 100644 index 000000000..920853cc0 --- /dev/null +++ b/test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol @@ -0,0 +1,77 @@ +// SPDX-License-Identifier: BUSL-1.1 +pragma solidity ^0.8.23; + +// Test Utils +import "../../../utils/ProtocolActions.sol"; + +contract MDMVDMulti0000NoTokenInputSlippageAMB12Permit2 is ProtocolActions { + function setUp() public override { + chainIds = [ETH, OP]; + + super.setUp(); + /*////////////////////////////////////////////////////////////// + !! WARNING !! DEFINE TEST SETTINGS HERE + //////////////////////////////////////////////////////////////*/ + + AMBs = [1, 2]; + MultiDstAMBs = [AMBs, AMBs]; + + CHAIN_0 = OP; + DST_CHAINS = [OP, ETH]; + + /// @dev define vaults amounts and slippage for every destination chain and for every action + TARGET_UNDERLYINGS[OP][0] = [0, 1]; + TARGET_UNDERLYINGS[ETH][0] = [1, 0]; + + TARGET_VAULTS[OP][0] = [0, 0]; + TARGET_VAULTS[ETH][0] = [0, 0]; + + TARGET_FORM_KINDS[OP][0] = [0, 0]; + TARGET_FORM_KINDS[ETH][0] = [0, 0]; + + MAX_SLIPPAGE = 1000; + + LIQ_BRIDGES[OP][0] = [2, 1]; + LIQ_BRIDGES[ETH][0] = [2, 2]; + + RECEIVE_4626[OP][0] = [false, false]; + RECEIVE_4626[ETH][0] = [false, false]; + + actions.push( + TestAction({ + action: Actions.DepositPermit2, + multiVaults: true, //!!WARNING turn on or off multi vaults + user: 0, + testType: TestType.Pass, + revertError: "", + revertRole: "", + slippage: 421, // 0% <- if we are testing a pass this must be below each maxSlippage, + dstSwap: false, + externalToken: 1 // 0 = DAI, 1 = USDT, 2 = WETH + }) + ); + } + + /*/////////////////////////////////////////////////////////////// + SCENARIO TESTS + //////////////////////////////////////////////////////////////*/ + + function test_scenario(uint128 amountOne_, uint128 amountTwo_) public { + /// @dev amount = 1 after slippage will become 0, hence starting with 2 + amountOne_ = uint128(bound(amountOne_, 2 * 10 ** 18, 1000 * 10 ** 18)); + amountTwo_ = uint128(bound(amountTwo_, 2 * 10 ** 18, 1000 * 10 ** 18)); + AMOUNTS[OP][0] = [amountOne_, amountTwo_]; + AMOUNTS[ETH][0] = [amountTwo_, amountOne_]; + + for (uint256 act; act < actions.length; ++act) { + TestAction memory action = actions[act]; + MultiVaultSFData[] memory multiSuperformsData; + SingleVaultSFData[] memory singleSuperformsData; + MessagingAssertVars[] memory aV; + StagesLocalVars memory vars; + bool success; + + _runMainStages(action, act, multiSuperformsData, singleSuperformsData, aV, vars, success); + } + } +} From d570f6aefacc8d237d65f6a4624a24f920a53414 Mon Sep 17 00:00:00 2001 From: Timepunk <45543880+0xTimepunk@users.noreply.github.com> Date: Wed, 9 Oct 2024 16:14:07 +0100 Subject: [PATCH 2/2] test: fix scenario --- .../Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol | 8 ++++---- test/utils/CommonProtocolActions.sol | 3 +-- test/utils/ProtocolActions.sol | 2 +- 3 files changed, 6 insertions(+), 7 deletions(-) diff --git a/test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol b/test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol index 920853cc0..1d6a48542 100644 --- a/test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol +++ b/test/fuzz/scenarios/scenarios-deposit-multiDstMultiVaultDeposit/Multi.00.00.TokenInput.Slippage.AMB12.Permit2.sol @@ -31,8 +31,8 @@ contract MDMVDMulti0000NoTokenInputSlippageAMB12Permit2 is ProtocolActions { MAX_SLIPPAGE = 1000; - LIQ_BRIDGES[OP][0] = [2, 1]; - LIQ_BRIDGES[ETH][0] = [2, 2]; + LIQ_BRIDGES[OP][0] = [1, 1]; + LIQ_BRIDGES[ETH][0] = [1, 1]; RECEIVE_4626[OP][0] = [false, false]; RECEIVE_4626[ETH][0] = [false, false]; @@ -58,8 +58,8 @@ contract MDMVDMulti0000NoTokenInputSlippageAMB12Permit2 is ProtocolActions { function test_scenario(uint128 amountOne_, uint128 amountTwo_) public { /// @dev amount = 1 after slippage will become 0, hence starting with 2 - amountOne_ = uint128(bound(amountOne_, 2 * 10 ** 18, 1000 * 10 ** 18)); - amountTwo_ = uint128(bound(amountTwo_, 2 * 10 ** 18, 1000 * 10 ** 18)); + amountOne_ = uint128(bound(amountOne_, 2 * 10 ** 6, TOTAL_SUPPLY_USDC / 4)); + amountTwo_ = uint128(bound(amountTwo_, 2 * 10 ** 6, TOTAL_SUPPLY_USDC / 4)); AMOUNTS[OP][0] = [amountOne_, amountTwo_]; AMOUNTS[ETH][0] = [amountTwo_, amountOne_]; diff --git a/test/utils/CommonProtocolActions.sol b/test/utils/CommonProtocolActions.sol index 1b6b40a8a..d5487e0c9 100644 --- a/test/utils/CommonProtocolActions.sol +++ b/test/utils/CommonProtocolActions.sol @@ -144,7 +144,6 @@ abstract contract CommonProtocolActions is BaseSetup { abi.encodeWithSelector(LiFiMock.swapAndStartBridgeTokensViaBridge.selector, bridgeData, swapData); } else { LibSwap.SwapData[] memory swapData = new LibSwap.SwapData[](1); - swapData[0] = LibSwap.SwapData( address(0), /// @dev callTo (arbitrary) @@ -181,7 +180,7 @@ abstract contract CommonProtocolActions is BaseSetup { } else if (args.liqBridgeKind == 2) { /// @notice bridge id 2 doesn't support same chain swaps if (args.toChainId == args.srcChainId) { - revert(); + revert("bridge id 2 doesn't support same chain swaps: "); } ISocketRegistry.BridgeRequest memory bridgeRequest; diff --git a/test/utils/ProtocolActions.sol b/test/utils/ProtocolActions.sol index 6906f2de2..daed4223d 100644 --- a/test/utils/ProtocolActions.sol +++ b/test/utils/ProtocolActions.sol @@ -3316,7 +3316,7 @@ abstract contract ProtocolActions is CommonProtocolActions { /// @notice ID: 2 Hyperlane if (AMBs[i] == 2) { HyperlaneHelper(getContract(TO_CHAIN, "HyperlaneHelper")).help( - address(HYPERLANE_MAILBOXES[TO_CHAIN]), // BARTIO + address(HYPERLANE_MAILBOXES[TO_CHAIN]), // BARTIO address(HYPERLANE_MAILBOXES[FROM_CHAIN]), // SEPOLIA FORKS[FROM_CHAIN], // SEPOLIA logs