@bananapus/core-v6 0.0.37 → 0.0.38
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/JBController.sol +19 -1
- package/src/JBMultiTerminal.sol +68 -34
- package/src/JBTerminalStore.sol +6 -6
- package/src/interfaces/IJBController.sol +4 -1
- package/src/libraries/JBFees.sol +47 -9
- package/src/libraries/JBPayoutSplitGroupLib.sol +2 -2
- package/src/periphery/JBMatchingPriceFeed.sol +1 -1
- 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,303 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity >=0.8.6;
|
|
3
|
-
|
|
4
|
-
import {TestBaseWorkflow} from "./helpers/TestBaseWorkflow.sol";
|
|
5
|
-
import {JBApprovalStatus} from "../src/enums/JBApprovalStatus.sol";
|
|
6
|
-
import {IJBController} from "../src/interfaces/IJBController.sol";
|
|
7
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
8
|
-
import {IJBRulesets} from "../src/interfaces/IJBRulesets.sol";
|
|
9
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
10
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
11
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
12
|
-
import {JBRuleset} from "../src/structs/JBRuleset.sol";
|
|
13
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
14
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
15
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
16
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
17
|
-
import {IERC165} from "@openzeppelin/contracts/utils/introspection/ERC165.sol";
|
|
18
|
-
|
|
19
|
-
/// @notice Mock approval hook that ALWAYS rejects queued rulesets.
|
|
20
|
-
contract AlwaysRejectApprovalHook is IJBRulesetApprovalHook {
|
|
21
|
-
// forge-lint: disable-next-line(mixed-case-function)
|
|
22
|
-
function DURATION() external pure override returns (uint256) {
|
|
23
|
-
return 0;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
function approvalStatusOf(uint256, JBRuleset memory) external pure override returns (JBApprovalStatus) {
|
|
27
|
-
return JBApprovalStatus.Failed;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
function supportsInterface(bytes4 interfaceId) external pure override returns (bool) {
|
|
31
|
-
return interfaceId == type(IJBRulesetApprovalHook).interfaceId || interfaceId == type(IERC165).interfaceId;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
/// @notice Regression tests for the weight cache stale-after-rejection fix.
|
|
36
|
-
///
|
|
37
|
-
/// Before the fix, updateRulesetWeightCache() only updated the cache for latestRulesetIdOf.
|
|
38
|
-
/// When a queued ruleset was rejected by an approval hook, currentOf() would fall back to
|
|
39
|
-
/// the base ruleset, but that base ruleset's cache could never be updated — causing
|
|
40
|
-
/// deriveWeightFrom() to revert with WeightCacheRequired after >20,000 cycles.
|
|
41
|
-
///
|
|
42
|
-
/// The fix adds a rulesetId parameter to updateRulesetWeightCache() so callers can
|
|
43
|
-
/// specify exactly which ruleset's cache to update — typically the one currentOf() uses.
|
|
44
|
-
contract TestWeightCacheStaleAfterRejection is TestBaseWorkflow {
|
|
45
|
-
IJBController private _controller;
|
|
46
|
-
IJBRulesets private _rulesets;
|
|
47
|
-
address private _projectOwner;
|
|
48
|
-
AlwaysRejectApprovalHook private _rejectHook;
|
|
49
|
-
|
|
50
|
-
uint256 private _projectId;
|
|
51
|
-
|
|
52
|
-
function setUp() public override {
|
|
53
|
-
super.setUp();
|
|
54
|
-
_controller = jbController();
|
|
55
|
-
_rulesets = jbRulesets();
|
|
56
|
-
_projectOwner = multisig();
|
|
57
|
-
_rejectHook = new AlwaysRejectApprovalHook();
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
/// @notice Launch a project with a 1-second duration ruleset, weight decay, and an always-reject approval hook.
|
|
61
|
-
function _launchProject() internal returns (uint256 projectId) {
|
|
62
|
-
JBRulesetConfig[] memory rulesetConfigurations = new JBRulesetConfig[](1);
|
|
63
|
-
|
|
64
|
-
JBRulesetMetadata memory metadata = JBRulesetMetadata({
|
|
65
|
-
reservedPercent: 0,
|
|
66
|
-
cashOutTaxRate: 0,
|
|
67
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
68
|
-
pausePay: false,
|
|
69
|
-
pauseCreditTransfers: false,
|
|
70
|
-
allowOwnerMinting: false,
|
|
71
|
-
allowSetCustomToken: false,
|
|
72
|
-
allowTerminalMigration: false,
|
|
73
|
-
allowSetTerminals: false,
|
|
74
|
-
ownerMustSendPayouts: false,
|
|
75
|
-
allowSetController: false,
|
|
76
|
-
allowAddAccountingContext: true,
|
|
77
|
-
allowAddPriceFeed: false,
|
|
78
|
-
holdFees: false,
|
|
79
|
-
useTotalSurplusForCashOuts: true,
|
|
80
|
-
useDataHookForPay: false,
|
|
81
|
-
useDataHookForCashOut: false,
|
|
82
|
-
dataHook: address(0),
|
|
83
|
-
metadata: 0
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
rulesetConfigurations[0] = JBRulesetConfig({
|
|
87
|
-
mustStartAtOrAfter: 0,
|
|
88
|
-
duration: 1, // 1 second — cycles very fast
|
|
89
|
-
weight: 1000e18,
|
|
90
|
-
weightCutPercent: 1, // Non-zero so weight decays each cycle
|
|
91
|
-
approvalHook: _rejectHook, // Will reject all subsequent rulesets
|
|
92
|
-
metadata: metadata,
|
|
93
|
-
splitGroups: new JBSplitGroup[](0),
|
|
94
|
-
fundAccessLimitGroups: new JBFundAccessLimitGroup[](0)
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
vm.prank(_projectOwner);
|
|
98
|
-
projectId = _controller.launchProjectFor({
|
|
99
|
-
owner: _projectOwner,
|
|
100
|
-
projectUri: "ipfs://test",
|
|
101
|
-
rulesetConfigurations: rulesetConfigurations,
|
|
102
|
-
terminalConfigurations: new JBTerminalConfig[](0),
|
|
103
|
-
memo: ""
|
|
104
|
-
});
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
/// @notice Helper to build a new ruleset config for queuing (will be rejected).
|
|
108
|
-
function _buildRejectedConfig() internal pure returns (JBRulesetConfig[] memory newConfigs) {
|
|
109
|
-
newConfigs = new JBRulesetConfig[](1);
|
|
110
|
-
newConfigs[0] = JBRulesetConfig({
|
|
111
|
-
mustStartAtOrAfter: 0,
|
|
112
|
-
duration: 1,
|
|
113
|
-
weight: 500e18, // Specific weight, not 1 (inherit), to avoid deriveWeightFrom during queuing
|
|
114
|
-
weightCutPercent: 1,
|
|
115
|
-
approvalHook: IJBRulesetApprovalHook(address(0)),
|
|
116
|
-
metadata: JBRulesetMetadata({
|
|
117
|
-
reservedPercent: 0,
|
|
118
|
-
cashOutTaxRate: 0,
|
|
119
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
120
|
-
pausePay: false,
|
|
121
|
-
pauseCreditTransfers: false,
|
|
122
|
-
allowOwnerMinting: false,
|
|
123
|
-
allowSetCustomToken: false,
|
|
124
|
-
allowTerminalMigration: false,
|
|
125
|
-
allowSetTerminals: false,
|
|
126
|
-
ownerMustSendPayouts: false,
|
|
127
|
-
allowSetController: false,
|
|
128
|
-
allowAddAccountingContext: true,
|
|
129
|
-
allowAddPriceFeed: false,
|
|
130
|
-
holdFees: false,
|
|
131
|
-
useTotalSurplusForCashOuts: true,
|
|
132
|
-
useDataHookForPay: false,
|
|
133
|
-
useDataHookForCashOut: false,
|
|
134
|
-
dataHook: address(0),
|
|
135
|
-
metadata: 0
|
|
136
|
-
}),
|
|
137
|
-
splitGroups: new JBSplitGroup[](0),
|
|
138
|
-
fundAccessLimitGroups: new JBFundAccessLimitGroup[](0)
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
/// @notice REGRESSION: After queuing a rejected ruleset and warping >20k cycles,
|
|
143
|
-
/// updateRulesetWeightCache() should update the active base ruleset's cache (not just the
|
|
144
|
-
/// rejected latest), allowing currentOf() to succeed.
|
|
145
|
-
function test_weightCache_fixedAfterApprovalRejection() public {
|
|
146
|
-
_projectId = _launchProject();
|
|
147
|
-
|
|
148
|
-
// Verify the project works initially.
|
|
149
|
-
JBRuleset memory initial = _rulesets.currentOf(_projectId);
|
|
150
|
-
assertGt(initial.weight, 0, "Initial weight should be set");
|
|
151
|
-
|
|
152
|
-
// Queue a new ruleset (B). It will be rejected by A's approval hook.
|
|
153
|
-
vm.prank(_projectOwner);
|
|
154
|
-
_controller.queueRulesetsOf({projectId: _projectId, rulesetConfigurations: _buildRejectedConfig(), memo: ""});
|
|
155
|
-
|
|
156
|
-
// Verify B is now the latest but A is still the current (B is rejected).
|
|
157
|
-
uint256 latestId = _rulesets.latestRulesetIdOf(_projectId);
|
|
158
|
-
assertGt(latestId, initial.id, "Latest should be B");
|
|
159
|
-
JBRuleset memory afterQueue = _rulesets.currentOf(_projectId);
|
|
160
|
-
assertEq(afterQueue.id, initial.id, "Current should still be A (B is rejected)");
|
|
161
|
-
|
|
162
|
-
// Warp beyond the 20,000-cycle cache threshold.
|
|
163
|
-
vm.warp(block.timestamp + 20_001);
|
|
164
|
-
|
|
165
|
-
// Before the fix, updateRulesetWeightCache only accepted projectId and always updated
|
|
166
|
-
// latestRulesetIdOf — which is the rejected B. A's cache could never be updated.
|
|
167
|
-
// After the fix, the caller passes the rulesetId of the active base ruleset (A).
|
|
168
|
-
_rulesets.updateRulesetWeightCache(_projectId, initial.id);
|
|
169
|
-
|
|
170
|
-
// Now currentOf() should succeed because A's cache is populated.
|
|
171
|
-
JBRuleset memory afterFix = _rulesets.currentOf(_projectId);
|
|
172
|
-
assertEq(afterFix.id, initial.id, "Should still use ruleset A");
|
|
173
|
-
// Weight should be less than initial (decayed over 20k+ cycles).
|
|
174
|
-
assertLt(afterFix.weight, initial.weight, "Weight should have decayed");
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
/// @notice Multiple cache updates work correctly when the latest is rejected.
|
|
178
|
-
/// Verifies that progressive caching (multiple updateRulesetWeightCache calls) also
|
|
179
|
-
/// works for the base ruleset, not just the latest.
|
|
180
|
-
function test_weightCache_progressiveCachingForRejectedLatest() public {
|
|
181
|
-
_projectId = _launchProject();
|
|
182
|
-
|
|
183
|
-
// Capture the base ruleset (A) ID before warping — after the warp, currentOf() would revert.
|
|
184
|
-
uint256 baseRulesetId = _rulesets.currentOf(_projectId).id;
|
|
185
|
-
|
|
186
|
-
// Queue a rejected ruleset.
|
|
187
|
-
vm.prank(_projectOwner);
|
|
188
|
-
_controller.queueRulesetsOf({projectId: _projectId, rulesetConfigurations: _buildRejectedConfig(), memo: ""});
|
|
189
|
-
|
|
190
|
-
// Warp far into the future (50k cycles — needs 3 cache update calls).
|
|
191
|
-
vm.warp(block.timestamp + 50_001);
|
|
192
|
-
|
|
193
|
-
// First cache update covers up to 20k cycles.
|
|
194
|
-
_rulesets.updateRulesetWeightCache(_projectId, baseRulesetId);
|
|
195
|
-
// Second covers up to 40k.
|
|
196
|
-
_rulesets.updateRulesetWeightCache(_projectId, baseRulesetId);
|
|
197
|
-
// Third covers up to 50k.
|
|
198
|
-
_rulesets.updateRulesetWeightCache(_projectId, baseRulesetId);
|
|
199
|
-
|
|
200
|
-
// currentOf() should now work.
|
|
201
|
-
JBRuleset memory current = _rulesets.currentOf(_projectId);
|
|
202
|
-
assertGt(current.cycleNumber, 50_000, "Should be past 50k cycles");
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
/// @notice With the fix applied, payments and cashouts continue to work even after
|
|
206
|
-
/// a rejected ruleset + large cycle gap.
|
|
207
|
-
function test_weightCache_terminalOperationsWorkAfterFix() public {
|
|
208
|
-
// Set up terminal for the project.
|
|
209
|
-
JBAccountingContext[] memory accountingContexts = new JBAccountingContext[](1);
|
|
210
|
-
accountingContexts[0] = JBAccountingContext({
|
|
211
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
JBTerminalConfig[] memory terminalConfigs = new JBTerminalConfig[](1);
|
|
215
|
-
terminalConfigs[0] =
|
|
216
|
-
JBTerminalConfig({terminal: jbMultiTerminal(), accountingContextsToAccept: accountingContexts});
|
|
217
|
-
|
|
218
|
-
// Launch with terminals.
|
|
219
|
-
JBRulesetConfig[] memory rulesetConfigurations = new JBRulesetConfig[](1);
|
|
220
|
-
rulesetConfigurations[0] = JBRulesetConfig({
|
|
221
|
-
mustStartAtOrAfter: 0,
|
|
222
|
-
duration: 1,
|
|
223
|
-
weight: 1000e18,
|
|
224
|
-
weightCutPercent: 1,
|
|
225
|
-
approvalHook: _rejectHook,
|
|
226
|
-
metadata: JBRulesetMetadata({
|
|
227
|
-
reservedPercent: 0,
|
|
228
|
-
cashOutTaxRate: 0,
|
|
229
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
230
|
-
pausePay: false,
|
|
231
|
-
pauseCreditTransfers: false,
|
|
232
|
-
allowOwnerMinting: false,
|
|
233
|
-
allowSetCustomToken: false,
|
|
234
|
-
allowTerminalMigration: false,
|
|
235
|
-
allowSetTerminals: false,
|
|
236
|
-
ownerMustSendPayouts: false,
|
|
237
|
-
allowSetController: false,
|
|
238
|
-
allowAddAccountingContext: true,
|
|
239
|
-
allowAddPriceFeed: false,
|
|
240
|
-
holdFees: false,
|
|
241
|
-
useTotalSurplusForCashOuts: true,
|
|
242
|
-
useDataHookForPay: false,
|
|
243
|
-
useDataHookForCashOut: false,
|
|
244
|
-
dataHook: address(0),
|
|
245
|
-
metadata: 0
|
|
246
|
-
}),
|
|
247
|
-
splitGroups: new JBSplitGroup[](0),
|
|
248
|
-
fundAccessLimitGroups: new JBFundAccessLimitGroup[](0)
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
vm.prank(_projectOwner);
|
|
252
|
-
_projectId = _controller.launchProjectFor({
|
|
253
|
-
owner: _projectOwner,
|
|
254
|
-
projectUri: "ipfs://test",
|
|
255
|
-
rulesetConfigurations: rulesetConfigurations,
|
|
256
|
-
terminalConfigurations: terminalConfigs,
|
|
257
|
-
memo: ""
|
|
258
|
-
});
|
|
259
|
-
|
|
260
|
-
// Make a payment so there are funds in the terminal.
|
|
261
|
-
address payer = makeAddr("payer");
|
|
262
|
-
vm.deal(payer, 10 ether);
|
|
263
|
-
vm.prank(payer);
|
|
264
|
-
jbMultiTerminal().pay{value: 5 ether}({
|
|
265
|
-
projectId: _projectId,
|
|
266
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
267
|
-
amount: 5 ether,
|
|
268
|
-
beneficiary: payer,
|
|
269
|
-
minReturnedTokens: 0,
|
|
270
|
-
memo: "",
|
|
271
|
-
metadata: ""
|
|
272
|
-
});
|
|
273
|
-
|
|
274
|
-
// Capture the base ruleset (A) ID before queuing a rejected one.
|
|
275
|
-
uint256 baseRulesetId = _rulesets.currentOf(_projectId).id;
|
|
276
|
-
|
|
277
|
-
// Queue a rejected ruleset.
|
|
278
|
-
vm.prank(_projectOwner);
|
|
279
|
-
_controller.queueRulesetsOf({projectId: _projectId, rulesetConfigurations: _buildRejectedConfig(), memo: ""});
|
|
280
|
-
|
|
281
|
-
// Warp beyond 20k cycles.
|
|
282
|
-
vm.warp(block.timestamp + 20_001);
|
|
283
|
-
|
|
284
|
-
// Update the cache for the active base ruleset (A), not the rejected latest (B).
|
|
285
|
-
_rulesets.updateRulesetWeightCache(_projectId, baseRulesetId);
|
|
286
|
-
|
|
287
|
-
// Payments should succeed after cache update.
|
|
288
|
-
vm.deal(payer, 1 ether);
|
|
289
|
-
vm.prank(payer);
|
|
290
|
-
jbMultiTerminal().pay{value: 1 ether}({
|
|
291
|
-
projectId: _projectId,
|
|
292
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
293
|
-
amount: 1 ether,
|
|
294
|
-
beneficiary: payer,
|
|
295
|
-
minReturnedTokens: 0,
|
|
296
|
-
memo: "",
|
|
297
|
-
metadata: ""
|
|
298
|
-
});
|
|
299
|
-
|
|
300
|
-
uint256 tokenBalance = jbTokens().totalBalanceOf(payer, _projectId);
|
|
301
|
-
assertGt(tokenBalance, 0, "Payer should have tokens after fix");
|
|
302
|
-
}
|
|
303
|
-
}
|