@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,233 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.6;
|
|
3
|
-
|
|
4
|
-
import {TestBaseWorkflow} from "./helpers/TestBaseWorkflow.sol";
|
|
5
|
-
import {JBRulesets} from "../src/JBRulesets.sol";
|
|
6
|
-
import {IJBDirectory} from "../src/interfaces/IJBDirectory.sol";
|
|
7
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
8
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
9
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
10
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
11
|
-
import {JBRuleset} from "../src/structs/JBRuleset.sol";
|
|
12
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
13
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
14
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
15
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
16
|
-
|
|
17
|
-
/// @notice Harness that exposes the internal `_simulateCycledRulesetBasedOn` for direct testing.
|
|
18
|
-
contract JBRulesetsHarness is JBRulesets {
|
|
19
|
-
constructor(IJBDirectory directory) JBRulesets(directory) {}
|
|
20
|
-
|
|
21
|
-
/// @notice Public wrapper for the internal function under test.
|
|
22
|
-
// forge-lint: disable-next-line(mixed-case-function)
|
|
23
|
-
function exposed_simulateCycledRulesetBasedOn(
|
|
24
|
-
uint256 projectId,
|
|
25
|
-
JBRuleset memory baseRuleset,
|
|
26
|
-
bool allowMidRuleset
|
|
27
|
-
)
|
|
28
|
-
external
|
|
29
|
-
view
|
|
30
|
-
returns (JBRuleset memory)
|
|
31
|
-
{
|
|
32
|
-
return _simulateCycledRulesetBasedOn(projectId, baseRuleset, allowMidRuleset);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/// @notice Tests for duration underflow fix in `_simulateCycledRulesetBasedOn`.
|
|
37
|
-
///
|
|
38
|
-
/// The fix guards against arithmetic underflow when `baseRuleset.duration >= block.timestamp`.
|
|
39
|
-
/// Without the fix, `block.timestamp - baseRuleset.duration + 1` wraps around to ~2^256,
|
|
40
|
-
/// causing `deriveStartFrom` to loop or revert.
|
|
41
|
-
///
|
|
42
|
-
/// NOTE: Through `currentOf`, the vulnerable code path (line 229) is structurally unreachable
|
|
43
|
-
/// with `duration >= block.timestamp` because:
|
|
44
|
-
/// - A queued successor starts at `base.start + k * base.duration` (k >= 1)
|
|
45
|
-
/// - So `block.timestamp >= base.start + base.duration > base.duration`
|
|
46
|
-
/// - Therefore `block.timestamp > base.duration`, meaning no underflow
|
|
47
|
-
///
|
|
48
|
-
/// The fix is defensive — it prevents underflow if the function is called with crafted parameters
|
|
49
|
-
/// or if future code changes introduce a new call path. These tests exercise the internal
|
|
50
|
-
/// function directly via a harness to verify the fix works.
|
|
51
|
-
contract TestDurationUnderflow is TestBaseWorkflow {
|
|
52
|
-
JBRulesetsHarness private _harness;
|
|
53
|
-
|
|
54
|
-
function setUp() public override {
|
|
55
|
-
super.setUp();
|
|
56
|
-
_harness = new JBRulesetsHarness(jbDirectory());
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
// ──────────────────────────────────────────────────────────────────────
|
|
60
|
-
// Helper: build a minimal base ruleset struct for direct testing.
|
|
61
|
-
// ──────────────────────────────────────────────────────────────────────
|
|
62
|
-
|
|
63
|
-
function _makeBaseRuleset(uint48 start, uint32 duration, uint112 weight) internal pure returns (JBRuleset memory) {
|
|
64
|
-
return JBRuleset({
|
|
65
|
-
cycleNumber: 1,
|
|
66
|
-
id: start, // rulesetId = start timestamp by convention
|
|
67
|
-
basedOnId: 0,
|
|
68
|
-
start: start,
|
|
69
|
-
duration: duration,
|
|
70
|
-
weight: weight,
|
|
71
|
-
weightCutPercent: 0,
|
|
72
|
-
approvalHook: IJBRulesetApprovalHook(address(0)),
|
|
73
|
-
metadata: 0
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
// ──────────────────────────────────────────────────────────────────────
|
|
78
|
-
// Direct harness tests — exercise the fix at line 606.
|
|
79
|
-
//
|
|
80
|
-
// foundry.toml sets block_timestamp = 1643802347 (~1.64 billion).
|
|
81
|
-
// A duration > 1643802347 triggers the underflow guard.
|
|
82
|
-
//
|
|
83
|
-
// Without the fix, `block.timestamp - duration + 1` wraps to ~2^256
|
|
84
|
-
// and causes `deriveStartFrom` to loop indefinitely or revert.
|
|
85
|
-
// With the fix, `mustStartAtOrAfter = 1` is used instead, and
|
|
86
|
-
// `deriveStartFrom` returns `base.start + duration` (next cycle).
|
|
87
|
-
// ──────────────────────────────────────────────────────────────────────
|
|
88
|
-
|
|
89
|
-
/// @notice duration > block.timestamp: the fix prevents underflow.
|
|
90
|
-
function test_harness_durationExceedsTimestamp_doesNotRevert() public view {
|
|
91
|
-
// duration = 2 billion > block_timestamp (~1.64 billion) → fix kicks in.
|
|
92
|
-
JBRuleset memory base = _makeBaseRuleset({start: 1, duration: uint32(2_000_000_000), weight: 1000e18});
|
|
93
|
-
|
|
94
|
-
// Without the fix this reverts. With the fix, mustStartAtOrAfter = 1.
|
|
95
|
-
JBRuleset memory result = _harness.exposed_simulateCycledRulesetBasedOn(1, base, true);
|
|
96
|
-
|
|
97
|
-
// Should return a valid ruleset (cycle 2 since deriveStartFrom returns base.start + duration).
|
|
98
|
-
assertGt(result.cycleNumber, 0, "Cycle number should be positive");
|
|
99
|
-
assertEq(result.duration, 2_000_000_000, "Duration should be preserved");
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
/// @notice duration == block.timestamp: exact boundary of the guard.
|
|
103
|
-
function test_harness_durationEqualsTimestamp_doesNotRevert() public view {
|
|
104
|
-
// Use the exact block_timestamp as duration → duration >= block.timestamp → guard fires.
|
|
105
|
-
uint32 exactDuration = uint32(block.timestamp);
|
|
106
|
-
JBRuleset memory base = _makeBaseRuleset({start: 1, duration: exactDuration, weight: 1000e18});
|
|
107
|
-
|
|
108
|
-
JBRuleset memory result = _harness.exposed_simulateCycledRulesetBasedOn(1, base, true);
|
|
109
|
-
|
|
110
|
-
assertGt(result.cycleNumber, 0, "Cycle number should be positive");
|
|
111
|
-
assertEq(result.duration, exactDuration, "Duration should match");
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
/// @notice duration = type(uint32).max: maximum possible duration.
|
|
115
|
-
function test_harness_maxDuration_doesNotRevert() public view {
|
|
116
|
-
JBRuleset memory base = _makeBaseRuleset({start: 1, duration: type(uint32).max, weight: 1000e18});
|
|
117
|
-
|
|
118
|
-
JBRuleset memory result = _harness.exposed_simulateCycledRulesetBasedOn(1, base, true);
|
|
119
|
-
|
|
120
|
-
assertGt(result.cycleNumber, 0, "Cycle number should be positive");
|
|
121
|
-
assertEq(result.duration, type(uint32).max, "Duration should be max uint32");
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
/// @notice Normal case: duration < block.timestamp. No underflow even without the fix.
|
|
125
|
-
function test_harness_normalDuration_noUnderflow() public {
|
|
126
|
-
// Warp to a realistic timestamp so that `block.timestamp - 30 days` doesn't underflow.
|
|
127
|
-
vm.warp(1_643_802_347);
|
|
128
|
-
JBRuleset memory base =
|
|
129
|
-
_makeBaseRuleset({start: uint48(block.timestamp - 30 days), duration: uint32(7 days), weight: 1000e18});
|
|
130
|
-
|
|
131
|
-
JBRuleset memory result = _harness.exposed_simulateCycledRulesetBasedOn(1, base, true);
|
|
132
|
-
|
|
133
|
-
assertGt(result.cycleNumber, 1, "Should be past cycle 1 after 30 days");
|
|
134
|
-
assertEq(result.duration, uint32(7 days), "Duration should match");
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
/// @notice allowMidRuleset = false: the duration branch is never taken.
|
|
138
|
-
function test_harness_allowMidRulesetFalse_doesNotRevert() public view {
|
|
139
|
-
JBRuleset memory base = _makeBaseRuleset({start: 1, duration: type(uint32).max, weight: 1000e18});
|
|
140
|
-
|
|
141
|
-
// allowMidRuleset = false → mustStartAtOrAfter = block.timestamp + 1, no subtraction.
|
|
142
|
-
JBRuleset memory result = _harness.exposed_simulateCycledRulesetBasedOn(1, base, false);
|
|
143
|
-
|
|
144
|
-
assertGt(result.cycleNumber, 0, "Cycle number should be positive");
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
// ──────────────────────────────────────────────────────────────────────
|
|
148
|
-
// Integration tests — currentOf with large durations
|
|
149
|
-
//
|
|
150
|
-
// These exercise the normal `currentOf` path (early return at line 191).
|
|
151
|
-
// The underflow path (line 229) is not reachable here, but these tests
|
|
152
|
-
// verify the protocol works correctly with large durations end-to-end.
|
|
153
|
-
// ──────────────────────────────────────────────────────────────────────
|
|
154
|
-
|
|
155
|
-
function _launchProject(uint32 duration) internal returns (uint256) {
|
|
156
|
-
JBRulesetConfig[] memory rulesetConfig = new JBRulesetConfig[](1);
|
|
157
|
-
rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
158
|
-
rulesetConfig[0].duration = duration;
|
|
159
|
-
rulesetConfig[0].weight = 1000e18;
|
|
160
|
-
rulesetConfig[0].weightCutPercent = 0;
|
|
161
|
-
rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
162
|
-
rulesetConfig[0].metadata = JBRulesetMetadata({
|
|
163
|
-
reservedPercent: 0,
|
|
164
|
-
cashOutTaxRate: 0,
|
|
165
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
166
|
-
pausePay: false,
|
|
167
|
-
pauseCreditTransfers: false,
|
|
168
|
-
allowOwnerMinting: false,
|
|
169
|
-
allowSetCustomToken: false,
|
|
170
|
-
allowTerminalMigration: false,
|
|
171
|
-
allowSetTerminals: false,
|
|
172
|
-
ownerMustSendPayouts: false,
|
|
173
|
-
allowSetController: false,
|
|
174
|
-
allowAddAccountingContext: true,
|
|
175
|
-
allowAddPriceFeed: false,
|
|
176
|
-
holdFees: false,
|
|
177
|
-
useTotalSurplusForCashOuts: false,
|
|
178
|
-
useDataHookForPay: false,
|
|
179
|
-
useDataHookForCashOut: false,
|
|
180
|
-
dataHook: address(0),
|
|
181
|
-
metadata: 0
|
|
182
|
-
});
|
|
183
|
-
rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
184
|
-
rulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
185
|
-
|
|
186
|
-
JBTerminalConfig[] memory terminalConfigs = new JBTerminalConfig[](1);
|
|
187
|
-
JBAccountingContext[] memory tokens = new JBAccountingContext[](1);
|
|
188
|
-
tokens[0] = JBAccountingContext({
|
|
189
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
190
|
-
});
|
|
191
|
-
terminalConfigs[0] = JBTerminalConfig({terminal: jbMultiTerminal(), accountingContextsToAccept: tokens});
|
|
192
|
-
|
|
193
|
-
return jbController()
|
|
194
|
-
.launchProjectFor({
|
|
195
|
-
owner: multisig(),
|
|
196
|
-
projectUri: "test",
|
|
197
|
-
rulesetConfigurations: rulesetConfig,
|
|
198
|
-
terminalConfigurations: terminalConfigs,
|
|
199
|
-
memo: ""
|
|
200
|
-
});
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
/// @notice currentOf with a large duration (cycle 1, no cycling needed).
|
|
204
|
-
function test_currentOf_largeDuration() public {
|
|
205
|
-
uint256 projectId = _launchProject(uint32(2_000_000_000));
|
|
206
|
-
|
|
207
|
-
JBRuleset memory ruleset = jbRulesets().currentOf(projectId);
|
|
208
|
-
|
|
209
|
-
assertEq(ruleset.cycleNumber, 1, "Should be cycle 1");
|
|
210
|
-
assertGt(ruleset.start, 0, "Should have a valid start time");
|
|
211
|
-
assertEq(ruleset.duration, 2_000_000_000, "Duration should match");
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
/// @notice currentOf with max uint32 duration.
|
|
215
|
-
function test_currentOf_maxDuration() public {
|
|
216
|
-
uint256 projectId = _launchProject(type(uint32).max);
|
|
217
|
-
|
|
218
|
-
JBRuleset memory ruleset = jbRulesets().currentOf(projectId);
|
|
219
|
-
|
|
220
|
-
assertEq(ruleset.cycleNumber, 1, "Should be cycle 1");
|
|
221
|
-
assertEq(ruleset.duration, type(uint32).max, "Duration should match");
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
/// @notice Sanity: currentOf with a normal duration still works.
|
|
225
|
-
function test_currentOf_normalDuration() public {
|
|
226
|
-
uint256 projectId = _launchProject(uint32(7 days));
|
|
227
|
-
|
|
228
|
-
JBRuleset memory ruleset = jbRulesets().currentOf(projectId);
|
|
229
|
-
|
|
230
|
-
assertEq(ruleset.cycleNumber, 1, "Should be cycle 1");
|
|
231
|
-
assertEq(ruleset.duration, uint32(7 days), "Duration should match");
|
|
232
|
-
}
|
|
233
|
-
}
|