@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,306 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.6;
|
|
3
|
-
|
|
4
|
-
import {StdInvariant} from "forge-std/StdInvariant.sol";
|
|
5
|
-
import {TestBaseWorkflow} from "./helpers/TestBaseWorkflow.sol";
|
|
6
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
7
|
-
import {IJBTerminal} from "../src/interfaces/IJBTerminal.sol";
|
|
8
|
-
import {IJBSplitHook} from "../src/interfaces/IJBSplitHook.sol";
|
|
9
|
-
import {IJBToken} from "../src/interfaces/IJBToken.sol";
|
|
10
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
11
|
-
import {JBRulesetMetadataResolver} from "../src/libraries/JBRulesetMetadataResolver.sol";
|
|
12
|
-
import {JBCurrencyAmount} from "../src/structs/JBCurrencyAmount.sol";
|
|
13
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
14
|
-
import {JBRuleset} from "../src/structs/JBRuleset.sol";
|
|
15
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
16
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
17
|
-
import {JBSplit} from "../src/structs/JBSplit.sol";
|
|
18
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
19
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
20
|
-
import {ComprehensiveHandler} from "./invariants/handlers/ComprehensiveHandler.sol";
|
|
21
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
22
|
-
|
|
23
|
-
/// @notice Comprehensive invariant tests for JB V5 fund conservation.
|
|
24
|
-
/// @dev Tests 8 invariants across 10 operations: pay, cashOut, sendPayouts, addToBalance,
|
|
25
|
-
/// sendReservedTokens, useAllowance, burnTokens, claimCredits, advanceTime, processHeldFees.
|
|
26
|
-
contract ComprehensiveInvariant_Local is StdInvariant, TestBaseWorkflow {
|
|
27
|
-
using JBRulesetMetadataResolver for JBRuleset;
|
|
28
|
-
|
|
29
|
-
ComprehensiveHandler public handler;
|
|
30
|
-
|
|
31
|
-
uint256 public projectId;
|
|
32
|
-
address public projectOwner;
|
|
33
|
-
address public splitBeneficiary;
|
|
34
|
-
|
|
35
|
-
function setUp() public override {
|
|
36
|
-
super.setUp();
|
|
37
|
-
projectOwner = multisig();
|
|
38
|
-
splitBeneficiary = address(0xBEEF);
|
|
39
|
-
|
|
40
|
-
// ── Launch fee collector project (#1)
|
|
41
|
-
// ────────────────────────
|
|
42
|
-
JBRulesetConfig[] memory feeRulesetConfig = new JBRulesetConfig[](1);
|
|
43
|
-
feeRulesetConfig[0].mustStartAtOrAfter = 0;
|
|
44
|
-
feeRulesetConfig[0].duration = 0;
|
|
45
|
-
feeRulesetConfig[0].weight = 1000e18;
|
|
46
|
-
feeRulesetConfig[0].weightCutPercent = 0;
|
|
47
|
-
feeRulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
48
|
-
feeRulesetConfig[0].metadata = JBRulesetMetadata({
|
|
49
|
-
reservedPercent: 0,
|
|
50
|
-
cashOutTaxRate: 0,
|
|
51
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
52
|
-
pausePay: false,
|
|
53
|
-
pauseCreditTransfers: false,
|
|
54
|
-
allowOwnerMinting: false,
|
|
55
|
-
allowSetCustomToken: false,
|
|
56
|
-
allowTerminalMigration: false,
|
|
57
|
-
allowSetTerminals: false,
|
|
58
|
-
ownerMustSendPayouts: false,
|
|
59
|
-
allowSetController: false,
|
|
60
|
-
allowAddAccountingContext: true,
|
|
61
|
-
allowAddPriceFeed: false,
|
|
62
|
-
holdFees: false,
|
|
63
|
-
useTotalSurplusForCashOuts: false,
|
|
64
|
-
useDataHookForPay: false,
|
|
65
|
-
useDataHookForCashOut: false,
|
|
66
|
-
dataHook: address(0),
|
|
67
|
-
metadata: 0
|
|
68
|
-
});
|
|
69
|
-
feeRulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
70
|
-
feeRulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
71
|
-
|
|
72
|
-
JBTerminalConfig[] memory terminalConfigurations = new JBTerminalConfig[](1);
|
|
73
|
-
JBAccountingContext[] memory tokensToAccept = new JBAccountingContext[](1);
|
|
74
|
-
tokensToAccept[0] = JBAccountingContext({
|
|
75
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
76
|
-
});
|
|
77
|
-
terminalConfigurations[0] =
|
|
78
|
-
JBTerminalConfig({terminal: jbMultiTerminal(), accountingContextsToAccept: tokensToAccept});
|
|
79
|
-
|
|
80
|
-
jbController()
|
|
81
|
-
.launchProjectFor({
|
|
82
|
-
owner: address(420),
|
|
83
|
-
projectUri: "feeCollector",
|
|
84
|
-
rulesetConfigurations: feeRulesetConfig,
|
|
85
|
-
terminalConfigurations: terminalConfigurations,
|
|
86
|
-
memo: ""
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
// ── Launch test project (#2): 20% reserved, 30% cashOutTax, holdFees, splits, limits ──
|
|
90
|
-
JBRulesetConfig[] memory rulesetConfig = new JBRulesetConfig[](1);
|
|
91
|
-
rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
92
|
-
rulesetConfig[0].duration = 0;
|
|
93
|
-
rulesetConfig[0].weight = 1000e18;
|
|
94
|
-
rulesetConfig[0].weightCutPercent = 0;
|
|
95
|
-
rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
96
|
-
rulesetConfig[0].metadata = JBRulesetMetadata({
|
|
97
|
-
reservedPercent: 2000, // 20%
|
|
98
|
-
cashOutTaxRate: 3000, // 30%
|
|
99
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
100
|
-
pausePay: false,
|
|
101
|
-
pauseCreditTransfers: false,
|
|
102
|
-
allowOwnerMinting: true,
|
|
103
|
-
allowSetCustomToken: true,
|
|
104
|
-
allowTerminalMigration: false,
|
|
105
|
-
allowSetTerminals: false,
|
|
106
|
-
ownerMustSendPayouts: false,
|
|
107
|
-
allowSetController: false,
|
|
108
|
-
allowAddAccountingContext: true,
|
|
109
|
-
allowAddPriceFeed: false,
|
|
110
|
-
holdFees: true,
|
|
111
|
-
useTotalSurplusForCashOuts: false,
|
|
112
|
-
useDataHookForPay: false,
|
|
113
|
-
useDataHookForCashOut: false,
|
|
114
|
-
dataHook: address(0),
|
|
115
|
-
metadata: 0
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
// Splits: 50% to splitBeneficiary, 50% to fee project (via projectId=1)
|
|
119
|
-
JBSplit[] memory splits = new JBSplit[](2);
|
|
120
|
-
splits[0] = JBSplit({
|
|
121
|
-
percent: uint32(JBConstants.SPLITS_TOTAL_PERCENT / 2),
|
|
122
|
-
projectId: 0,
|
|
123
|
-
beneficiary: payable(splitBeneficiary),
|
|
124
|
-
preferAddToBalance: false,
|
|
125
|
-
lockedUntil: 0,
|
|
126
|
-
hook: IJBSplitHook(address(0))
|
|
127
|
-
});
|
|
128
|
-
splits[1] = JBSplit({
|
|
129
|
-
percent: uint32(JBConstants.SPLITS_TOTAL_PERCENT / 2),
|
|
130
|
-
projectId: 1,
|
|
131
|
-
beneficiary: payable(address(0)),
|
|
132
|
-
preferAddToBalance: true,
|
|
133
|
-
lockedUntil: 0,
|
|
134
|
-
hook: IJBSplitHook(address(0))
|
|
135
|
-
});
|
|
136
|
-
JBSplitGroup[] memory splitGroups = new JBSplitGroup[](1);
|
|
137
|
-
splitGroups[0] = JBSplitGroup({groupId: uint256(uint160(JBConstants.NATIVE_TOKEN)), splits: splits});
|
|
138
|
-
rulesetConfig[0].splitGroups = splitGroups;
|
|
139
|
-
|
|
140
|
-
// Fund access limits: 5 ETH payout limit, 3 ETH surplus allowance
|
|
141
|
-
JBCurrencyAmount[] memory payoutLimits = new JBCurrencyAmount[](1);
|
|
142
|
-
payoutLimits[0] = JBCurrencyAmount({amount: 5 ether, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))});
|
|
143
|
-
|
|
144
|
-
JBCurrencyAmount[] memory surplusAllowances = new JBCurrencyAmount[](1);
|
|
145
|
-
surplusAllowances[0] = JBCurrencyAmount({amount: 3 ether, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))});
|
|
146
|
-
|
|
147
|
-
JBFundAccessLimitGroup[] memory fundAccessLimitGroups = new JBFundAccessLimitGroup[](1);
|
|
148
|
-
fundAccessLimitGroups[0] = JBFundAccessLimitGroup({
|
|
149
|
-
terminal: address(jbMultiTerminal()),
|
|
150
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
151
|
-
payoutLimits: payoutLimits,
|
|
152
|
-
surplusAllowances: surplusAllowances
|
|
153
|
-
});
|
|
154
|
-
rulesetConfig[0].fundAccessLimitGroups = fundAccessLimitGroups;
|
|
155
|
-
|
|
156
|
-
projectId = jbController()
|
|
157
|
-
.launchProjectFor({
|
|
158
|
-
owner: projectOwner,
|
|
159
|
-
projectUri: "testProject",
|
|
160
|
-
rulesetConfigurations: rulesetConfig,
|
|
161
|
-
terminalConfigurations: terminalConfigurations,
|
|
162
|
-
memo: ""
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
// Deploy ERC20 so tokens can be tracked
|
|
166
|
-
vm.prank(projectOwner);
|
|
167
|
-
jbController().deployERC20For(projectId, "TestToken", "TT", bytes32(0));
|
|
168
|
-
|
|
169
|
-
// Deploy handler
|
|
170
|
-
handler = new ComprehensiveHandler(
|
|
171
|
-
jbMultiTerminal(), jbTerminalStore(), jbController(), jbTokens(), projectId, projectOwner
|
|
172
|
-
);
|
|
173
|
-
|
|
174
|
-
// Register all 10 handler operations
|
|
175
|
-
bytes4[] memory selectors = new bytes4[](10);
|
|
176
|
-
selectors[0] = ComprehensiveHandler.payProject.selector;
|
|
177
|
-
selectors[1] = ComprehensiveHandler.cashOutTokens.selector;
|
|
178
|
-
selectors[2] = ComprehensiveHandler.sendPayouts.selector;
|
|
179
|
-
selectors[3] = ComprehensiveHandler.addToBalance.selector;
|
|
180
|
-
selectors[4] = ComprehensiveHandler.sendReservedTokens.selector;
|
|
181
|
-
selectors[5] = ComprehensiveHandler.useAllowance.selector;
|
|
182
|
-
selectors[6] = ComprehensiveHandler.burnTokens.selector;
|
|
183
|
-
selectors[7] = ComprehensiveHandler.claimCredits.selector;
|
|
184
|
-
selectors[8] = ComprehensiveHandler.advanceTime.selector;
|
|
185
|
-
selectors[9] = ComprehensiveHandler.processHeldFees.selector;
|
|
186
|
-
|
|
187
|
-
targetContract(address(handler));
|
|
188
|
-
targetSelector(FuzzSelector({addr: address(handler), selectors: selectors}));
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
/// @notice COMP1: Terminal ETH balance >= sum of recorded balances.
|
|
192
|
-
function invariant_COMP1_terminalBalanceCoversRecordedBalances() public view {
|
|
193
|
-
uint256 projectBalance =
|
|
194
|
-
jbTerminalStore().balanceOf(address(jbMultiTerminal()), projectId, JBConstants.NATIVE_TOKEN);
|
|
195
|
-
uint256 feeProjectBalance = jbTerminalStore().balanceOf(address(jbMultiTerminal()), 1, JBConstants.NATIVE_TOKEN);
|
|
196
|
-
uint256 actualBalance = address(jbMultiTerminal()).balance;
|
|
197
|
-
|
|
198
|
-
assertGe(
|
|
199
|
-
actualBalance,
|
|
200
|
-
projectBalance + feeProjectBalance,
|
|
201
|
-
"COMP1: Terminal ETH balance must be >= sum of recorded project balances"
|
|
202
|
-
);
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
/// @notice COMP2: totalSupplyOf == creditSupply + erc20Supply.
|
|
206
|
-
function invariant_COMP2_tokenSupplyConsistency() public view {
|
|
207
|
-
uint256 totalSupply = jbTokens().totalSupplyOf(projectId);
|
|
208
|
-
uint256 creditSupply = jbTokens().totalCreditSupplyOf(projectId);
|
|
209
|
-
|
|
210
|
-
IJBToken token = jbTokens().tokenOf(projectId);
|
|
211
|
-
uint256 erc20Supply = 0;
|
|
212
|
-
if (address(token) != address(0)) {
|
|
213
|
-
erc20Supply = token.totalSupply();
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
assertEq(totalSupply, creditSupply + erc20Supply, "COMP2: totalSupply must equal creditSupply + erc20Supply");
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
/// @notice COMP3: usedPayoutLimit <= payoutLimit per cycle.
|
|
220
|
-
function invariant_COMP3_payoutLimitRespected() public view {
|
|
221
|
-
(JBRuleset memory ruleset,) = jbController().currentRulesetOf(projectId);
|
|
222
|
-
uint256 usedPayoutLimit = jbTerminalStore()
|
|
223
|
-
.usedPayoutLimitOf(
|
|
224
|
-
address(jbMultiTerminal()),
|
|
225
|
-
projectId,
|
|
226
|
-
JBConstants.NATIVE_TOKEN,
|
|
227
|
-
ruleset.cycleNumber,
|
|
228
|
-
uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
229
|
-
);
|
|
230
|
-
|
|
231
|
-
// Payout limit is 5 ETH
|
|
232
|
-
assertLe(usedPayoutLimit, 5 ether, "COMP3: usedPayoutLimit must not exceed configured payout limit");
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
/// @notice COMP4: reclaimableSurplus(halfSupply) <= currentSurplus.
|
|
236
|
-
function invariant_COMP4_reclaimableSurplusLeqSurplus() public view {
|
|
237
|
-
uint256 totalSupply = jbTokens().totalSupplyOf(projectId);
|
|
238
|
-
if (totalSupply == 0) return;
|
|
239
|
-
|
|
240
|
-
IJBTerminal[] memory _terminals = new IJBTerminal[](1);
|
|
241
|
-
_terminals[0] = IJBTerminal(jbMultiTerminal());
|
|
242
|
-
uint256 surplus = jbTerminalStore()
|
|
243
|
-
.currentSurplusOf({
|
|
244
|
-
projectId: projectId,
|
|
245
|
-
terminals: _terminals,
|
|
246
|
-
tokens: new address[](0),
|
|
247
|
-
decimals: 18,
|
|
248
|
-
currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
uint256 halfSupply = totalSupply / 2;
|
|
252
|
-
if (halfSupply == 0) return;
|
|
253
|
-
|
|
254
|
-
uint256 reclaimable = jbTerminalStore()
|
|
255
|
-
.currentReclaimableSurplusOf({
|
|
256
|
-
projectId: projectId, cashOutCount: halfSupply, totalSupply: totalSupply, surplus: surplus
|
|
257
|
-
});
|
|
258
|
-
|
|
259
|
-
assertLe(reclaimable, surplus, "COMP4: Reclaimable surplus must not exceed current surplus");
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
/// @notice COMP5: After sendReservedTokens, pending balance == 0.
|
|
263
|
-
function invariant_COMP5_reservesPendingAfterDistribution() public view {
|
|
264
|
-
// This is an informational invariant: we verify that the pending balance
|
|
265
|
-
// can be read without reverting. The actual test is that if
|
|
266
|
-
// sendReservedTokens was called, pending should have been zeroed.
|
|
267
|
-
// We can't force a call here, but we check consistency.
|
|
268
|
-
uint256 pending = jbController().pendingReservedTokenBalanceOf(projectId);
|
|
269
|
-
// Pending is allowed to be > 0 (tokens accumulate between distributions).
|
|
270
|
-
// The important thing is that the view function doesn't revert.
|
|
271
|
-
assertGe(pending, 0, "COMP5: pendingReservedTokenBalance should be readable");
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
/// @notice COMP6: Ghost fund conservation (totalIn >= totalOut + remaining).
|
|
275
|
-
function invariant_COMP6_ghostFundConservation() public view {
|
|
276
|
-
uint256 totalIn = handler.ghost_totalPaidIn() + handler.ghost_totalAddedToBalance();
|
|
277
|
-
uint256 totalOut =
|
|
278
|
-
handler.ghost_totalCashedOut() + handler.ghost_totalPaidOut() + handler.ghost_totalAllowanceUsed();
|
|
279
|
-
|
|
280
|
-
// Fees go to project #1, so total funds are conserved within the terminal
|
|
281
|
-
assertGe(totalIn, totalOut, "COMP6: Ghost conservation - total funds in must be >= total funds out");
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
/// @notice COMP7: Fee project balance never decreases (monotonically increasing).
|
|
285
|
-
function invariant_COMP7_feeProjectBalanceMonotonic() public view {
|
|
286
|
-
assertEq(handler.ghost_feeProjectBalanceDecreased(), 0, "COMP7: Fee project balance must never decrease");
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
/// @notice COMP8: Terminal ETH balance == projectBalance + feeBalance + heldFeeAmounts.
|
|
290
|
-
/// @dev Held fees are subtracted from the project's recorded balance, so the terminal's
|
|
291
|
-
/// actual ETH balance should account for held fees.
|
|
292
|
-
function invariant_COMP8_exactAccountingWithHeldFees() public view {
|
|
293
|
-
uint256 projectBalance =
|
|
294
|
-
jbTerminalStore().balanceOf(address(jbMultiTerminal()), projectId, JBConstants.NATIVE_TOKEN);
|
|
295
|
-
uint256 feeProjectBalance = jbTerminalStore().balanceOf(address(jbMultiTerminal()), 1, JBConstants.NATIVE_TOKEN);
|
|
296
|
-
uint256 actualBalance = address(jbMultiTerminal()).balance;
|
|
297
|
-
|
|
298
|
-
// The terminal's actual ETH balance should always be >= sum of recorded balances.
|
|
299
|
-
// The difference accounts for held fees that haven't been processed yet.
|
|
300
|
-
assertGe(
|
|
301
|
-
actualBalance,
|
|
302
|
-
projectBalance + feeProjectBalance,
|
|
303
|
-
"COMP8: Terminal must hold at least the sum of all recorded balances"
|
|
304
|
-
);
|
|
305
|
-
}
|
|
306
|
-
}
|