@bananapus/core-v6 0.0.37 → 0.0.39
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/foundry.lock +1 -7
- package/foundry.toml +1 -1
- package/package.json +19 -7
- package/src/JBChainlinkV3PriceFeed.sol +4 -1
- package/src/JBChainlinkV3SequencerPriceFeed.sol +4 -2
- package/src/JBController.sol +71 -44
- package/src/JBDeadline.sol +4 -4
- package/src/JBDirectory.sol +34 -32
- package/src/JBERC20.sol +5 -4
- package/src/JBFeelessAddresses.sol +6 -3
- package/src/JBFundAccessLimits.sol +25 -21
- package/src/JBMultiTerminal.sol +121 -84
- package/src/JBPermissions.sol +34 -37
- package/src/JBPrices.sol +23 -18
- package/src/JBProjects.sol +6 -3
- package/src/JBRulesets.sol +44 -41
- package/src/JBSplits.sol +18 -16
- package/src/JBTerminalStore.sol +32 -25
- package/src/JBTokens.sol +36 -26
- package/src/abstract/JBControlled.sol +3 -1
- package/src/abstract/JBPermissioned.sol +3 -1
- package/src/enums/JBApprovalStatus.sol +7 -1
- package/src/interfaces/IJBController.sol +7 -3
- package/src/interfaces/IJBDirectory.sol +3 -1
- package/src/interfaces/IJBMultiTerminal.sol +3 -2
- package/src/interfaces/IJBPermissions.sol +2 -1
- package/src/interfaces/IJBPrices.sol +3 -1
- package/src/interfaces/IJBRulesets.sol +2 -1
- package/src/interfaces/IJBSplits.sol +2 -1
- package/src/interfaces/IJBTerminal.sol +3 -1
- package/src/interfaces/IJBTerminalStore.sol +3 -1
- package/src/interfaces/IJBTokens.sol +2 -1
- package/src/libraries/JBCashOuts.sol +6 -1
- package/src/libraries/JBConstants.sol +12 -3
- package/src/libraries/JBCurrencyIds.sol +2 -0
- package/src/libraries/JBFees.sol +52 -10
- package/src/libraries/JBFixedPointNumber.sol +2 -0
- package/src/libraries/JBPayoutSplitGroupLib.sol +7 -4
- package/src/libraries/JBRulesetMetadataResolver.sol +4 -0
- package/src/libraries/JBSplitGroupIds.sol +2 -1
- package/src/libraries/JBSurplus.sol +3 -1
- package/src/periphery/JBMatchingPriceFeed.sol +3 -1
- package/src/structs/JBAccountingContext.sol +7 -4
- package/src/structs/JBFundAccessLimitGroup.sol +10 -17
- package/src/structs/JBRuleset.sol +18 -26
- package/src/structs/JBRulesetConfig.sol +13 -25
- package/src/structs/JBRulesetMetadata.sol +25 -32
- package/test/mock/MockMaliciousBeneficiary.sol +15 -15
- package/ADMINISTRATION.md +0 -103
- package/ARCHITECTURE.md +0 -133
- package/AUDIT_INSTRUCTIONS.md +0 -139
- package/RISKS.md +0 -215
- package/SKILLS.md +0 -55
- package/STYLE_GUIDE.md +0 -610
- package/USER_JOURNEYS.md +0 -215
- package/script/Deploy.s.sol +0 -124
- package/script/DeployPeriphery.s.sol +0 -354
- package/slither-ci.config.json +0 -10
- package/test/AuditFixes.t.sol +0 -808
- package/test/ComprehensiveInvariant.t.sol +0 -306
- package/test/CoreExploitTests.t.sol +0 -2741
- package/test/EconomicSimulation.t.sol +0 -348
- package/test/EntryPointPermutations.t.sol +0 -684
- package/test/FlashLoanAttacks.t.sol +0 -797
- package/test/PermissionEscalation.t.sol +0 -711
- package/test/PermissionsInvariant.t.sol +0 -403
- package/test/RulesetTransitions.t.sol +0 -713
- package/test/SplitLoopTests.t.sol +0 -752
- package/test/TestAccessToFunds.sol +0 -2683
- package/test/TestAuditResponseDesignProofs.sol +0 -434
- package/test/TestCashOut.sol +0 -198
- package/test/TestCashOutCountFor.sol +0 -271
- package/test/TestCashOutHooks.sol +0 -351
- package/test/TestCashOutTimingEdge.sol +0 -241
- package/test/TestDataHookFuzzing.sol +0 -524
- package/test/TestDurationUnderflow.sol +0 -233
- package/test/TestFeeFreeCashOutBypass.sol +0 -949
- package/test/TestFeeProcessingFailure.sol +0 -218
- package/test/TestFees.sol +0 -619
- package/test/TestForwardedTokenConsumption.sol +0 -425
- package/test/TestInterfaceSupport.sol +0 -81
- package/test/TestJBERC20Inheritance.sol +0 -103
- package/test/TestL2SequencerPriceFeed.sol +0 -292
- package/test/TestLaunchProject.sol +0 -188
- package/test/TestMetaTx.sol +0 -217
- package/test/TestMetadataOffsetOverflow.sol +0 -179
- package/test/TestMetadataParserLib.sol +0 -471
- package/test/TestMigrationHeldFees.sol +0 -255
- package/test/TestMintTokensOf.sol +0 -185
- package/test/TestMultiTerminalSurplus.sol +0 -348
- package/test/TestMultiTokenSurplus.sol +0 -202
- package/test/TestMultipleAccessLimits.sol +0 -664
- package/test/TestPayBurnRedeemFlow.sol +0 -195
- package/test/TestPayHooks.sol +0 -209
- package/test/TestPermissions.sol +0 -324
- package/test/TestPermissionsEdge.sol +0 -290
- package/test/TestPermit2DataHook.t.sol +0 -360
- package/test/TestPermit2Terminal.sol +0 -372
- package/test/TestRulesetQueueing.sol +0 -1025
- package/test/TestRulesetQueuingStress.sol +0 -806
- package/test/TestRulesetWeightCaching.sol +0 -178
- package/test/TestSplits.sol +0 -391
- package/test/TestTerminalMigration.sol +0 -274
- package/test/TestTerminalPreviewParity.sol +0 -208
- package/test/TestTokenFlow.sol +0 -191
- package/test/TestWeightCacheStaleAfterRejection.sol +0 -303
- package/test/WeirdTokenTests.t.sol +0 -817
- package/test/audit/CashOutReenterPay.t.sol +0 -501
- package/test/audit/CodexHeldFeeRounding.t.sol +0 -159
- package/test/audit/CodexMigrationFeeFailure.t.sol +0 -163
- package/test/audit/CrossTerminalSurplusSpoof.t.sol +0 -140
- package/test/audit/CycledSurplusAllowanceReset.t.sol +0 -184
- package/test/audit/FeeFreeSurplusLifecycle.t.sol +0 -399
- package/test/audit/FeeFreeSurplusStale.t.sol +0 -248
- package/test/audit/USDTVoidReturnCompat.t.sol +0 -525
- package/test/fork/TestChainlinkPriceFeedFork.sol +0 -254
- package/test/fork/TestSequencerPriceFeedFork.sol +0 -168
- package/test/fork/TestTerminalPreviewParityFork.sol +0 -108
- package/test/formal/BondingCurveProperties.t.sol +0 -420
- package/test/formal/FeeProperties.t.sol +0 -252
- package/test/invariants/Phase3DeepInvariant.t.sol +0 -412
- package/test/invariants/RulesetsInvariant.t.sol +0 -125
- package/test/invariants/TerminalStoreInvariant.t.sol +0 -227
- package/test/invariants/TokensInvariant.t.sol +0 -195
- package/test/invariants/handlers/ComprehensiveHandler.sol +0 -303
- package/test/invariants/handlers/EconomicHandler.sol +0 -377
- package/test/invariants/handlers/Phase3Handler.sol +0 -443
- package/test/invariants/handlers/RulesetsHandler.sol +0 -115
- package/test/invariants/handlers/TerminalStoreHandler.sol +0 -151
- package/test/invariants/handlers/TokensHandler.sol +0 -126
- package/test/regression/HoldFeesCashOutReserved.t.sol +0 -415
- package/test/regression/WeightCacheBoundary.t.sol +0 -291
- package/test/trees/JBController/burnTokensOf.tree +0 -9
- package/test/trees/JBController/claimTokensFor.tree +0 -5
- package/test/trees/JBController/deployERC20For.tree +0 -5
- package/test/trees/JBController/getRulesetOf.tree +0 -5
- package/test/trees/JBController/launchProjectFor.tree +0 -12
- package/test/trees/JBController/launchRulesetsFor.tree +0 -8
- package/test/trees/JBController/migrateController.tree +0 -12
- package/test/trees/JBController/mintTokensOf.tree +0 -12
- package/test/trees/JBController/payReservedTokenToTerminal.tree +0 -8
- package/test/trees/JBController/receiveMigrationFrom.tree +0 -4
- package/test/trees/JBController/sendReservedTokensToSplitsOf.tree +0 -12
- package/test/trees/JBController/setMetadataOf.tree +0 -5
- package/test/trees/JBController/setSplitGroupsOf.tree +0 -5
- package/test/trees/JBController/setTokenFor.tree +0 -5
- package/test/trees/JBController/transferCreditsFrom.tree +0 -8
- package/test/trees/JBDirectory/primaryTerminalOf.tree +0 -8
- package/test/trees/JBDirectory/setControllerOf.tree +0 -11
- package/test/trees/JBDirectory/setPrimaryTerminalOf.tree +0 -15
- package/test/trees/JBDirectory/setTerminalsOf.tree +0 -11
- package/test/trees/JBERC20/initialize.tree +0 -7
- package/test/trees/JBERC20/name.tree +0 -5
- package/test/trees/JBERC20/nonces.tree +0 -5
- package/test/trees/JBERC20/symbol.tree +0 -5
- package/test/trees/JBFeelessAddresses/setFeelessAddress.tree +0 -5
- package/test/trees/JBFeelessAddresses/supportsInterface.tree +0 -5
- package/test/trees/JBFundAccessLimits/payoutLimitOf.tree +0 -5
- package/test/trees/JBFundAccessLimits/payoutLimitsOf.tree +0 -8
- package/test/trees/JBFundAccessLimits/setFundAccessLimitsFor.tree +0 -18
- package/test/trees/JBFundAccessLimits/surplusAllowanceOf.tree +0 -5
- package/test/trees/JBFundAccessLimits/surplusAllowancesOf.tree +0 -8
- package/test/trees/JBMetadataResolver/getDataFor.tree +0 -8
- package/test/trees/JBMultiTerminal/accountingContextsOf.tree +0 -5
- package/test/trees/JBMultiTerminal/addAccountingContextsFor.tree +0 -10
- package/test/trees/JBMultiTerminal/addToBalanceOf.tree +0 -23
- package/test/trees/JBMultiTerminal/cashOutTokensOf.tree +0 -23
- package/test/trees/JBMultiTerminal/executePayout.tree +0 -32
- package/test/trees/JBMultiTerminal/executeProcessFee.tree +0 -14
- package/test/trees/JBMultiTerminal/migrateBalanceOf.tree +0 -12
- package/test/trees/JBMultiTerminal/pay.tree +0 -23
- package/test/trees/JBMultiTerminal/processHeldFeesOf.tree +0 -8
- package/test/trees/JBMultiTerminal/sendPayoutsOf.tree +0 -34
- package/test/trees/JBMultiTerminal/useAllowanceOf.tree +0 -16
- package/test/trees/JBPermissions/hasPermission.tree +0 -8
- package/test/trees/JBPermissions/hasPermissions.tree +0 -8
- package/test/trees/JBPermissions/setPermissionsFor.tree +0 -5
- package/test/trees/JBPrices/addPriceFeedFor.tree +0 -14
- package/test/trees/JBPrices/pricePerUnitOf.tree +0 -11
- package/test/trees/JBProjects/createFor.tree +0 -11
- package/test/trees/JBProjects/setTokenUriResolver.tree +0 -5
- package/test/trees/JBProjects/supportsInterface.tree +0 -9
- package/test/trees/JBProjects/tokenURI.tree +0 -5
- package/test/trees/JBRulesets/currentApprovalStatusForLatestRulesetOf.tree +0 -8
- package/test/trees/JBRulesets/currentOf.tree +0 -12
- package/test/trees/JBRulesets/getRulesetOf.tree +0 -5
- package/test/trees/JBRulesets/latestQueuedRulesetOf.tree +0 -10
- package/test/trees/JBRulesets/rulesetsOf.tree +0 -11
- package/test/trees/JBRulesets/upcomingRulesetOf.tree +0 -20
- package/test/trees/JBRulesets/updateRulesetWeightCache.tree +0 -5
- package/test/trees/JBSplits/setSplitGroupsOf.tree +0 -17
- package/test/trees/JBSplits/splitsOf.tree +0 -5
- package/test/trees/JBTerminalStore/currentReclaimableSurplusOf.tree +0 -16
- package/test/trees/JBTerminalStore/currentSurplusOf.tree +0 -25
- package/test/trees/JBTerminalStore/currentTotalSurplusOf.tree +0 -5
- package/test/trees/JBTerminalStore/recordCashOutsFor.tree +0 -16
- package/test/trees/JBTerminalStore/recordPaymentFrom.tree +0 -14
- package/test/trees/JBTerminalStore/recordPayoutFor.tree +0 -10
- package/test/trees/JBTerminalStore/recordTerminalMigration.tree +0 -5
- package/test/trees/JBTerminalStore/recordUsedAllowanceOf.tree +0 -10
- package/test/trees/JBTokens/burnFrom.tree +0 -10
- package/test/trees/JBTokens/claimTokensFor.tree +0 -10
- package/test/trees/JBTokens/deployERC20For.tree +0 -12
- package/test/trees/JBTokens/mintFor.tree +0 -10
- package/test/trees/JBTokens/setTokenFor.tree +0 -11
- package/test/trees/JBTokens/totalBalanceOf.tree +0 -5
- package/test/trees/JBTokens/totalSupplyOf.tree +0 -5
- package/test/trees/JBTokens/transferCreditsFrom.tree +0 -8
- package/test/trees/mintTokensOf.tree +0 -12
- package/test/units/static/JBChainlinkV3PriceFeed/TestPriceFeed.sol +0 -223
- package/test/units/static/JBController/JBControllerSetup.sol +0 -50
- package/test/units/static/JBController/TestBurnTokensOf.sol +0 -114
- package/test/units/static/JBController/TestClaimTokensFor.sol +0 -63
- package/test/units/static/JBController/TestDeployErc20For.sol +0 -86
- package/test/units/static/JBController/TestLaunchProjectFor.sol +0 -302
- package/test/units/static/JBController/TestLaunchRulesetsFor.sol +0 -342
- package/test/units/static/JBController/TestMigrateController.sol +0 -157
- package/test/units/static/JBController/TestMintTokensOfUnits.sol +0 -111
- package/test/units/static/JBController/TestOmnichainRulesetOperator.sol +0 -324
- package/test/units/static/JBController/TestPayReservedTokenToTerminal.sol +0 -74
- package/test/units/static/JBController/TestPreviewMintOf.sol +0 -117
- package/test/units/static/JBController/TestReceiveMigrationFrom.sol +0 -99
- package/test/units/static/JBController/TestRulesetViews.sol +0 -225
- package/test/units/static/JBController/TestSendReservedTokensToSplitsOf.sol +0 -615
- package/test/units/static/JBController/TestSetSplitGroupsOf.sol +0 -68
- package/test/units/static/JBController/TestSetTokenFor.sol +0 -239
- package/test/units/static/JBController/TestSetUriOf.sol +0 -57
- package/test/units/static/JBController/TestTransferCreditsFrom.sol +0 -169
- package/test/units/static/JBDeadline/TestDeadlineFuzz.sol +0 -211
- package/test/units/static/JBDirectory/JBDirectorySetup.sol +0 -26
- package/test/units/static/JBDirectory/TestPrimaryTerminalOf.sol +0 -126
- package/test/units/static/JBDirectory/TestSetControllerOf.sol +0 -183
- package/test/units/static/JBDirectory/TestSetControllerOfMigrationOrder.sol +0 -104
- package/test/units/static/JBDirectory/TestSetPrimaryTerminalOf.sol +0 -179
- package/test/units/static/JBDirectory/TestSetTerminalsOf.sol +0 -137
- package/test/units/static/JBERC20/JBERC20Setup.sol +0 -34
- package/test/units/static/JBERC20/SigUtils.sol +0 -36
- package/test/units/static/JBERC20/TestInitialize.sol +0 -60
- package/test/units/static/JBERC20/TestName.sol +0 -30
- package/test/units/static/JBERC20/TestNonces.sol +0 -62
- package/test/units/static/JBERC20/TestSymbol.sol +0 -31
- package/test/units/static/JBFeelessAdresses/JBFeelessSetup.sol +0 -22
- package/test/units/static/JBFeelessAdresses/TestInterfaces.sol +0 -30
- package/test/units/static/JBFeelessAdresses/TestSetFeelessAddress.sol +0 -35
- package/test/units/static/JBFees/TestFeesFuzz.sol +0 -79
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimals.sol +0 -16
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimalsFuzz.sol +0 -71
- package/test/units/static/JBFundAccessLimits/JBFundAccessSetup.sol +0 -24
- package/test/units/static/JBFundAccessLimits/TestFundAccessLimitsEdge.sol +0 -163
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitOf.sol +0 -59
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitsOf.sol +0 -101
- package/test/units/static/JBFundAccessLimits/TestSetFundAccessLimitsFor.sol +0 -189
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowanceOf.sol +0 -64
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowancesOf.sol +0 -102
- package/test/units/static/JBMetadataResolver/TestGetDataFor.sol +0 -90
- package/test/units/static/JBMetadataResolver/TestMetadataResolverEdgeCases.sol +0 -247
- package/test/units/static/JBMetadataResolver/TestMetadataResolverFuzz.sol +0 -229
- package/test/units/static/JBMultiTerminal/JBMultiTerminalSetup.sol +0 -50
- package/test/units/static/JBMultiTerminal/TestAccountingContextsOf.sol +0 -72
- package/test/units/static/JBMultiTerminal/TestAddAccountingContextsFor.sol +0 -289
- package/test/units/static/JBMultiTerminal/TestAddToBalanceOf.sol +0 -474
- package/test/units/static/JBMultiTerminal/TestCashOutTokensOf.sol +0 -624
- package/test/units/static/JBMultiTerminal/TestExecutePayout.sol +0 -578
- package/test/units/static/JBMultiTerminal/TestExecuteProcessFee.sol +0 -202
- package/test/units/static/JBMultiTerminal/TestMigrateBalanceOf.sol +0 -222
- package/test/units/static/JBMultiTerminal/TestPay.sol +0 -604
- package/test/units/static/JBMultiTerminal/TestPreviewCashOutFrom.sol +0 -117
- package/test/units/static/JBMultiTerminal/TestPreviewPayFor.sol +0 -114
- package/test/units/static/JBMultiTerminal/TestProcessHeldFeesOf.sol +0 -228
- package/test/units/static/JBMultiTerminal/TestSelfPayRevert.sol +0 -55
- package/test/units/static/JBMultiTerminal/TestSendPayoutsOf.sol +0 -257
- package/test/units/static/JBMultiTerminal/TestUseAllowanceOf.sol +0 -611
- package/test/units/static/JBPermissions/JBPermissionsSetup.sol +0 -20
- package/test/units/static/JBPermissions/TestHasPermission.sol +0 -50
- package/test/units/static/JBPermissions/TestHasPermissions.sol +0 -93
- package/test/units/static/JBPermissions/TestSetPermissionsFor.sol +0 -64
- package/test/units/static/JBPrices/JBPricesSetup.sol +0 -32
- package/test/units/static/JBPrices/TestAddPriceFeedFor.sol +0 -107
- package/test/units/static/JBPrices/TestPricePerUnitOf.sol +0 -132
- package/test/units/static/JBPrices/TestPrices.sol +0 -265
- package/test/units/static/JBProjects/JBProjectsSetup.sol +0 -22
- package/test/units/static/JBProjects/TestCreateFor.sol +0 -71
- package/test/units/static/JBProjects/TestInitialProject.sol +0 -21
- package/test/units/static/JBProjects/TestInterfaces.sol +0 -26
- package/test/units/static/JBProjects/TestSetResolver.sol +0 -37
- package/test/units/static/JBProjects/TestTokenUri.sol +0 -40
- package/test/units/static/JBRulesetMetadataResolver/TestSetCashOutTaxRateTo.sol +0 -108
- package/test/units/static/JBRulesets/JBRulesetsSetup.sol +0 -24
- package/test/units/static/JBRulesets/TestCurrentApprovalStatusForLatestRulesetOf.sol +0 -265
- package/test/units/static/JBRulesets/TestCurrentOf.sol +0 -242
- package/test/units/static/JBRulesets/TestGetRulesetOf.sol +0 -100
- package/test/units/static/JBRulesets/TestLatestQueuedRulesetOf.sol +0 -260
- package/test/units/static/JBRulesets/TestRulesets.sol +0 -632
- package/test/units/static/JBRulesets/TestRulesetsOf.sol +0 -37
- package/test/units/static/JBRulesets/TestUpcomingRulesetOf.sol +0 -522
- package/test/units/static/JBRulesets/TestUpdateRulesetWeightCache.sol +0 -96
- package/test/units/static/JBSplits/JBSplitsSetup.sol +0 -26
- package/test/units/static/JBSplits/TestSelfManagedSplitGroups.sol +0 -552
- package/test/units/static/JBSplits/TestSetSplitGroupsOf.sol +0 -377
- package/test/units/static/JBSplits/TestSplitsLockedEdge.sol +0 -267
- package/test/units/static/JBSplits/TestSplitsOf.sol +0 -24
- package/test/units/static/JBSplits/TestSplitsPacking.sol +0 -36
- package/test/units/static/JBSurplus/TestSurplusFuzz.sol +0 -160
- package/test/units/static/JBTerminalStore/JBTerminalStoreSetup.sol +0 -45
- package/test/units/static/JBTerminalStore/TestCurrentReclaimableSurplusOf.sol +0 -536
- package/test/units/static/JBTerminalStore/TestCurrentSurplusOf.sol +0 -463
- package/test/units/static/JBTerminalStore/TestCurrentTotalSurplusOf.sol +0 -135
- package/test/units/static/JBTerminalStore/TestPreviewCashOutFrom.sol +0 -476
- package/test/units/static/JBTerminalStore/TestPreviewPayFrom.sol +0 -494
- package/test/units/static/JBTerminalStore/TestRecordCashOutsFor.sol +0 -652
- package/test/units/static/JBTerminalStore/TestRecordPaymentFrom.sol +0 -744
- package/test/units/static/JBTerminalStore/TestRecordPayoutFor.sol +0 -289
- package/test/units/static/JBTerminalStore/TestRecordTerminalMigration.sol +0 -138
- package/test/units/static/JBTerminalStore/TestRecordUsedAllowanceOf.sol +0 -415
- package/test/units/static/JBTerminalStore/TestUint224Overflow.sol +0 -219
- package/test/units/static/JBTokens/JBTokensSetup.sol +0 -32
- package/test/units/static/JBTokens/TestBurnFrom.sol +0 -107
- package/test/units/static/JBTokens/TestClaimTokensFor.sol +0 -110
- package/test/units/static/JBTokens/TestDeployERC20ForUnits.sol +0 -92
- package/test/units/static/JBTokens/TestMintFor.sol +0 -100
- package/test/units/static/JBTokens/TestSetTokenFor.sol +0 -98
- package/test/units/static/JBTokens/TestTotalBalanceOf.sol +0 -65
- package/test/units/static/JBTokens/TestTotalSupplyOf.sol +0 -56
- package/test/units/static/JBTokens/TestTransferCreditsFrom.sol +0 -56
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {JBMultiTerminal} from "../../../../src/JBMultiTerminal.sol";
|
|
5
|
-
import {IJBCashOutHook} from "../../../../src/interfaces/IJBCashOutHook.sol";
|
|
6
|
-
import {IJBDirectory} from "../../../../src/interfaces/IJBDirectory.sol";
|
|
7
|
-
import {IJBFeelessAddresses} from "../../../../src/interfaces/IJBFeelessAddresses.sol";
|
|
8
|
-
import {IJBRulesetApprovalHook} from "../../../../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
9
|
-
import {IJBTerminalStore} from "../../../../src/interfaces/IJBTerminalStore.sol";
|
|
10
|
-
import {JBConstants} from "../../../../src/libraries/JBConstants.sol";
|
|
11
|
-
import {JBAccountingContext} from "../../../../src/structs/JBAccountingContext.sol";
|
|
12
|
-
import {JBCashOutHookSpecification} from "../../../../src/structs/JBCashOutHookSpecification.sol";
|
|
13
|
-
import {JBRuleset} from "../../../../src/structs/JBRuleset.sol";
|
|
14
|
-
import {IERC721} from "@openzeppelin/contracts/token/ERC721/IERC721.sol";
|
|
15
|
-
import {JBMultiTerminalSetup} from "./JBMultiTerminalSetup.sol";
|
|
16
|
-
|
|
17
|
-
contract TestPreviewCashOutFrom_Local is JBMultiTerminalSetup {
|
|
18
|
-
uint256 _projectId = 1;
|
|
19
|
-
uint256 _cashOutCount = 1e18;
|
|
20
|
-
address _holder = makeAddr("holder");
|
|
21
|
-
address payable _beneficiary = payable(makeAddr("beneficiary"));
|
|
22
|
-
address _token = JBConstants.NATIVE_TOKEN;
|
|
23
|
-
|
|
24
|
-
function setUp() public {
|
|
25
|
-
super.multiTerminalSetup();
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
function _acceptToken(address token, uint8 decimals, uint32 currency) internal {
|
|
29
|
-
mockExpect(address(projects), abi.encodeCall(IERC721.ownerOf, (_projectId)), abi.encode(address(0)));
|
|
30
|
-
mockExpect(
|
|
31
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
32
|
-
);
|
|
33
|
-
|
|
34
|
-
JBAccountingContext[] memory contexts = new JBAccountingContext[](1);
|
|
35
|
-
contexts[0] = JBAccountingContext({token: token, decimals: decimals, currency: currency});
|
|
36
|
-
|
|
37
|
-
// Mock recordAccountingContextOf in the store (validation now happens there)
|
|
38
|
-
mockExpect(
|
|
39
|
-
address(store), abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, contexts)), ""
|
|
40
|
-
);
|
|
41
|
-
|
|
42
|
-
vm.prank(address(this));
|
|
43
|
-
_terminal.addAccountingContextsFor(_projectId, contexts);
|
|
44
|
-
|
|
45
|
-
// Mock accountingContextOf for subsequent reads (not all code paths call it, so use mockCall only)
|
|
46
|
-
vm.mockCall(
|
|
47
|
-
address(store),
|
|
48
|
-
abi.encodeCall(IJBTerminalStore.accountingContextOf, (address(_terminal), _projectId, token)),
|
|
49
|
-
abi.encode(contexts[0])
|
|
50
|
-
);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
function test_RevertsWhenTokenIsNotAccepted() external {
|
|
54
|
-
// previewCashOutFrom now delegates directly to the store without a token acceptance check,
|
|
55
|
-
// so it reverts during store computation (e.g. unmocked external call) rather than with TokenNotAccepted.
|
|
56
|
-
vm.expectRevert();
|
|
57
|
-
JBMultiTerminal(address(_terminal))
|
|
58
|
-
.previewCashOutFrom(_holder, _projectId, _cashOutCount, _token, _beneficiary, "");
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
function test_ReturnsRulesetAndCashOutPreviewValues() external {
|
|
62
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
63
|
-
_acceptToken(_token, 18, uint32(uint160(_token)));
|
|
64
|
-
|
|
65
|
-
JBRuleset memory ruleset = JBRuleset({
|
|
66
|
-
cycleNumber: 1,
|
|
67
|
-
id: 1,
|
|
68
|
-
basedOnId: 0,
|
|
69
|
-
start: uint48(block.timestamp),
|
|
70
|
-
duration: 0,
|
|
71
|
-
weight: 0,
|
|
72
|
-
weightCutPercent: 0,
|
|
73
|
-
approvalHook: IJBRulesetApprovalHook(address(0)),
|
|
74
|
-
metadata: 0
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
JBCashOutHookSpecification[] memory specs = new JBCashOutHookSpecification[](1);
|
|
78
|
-
specs[0] = JBCashOutHookSpecification({
|
|
79
|
-
hook: IJBCashOutHook(makeAddr("hook")), noop: false, amount: 321, metadata: hex"5678"
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
JBAccountingContext memory accountingContext =
|
|
83
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
84
|
-
JBAccountingContext({token: _token, decimals: 18, currency: uint32(uint160(_token))});
|
|
85
|
-
JBAccountingContext[] memory accountingContexts = new JBAccountingContext[](1);
|
|
86
|
-
accountingContexts[0] = accountingContext;
|
|
87
|
-
|
|
88
|
-
mockExpect(
|
|
89
|
-
address(feelessAddresses), abi.encodeCall(IJBFeelessAddresses.isFeeless, (_beneficiary)), abi.encode(true)
|
|
90
|
-
);
|
|
91
|
-
|
|
92
|
-
mockExpect(
|
|
93
|
-
address(store),
|
|
94
|
-
abi.encodeCall(
|
|
95
|
-
IJBTerminalStore.previewCashOutFrom,
|
|
96
|
-
(address(_terminal), _holder, _projectId, _cashOutCount, accountingContext.token, true, bytes(""))
|
|
97
|
-
),
|
|
98
|
-
abi.encode(ruleset, 999, 1234, specs)
|
|
99
|
-
);
|
|
100
|
-
|
|
101
|
-
(
|
|
102
|
-
JBRuleset memory previewRuleset,
|
|
103
|
-
uint256 reclaimAmount,
|
|
104
|
-
uint256 cashOutTaxRate,
|
|
105
|
-
JBCashOutHookSpecification[] memory previewSpecs
|
|
106
|
-
) = JBMultiTerminal(address(_terminal))
|
|
107
|
-
.previewCashOutFrom(_holder, _projectId, _cashOutCount, _token, _beneficiary, "");
|
|
108
|
-
|
|
109
|
-
assertEq(previewRuleset.id, ruleset.id);
|
|
110
|
-
assertEq(reclaimAmount, 999);
|
|
111
|
-
assertEq(cashOutTaxRate, 1234);
|
|
112
|
-
assertEq(previewSpecs.length, 1);
|
|
113
|
-
assertEq(address(previewSpecs[0].hook), address(specs[0].hook));
|
|
114
|
-
assertEq(previewSpecs[0].amount, specs[0].amount);
|
|
115
|
-
assertEq(previewSpecs[0].metadata, specs[0].metadata);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {JBMultiTerminal} from "../../../../src/JBMultiTerminal.sol";
|
|
5
|
-
import {IJBController} from "../../../../src/interfaces/IJBController.sol";
|
|
6
|
-
import {IJBDirectory} from "../../../../src/interfaces/IJBDirectory.sol";
|
|
7
|
-
import {IJBPayHook} from "../../../../src/interfaces/IJBPayHook.sol";
|
|
8
|
-
import {IJBRulesetApprovalHook} from "../../../../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
9
|
-
import {IJBTerminalStore} from "../../../../src/interfaces/IJBTerminalStore.sol";
|
|
10
|
-
import {JBConstants} from "../../../../src/libraries/JBConstants.sol";
|
|
11
|
-
import {JBAccountingContext} from "../../../../src/structs/JBAccountingContext.sol";
|
|
12
|
-
import {JBPayHookSpecification} from "../../../../src/structs/JBPayHookSpecification.sol";
|
|
13
|
-
import {JBRuleset} from "../../../../src/structs/JBRuleset.sol";
|
|
14
|
-
import {JBTokenAmount} from "../../../../src/structs/JBTokenAmount.sol";
|
|
15
|
-
import {JBMultiTerminalSetup} from "./JBMultiTerminalSetup.sol";
|
|
16
|
-
|
|
17
|
-
contract TestPreviewPayFor_Local is JBMultiTerminalSetup {
|
|
18
|
-
uint256 _projectId = 1;
|
|
19
|
-
uint256 _amount = 1e18;
|
|
20
|
-
address _token = JBConstants.NATIVE_TOKEN;
|
|
21
|
-
address _beneficiary = makeAddr("beneficiary");
|
|
22
|
-
address _payer = makeAddr("payer");
|
|
23
|
-
IJBController _controller = IJBController(makeAddr("controller"));
|
|
24
|
-
|
|
25
|
-
function setUp() public {
|
|
26
|
-
super.multiTerminalSetup();
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
function _setAccountingContext(address token, uint8 decimals, uint32 currency) internal {
|
|
30
|
-
// Mock the store to return this accounting context
|
|
31
|
-
mockExpect(
|
|
32
|
-
address(store),
|
|
33
|
-
abi.encodeCall(IJBTerminalStore.accountingContextOf, (address(_terminal), _projectId, token)),
|
|
34
|
-
abi.encode(JBAccountingContext({token: token, decimals: decimals, currency: currency}))
|
|
35
|
-
);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
function test_RevertsWhenTokenIsNotAccepted() external {
|
|
39
|
-
// Mock accountingContextOf to return empty context (token not accepted)
|
|
40
|
-
mockExpect(
|
|
41
|
-
address(store),
|
|
42
|
-
abi.encodeCall(IJBTerminalStore.accountingContextOf, (address(_terminal), _projectId, _token)),
|
|
43
|
-
abi.encode(JBAccountingContext({token: address(0), decimals: 0, currency: 0}))
|
|
44
|
-
);
|
|
45
|
-
|
|
46
|
-
vm.prank(_payer);
|
|
47
|
-
vm.expectRevert(abi.encodeWithSelector(JBMultiTerminal.JBMultiTerminal_TokenNotAccepted.selector, _token));
|
|
48
|
-
JBMultiTerminal(address(_terminal)).previewPayFor(_projectId, _token, _amount, _beneficiary, "");
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
function test_ReturnsRulesetMintSplitAndHookSpecifications() external {
|
|
52
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
53
|
-
_setAccountingContext(_token, 18, uint32(uint160(_token)));
|
|
54
|
-
|
|
55
|
-
_mockPreviewPayFrom();
|
|
56
|
-
|
|
57
|
-
vm.prank(_payer);
|
|
58
|
-
(
|
|
59
|
-
JBRuleset memory previewRuleset,
|
|
60
|
-
uint256 beneficiaryTokenCount,
|
|
61
|
-
uint256 reservedTokenCount,
|
|
62
|
-
JBPayHookSpecification[] memory previewSpecs
|
|
63
|
-
) = JBMultiTerminal(address(_terminal)).previewPayFor(_projectId, _token, _amount, _beneficiary, "");
|
|
64
|
-
|
|
65
|
-
assertEq(previewRuleset.id, 1);
|
|
66
|
-
assertEq(beneficiaryTokenCount, 750);
|
|
67
|
-
assertEq(reservedTokenCount, 250);
|
|
68
|
-
assertEq(previewSpecs.length, 1);
|
|
69
|
-
assertEq(previewSpecs[0].amount, 123);
|
|
70
|
-
assertEq(previewSpecs[0].metadata, hex"1234");
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
function _mockPreviewPayFrom() internal {
|
|
74
|
-
JBRuleset memory ruleset = JBRuleset({
|
|
75
|
-
cycleNumber: 1,
|
|
76
|
-
id: 1,
|
|
77
|
-
basedOnId: 0,
|
|
78
|
-
start: uint48(block.timestamp),
|
|
79
|
-
duration: 0,
|
|
80
|
-
weight: 0,
|
|
81
|
-
weightCutPercent: 0,
|
|
82
|
-
approvalHook: IJBRulesetApprovalHook(address(0)),
|
|
83
|
-
metadata: 0
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
JBPayHookSpecification[] memory specs = new JBPayHookSpecification[](1);
|
|
87
|
-
specs[0] =
|
|
88
|
-
JBPayHookSpecification({hook: IJBPayHook(makeAddr("hook")), noop: false, amount: 123, metadata: hex"1234"});
|
|
89
|
-
|
|
90
|
-
JBTokenAmount memory tokenAmount =
|
|
91
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
92
|
-
JBTokenAmount({token: _token, decimals: 18, currency: uint32(uint160(_token)), value: _amount});
|
|
93
|
-
|
|
94
|
-
mockExpect(
|
|
95
|
-
address(store),
|
|
96
|
-
abi.encodeWithSelector(
|
|
97
|
-
bytes4(0xdb6d7e03), address(_terminal), _payer, tokenAmount, _projectId, _beneficiary, bytes("")
|
|
98
|
-
),
|
|
99
|
-
abi.encode(ruleset, 1000, specs)
|
|
100
|
-
);
|
|
101
|
-
|
|
102
|
-
mockExpect(
|
|
103
|
-
address(directory),
|
|
104
|
-
abi.encodeCall(IJBDirectory.controllerOf, (_projectId)),
|
|
105
|
-
abi.encode(address(_controller))
|
|
106
|
-
);
|
|
107
|
-
|
|
108
|
-
mockExpect(
|
|
109
|
-
address(_controller),
|
|
110
|
-
abi.encodeCall(IJBController.previewMintOf, (_projectId, 1000, true)),
|
|
111
|
-
abi.encode(750, 250)
|
|
112
|
-
);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
@@ -1,228 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {JBMultiTerminal} from "../../../../src/JBMultiTerminal.sol";
|
|
5
|
-
import {IJBDirectory} from "../../../../src/interfaces/IJBDirectory.sol";
|
|
6
|
-
import {IJBFeeTerminal} from "../../../../src/interfaces/IJBFeeTerminal.sol";
|
|
7
|
-
import {IJBFeelessAddresses} from "../../../../src/interfaces/IJBFeelessAddresses.sol";
|
|
8
|
-
import {IJBPermissions} from "../../../../src/interfaces/IJBPermissions.sol";
|
|
9
|
-
import {IJBProjects} from "../../../../src/interfaces/IJBProjects.sol";
|
|
10
|
-
import {IJBRulesetApprovalHook} from "../../../../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
11
|
-
import {IJBRulesets} from "../../../../src/interfaces/IJBRulesets.sol";
|
|
12
|
-
import {IJBSplits} from "../../../../src/interfaces/IJBSplits.sol";
|
|
13
|
-
import {IJBTerminalStore} from "../../../../src/interfaces/IJBTerminalStore.sol";
|
|
14
|
-
import {IJBTokens} from "../../../../src/interfaces/IJBTokens.sol";
|
|
15
|
-
import {JBFees} from "../../../../src/libraries/JBFees.sol";
|
|
16
|
-
import {JBAccountingContext} from "../../../../src/structs/JBAccountingContext.sol";
|
|
17
|
-
import {JBFee} from "../../../../src/structs/JBFee.sol";
|
|
18
|
-
import {JBPayHookSpecification} from "../../../../src/structs/JBPayHookSpecification.sol";
|
|
19
|
-
import {JBRuleset} from "../../../../src/structs/JBRuleset.sol";
|
|
20
|
-
import {IPermit2} from "@uniswap/permit2/src/interfaces/IPermit2.sol";
|
|
21
|
-
import {JBTest} from "../../../helpers/JBTest.sol";
|
|
22
|
-
|
|
23
|
-
/// @dev Harness that exposes internal held fee storage for direct manipulation in tests.
|
|
24
|
-
contract ForTest_JBMultiTerminal is JBMultiTerminal {
|
|
25
|
-
constructor(
|
|
26
|
-
IJBFeelessAddresses feelessAddresses,
|
|
27
|
-
IJBPermissions permissions,
|
|
28
|
-
IJBProjects projects,
|
|
29
|
-
IJBSplits splits,
|
|
30
|
-
IJBTerminalStore store,
|
|
31
|
-
IJBTokens tokens,
|
|
32
|
-
IPermit2 permit2,
|
|
33
|
-
address trustedForwarder
|
|
34
|
-
)
|
|
35
|
-
JBMultiTerminal(feelessAddresses, permissions, projects, splits, store, tokens, permit2, trustedForwarder)
|
|
36
|
-
{}
|
|
37
|
-
|
|
38
|
-
function forTestAddHeldFee(uint256 projectId, address token, JBFee memory fee) external {
|
|
39
|
-
_heldFeesOf[projectId][token].push(fee);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
function forTestSetNextHeldFeeIndex(uint256 projectId, address token, uint256 index) external {
|
|
43
|
-
_nextHeldFeeIndexOf[projectId][token] = index;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
contract TestProcessHeldFeesOf_Local is JBTest {
|
|
48
|
-
// Target Contract (harness)
|
|
49
|
-
ForTest_JBMultiTerminal public _terminal;
|
|
50
|
-
|
|
51
|
-
// Mocks
|
|
52
|
-
IJBPermissions public permissions = IJBPermissions(makeAddr("permissions"));
|
|
53
|
-
IJBProjects public projects = IJBProjects(makeAddr("projects"));
|
|
54
|
-
IJBDirectory public directory = IJBDirectory(makeAddr("directory"));
|
|
55
|
-
IJBRulesets public rulesets = IJBRulesets(makeAddr("rulesets"));
|
|
56
|
-
IJBTokens public tokens = IJBTokens(makeAddr("tokens"));
|
|
57
|
-
IJBSplits public splits = IJBSplits(makeAddr("splits"));
|
|
58
|
-
IJBTerminalStore public store = IJBTerminalStore(makeAddr("store"));
|
|
59
|
-
IJBFeelessAddresses public feelessAddresses = IJBFeelessAddresses(makeAddr("feeless"));
|
|
60
|
-
IPermit2 public permit2 = IPermit2(makeAddr("permit2"));
|
|
61
|
-
address trustedForwarder = makeAddr("forwarder");
|
|
62
|
-
|
|
63
|
-
uint256 _feeProjectId = 1;
|
|
64
|
-
uint256 _projectId = 2;
|
|
65
|
-
address _mockToken = makeAddr("token");
|
|
66
|
-
address _beneficiary = makeAddr("beneficiary");
|
|
67
|
-
|
|
68
|
-
function _setAccountingContext(uint256 projectId, address token, uint8 decimals, uint32 currency) internal {
|
|
69
|
-
// Mock the store to return this accounting context
|
|
70
|
-
mockExpect(
|
|
71
|
-
address(store),
|
|
72
|
-
abi.encodeCall(IJBTerminalStore.accountingContextOf, (address(_terminal), projectId, token)),
|
|
73
|
-
abi.encode(JBAccountingContext({token: token, decimals: decimals, currency: currency}))
|
|
74
|
-
);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
function setUp() public {
|
|
78
|
-
// Constructor will call to find directory from the terminal store
|
|
79
|
-
mockExpect(address(store), abi.encodeCall(IJBTerminalStore.DIRECTORY, ()), abi.encode(address(directory)));
|
|
80
|
-
|
|
81
|
-
_terminal = new ForTest_JBMultiTerminal(
|
|
82
|
-
feelessAddresses, permissions, projects, splits, store, tokens, permit2, trustedForwarder
|
|
83
|
-
);
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
function test_WhenHeldFeeUnlockTimestampGTBlocktimestamp() external {
|
|
87
|
-
// it will not process the fee (fee remains held)
|
|
88
|
-
|
|
89
|
-
// Add a held fee with unlockTimestamp in the future
|
|
90
|
-
uint48 futureTimestamp = uint48(block.timestamp + 1000);
|
|
91
|
-
_terminal.forTestAddHeldFee(
|
|
92
|
-
_projectId, _mockToken, JBFee({amount: 100, beneficiary: _beneficiary, unlockTimestamp: futureTimestamp})
|
|
93
|
-
);
|
|
94
|
-
|
|
95
|
-
// Mock the directory call to find the fee terminal (project 1 is the fee beneficiary)
|
|
96
|
-
mockExpect(
|
|
97
|
-
address(directory),
|
|
98
|
-
abi.encodeCall(IJBDirectory.primaryTerminalOf, (1, _mockToken)),
|
|
99
|
-
abi.encode(address(_terminal))
|
|
100
|
-
);
|
|
101
|
-
|
|
102
|
-
// Call processHeldFeesOf - the fee should NOT be processed because it's still locked
|
|
103
|
-
_terminal.processHeldFeesOf(_projectId, _mockToken, 1);
|
|
104
|
-
|
|
105
|
-
// Verify the fee is still held
|
|
106
|
-
JBFee[] memory remaining = _terminal.heldFeesOf(_projectId, _mockToken, 10);
|
|
107
|
-
assertEq(remaining.length, 1, "fee should still be held");
|
|
108
|
-
assertEq(remaining[0].amount, 100, "fee amount should be unchanged");
|
|
109
|
-
assertEq(remaining[0].unlockTimestamp, futureTimestamp, "unlock timestamp should be unchanged");
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
modifier whenHeldFeeIsUnlocked() {
|
|
113
|
-
_;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
function test_GivenExecuteProcessFeeSucceeds() external whenHeldFeeIsUnlocked {
|
|
117
|
-
// it will process the fee and emit ProcessFee
|
|
118
|
-
|
|
119
|
-
// Add a held fee that is already unlocked
|
|
120
|
-
uint48 pastTimestamp = uint48(block.timestamp - 1);
|
|
121
|
-
uint256 heldAmount = 1000;
|
|
122
|
-
_terminal.forTestAddHeldFee(
|
|
123
|
-
_projectId,
|
|
124
|
-
_mockToken,
|
|
125
|
-
JBFee({amount: heldAmount, beneficiary: _beneficiary, unlockTimestamp: pastTimestamp})
|
|
126
|
-
);
|
|
127
|
-
|
|
128
|
-
// The fee amount that will be calculated from the held amount
|
|
129
|
-
uint256 expectedFeeAmount = JBFees.feeAmountFrom({amountBeforeFee: heldAmount, feePercent: _terminal.FEE()});
|
|
130
|
-
|
|
131
|
-
// Set up accounting context for the fee beneficiary project (project 1) so _pay can build the token amount.
|
|
132
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
133
|
-
_setAccountingContext(_feeProjectId, _mockToken, 0, uint32(uint160(_mockToken)));
|
|
134
|
-
|
|
135
|
-
// Mock the directory call to find the fee terminal - return _terminal itself so it uses internal _pay
|
|
136
|
-
mockExpect(
|
|
137
|
-
address(directory),
|
|
138
|
-
abi.encodeCall(IJBDirectory.primaryTerminalOf, (1, _mockToken)),
|
|
139
|
-
abi.encode(address(_terminal))
|
|
140
|
-
);
|
|
141
|
-
|
|
142
|
-
// Mock executeProcessFee: when the terminal calls itself, it will call recordPaymentFrom on the store.
|
|
143
|
-
// Since executeProcessFee is external and calls pay on the feeTerminal (which is _terminal itself),
|
|
144
|
-
// we need to mock the internal pay path: recordPaymentFrom on the store.
|
|
145
|
-
vm.mockCall(
|
|
146
|
-
address(store),
|
|
147
|
-
abi.encodeWithSelector(IJBTerminalStore.recordPaymentFrom.selector),
|
|
148
|
-
abi.encode(
|
|
149
|
-
JBRuleset({
|
|
150
|
-
cycleNumber: 1,
|
|
151
|
-
id: 1,
|
|
152
|
-
basedOnId: 0,
|
|
153
|
-
start: 0,
|
|
154
|
-
duration: 0,
|
|
155
|
-
weight: 0,
|
|
156
|
-
weightCutPercent: 0,
|
|
157
|
-
approvalHook: IJBRulesetApprovalHook(address(0)),
|
|
158
|
-
metadata: 0
|
|
159
|
-
}),
|
|
160
|
-
uint256(0),
|
|
161
|
-
new JBPayHookSpecification[](0)
|
|
162
|
-
)
|
|
163
|
-
);
|
|
164
|
-
|
|
165
|
-
// Expect ProcessFee event
|
|
166
|
-
vm.expectEmit();
|
|
167
|
-
emit IJBFeeTerminal.ProcessFee({
|
|
168
|
-
projectId: _projectId,
|
|
169
|
-
token: _mockToken,
|
|
170
|
-
amount: expectedFeeAmount,
|
|
171
|
-
wasHeld: true,
|
|
172
|
-
beneficiary: _beneficiary,
|
|
173
|
-
caller: address(this)
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
_terminal.processHeldFeesOf(_projectId, _mockToken, 1);
|
|
177
|
-
|
|
178
|
-
// Verify held fees are cleaned up
|
|
179
|
-
JBFee[] memory remaining = _terminal.heldFeesOf(_projectId, _mockToken, 10);
|
|
180
|
-
assertEq(remaining.length, 0, "held fees should be empty after processing");
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
function test_GivenExecuteProcessFeeFails() external whenHeldFeeIsUnlocked {
|
|
184
|
-
// it will readd balance and emit FeeReverted
|
|
185
|
-
|
|
186
|
-
// Add a held fee that is already unlocked
|
|
187
|
-
uint48 pastTimestamp = uint48(block.timestamp - 1);
|
|
188
|
-
uint256 heldAmount = 1000;
|
|
189
|
-
_terminal.forTestAddHeldFee(
|
|
190
|
-
_projectId,
|
|
191
|
-
_mockToken,
|
|
192
|
-
JBFee({amount: heldAmount, beneficiary: _beneficiary, unlockTimestamp: pastTimestamp})
|
|
193
|
-
);
|
|
194
|
-
|
|
195
|
-
// The fee amount that will be calculated from the held amount
|
|
196
|
-
uint256 expectedFeeAmount = JBFees.feeAmountFrom({amountBeforeFee: heldAmount, feePercent: _terminal.FEE()});
|
|
197
|
-
|
|
198
|
-
// Mock the directory call to find the fee terminal - return address(0) which will cause
|
|
199
|
-
// executeProcessFee to revert with FeeTerminalNotFound
|
|
200
|
-
mockExpect(
|
|
201
|
-
address(directory), abi.encodeCall(IJBDirectory.primaryTerminalOf, (1, _mockToken)), abi.encode(address(0))
|
|
202
|
-
);
|
|
203
|
-
|
|
204
|
-
// Mock the recordAddedBalanceFor call that happens on fee revert (balance returned to project)
|
|
205
|
-
mockExpect(
|
|
206
|
-
address(store),
|
|
207
|
-
abi.encodeCall(IJBTerminalStore.recordAddedBalanceFor, (_projectId, _mockToken, expectedFeeAmount)),
|
|
208
|
-
abi.encode()
|
|
209
|
-
);
|
|
210
|
-
|
|
211
|
-
// Expect FeeReverted event
|
|
212
|
-
vm.expectEmit(true, true, true, false);
|
|
213
|
-
emit IJBFeeTerminal.FeeReverted({
|
|
214
|
-
projectId: _projectId,
|
|
215
|
-
token: _mockToken,
|
|
216
|
-
feeProjectId: 1,
|
|
217
|
-
amount: expectedFeeAmount,
|
|
218
|
-
reason: "",
|
|
219
|
-
caller: address(this)
|
|
220
|
-
});
|
|
221
|
-
|
|
222
|
-
_terminal.processHeldFeesOf(_projectId, _mockToken, 1);
|
|
223
|
-
|
|
224
|
-
// Verify held fees are cleaned up (entry was deleted even though fee processing failed)
|
|
225
|
-
JBFee[] memory remaining = _terminal.heldFeesOf(_projectId, _mockToken, 10);
|
|
226
|
-
assertEq(remaining.length, 0, "held fees should be empty after failed processing");
|
|
227
|
-
}
|
|
228
|
-
}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {JBMultiTerminal} from "../../../../src/JBMultiTerminal.sol";
|
|
5
|
-
import {IJBDirectory} from "../../../../src/interfaces/IJBDirectory.sol";
|
|
6
|
-
import {JBConstants} from "../../../../src/libraries/JBConstants.sol";
|
|
7
|
-
import {JBSplit} from "../../../../src/structs/JBSplit.sol";
|
|
8
|
-
import {IJBSplitHook} from "../../../../src/interfaces/IJBSplitHook.sol";
|
|
9
|
-
import {JBMultiTerminalSetup} from "./JBMultiTerminalSetup.sol";
|
|
10
|
-
|
|
11
|
-
/// @notice Tests that a pay-type split back into the same terminal reverts with MintNotAllowed.
|
|
12
|
-
contract TestSelfPayRevert_Local is JBMultiTerminalSetup {
|
|
13
|
-
uint64 _projectId = 1;
|
|
14
|
-
uint256 _defaultAmount = 1e18;
|
|
15
|
-
address _sender = makeAddr("sender");
|
|
16
|
-
address _native = JBConstants.NATIVE_TOKEN;
|
|
17
|
-
|
|
18
|
-
function setUp() public {
|
|
19
|
-
super.multiTerminalSetup();
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
/// @notice When a split routes a pay back to the same project on the same terminal,
|
|
23
|
-
/// executePayout should revert with MintNotAllowed.
|
|
24
|
-
function test_RevertWhen_SplitPaysBackToSameTerminal() external {
|
|
25
|
-
// Build a split targeting the SAME project with preferAddToBalance = false (pay path).
|
|
26
|
-
JBSplit memory split = JBSplit({
|
|
27
|
-
preferAddToBalance: false,
|
|
28
|
-
percent: 1_000_000_000,
|
|
29
|
-
projectId: _projectId,
|
|
30
|
-
beneficiary: payable(_sender),
|
|
31
|
-
lockedUntil: 0,
|
|
32
|
-
hook: IJBSplitHook(address(0))
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
// Mock primaryTerminalOf to return this terminal (self-referencing).
|
|
36
|
-
mockExpect(
|
|
37
|
-
address(directory),
|
|
38
|
-
abi.encodeCall(IJBDirectory.primaryTerminalOf, (_projectId, _native)),
|
|
39
|
-
abi.encode(address(_terminal))
|
|
40
|
-
);
|
|
41
|
-
|
|
42
|
-
// executePayout requires msg.sender == address(this), so we call it via the terminal.
|
|
43
|
-
// The terminal's try-catch in the split group lib would normally catch this.
|
|
44
|
-
vm.prank(address(_terminal));
|
|
45
|
-
vm.expectRevert(JBMultiTerminal.JBMultiTerminal_MintNotAllowed.selector);
|
|
46
|
-
JBMultiTerminal(payable(address(_terminal)))
|
|
47
|
-
.executePayout({
|
|
48
|
-
split: split,
|
|
49
|
-
projectId: uint256(_projectId),
|
|
50
|
-
token: _native,
|
|
51
|
-
amount: _defaultAmount,
|
|
52
|
-
originalMessageSender: _sender
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
}
|