@bananapus/core-v6 0.0.36 → 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 +26 -5
- package/src/JBMultiTerminal.sol +85 -47
- 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/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,348 +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 {JBRulesetMetadataResolver} from "../src/libraries/JBRulesetMetadataResolver.sol";
|
|
8
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
9
|
-
import {JBRuleset} from "../src/structs/JBRuleset.sol";
|
|
10
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
11
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
12
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
13
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
14
|
-
import {EconomicHandler} from "./invariants/handlers/EconomicHandler.sol";
|
|
15
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
16
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
17
|
-
|
|
18
|
-
/// @title EconomicSimulation
|
|
19
|
-
/// @notice Multi-project economic invariant tests with 3 projects and 10 actors.
|
|
20
|
-
/// Verifies fund conservation, supply consistency, and cross-project split cascades.
|
|
21
|
-
contract EconomicSimulation_Local is StdInvariant, TestBaseWorkflow {
|
|
22
|
-
using JBRulesetMetadataResolver for JBRuleset;
|
|
23
|
-
|
|
24
|
-
EconomicHandler public handler;
|
|
25
|
-
|
|
26
|
-
uint256 public projectA;
|
|
27
|
-
uint256 public projectB;
|
|
28
|
-
uint256 public projectC;
|
|
29
|
-
address public projectOwner;
|
|
30
|
-
|
|
31
|
-
function setUp() public override {
|
|
32
|
-
super.setUp();
|
|
33
|
-
projectOwner = multisig();
|
|
34
|
-
|
|
35
|
-
// =====================================================================
|
|
36
|
-
// Fee collector project (#1) — create explicitly since TestBaseWorkflow
|
|
37
|
-
// passes feeProjectOwner=address(0) to JBProjects.
|
|
38
|
-
// This ensures projectA=2, projectB=3, projectC=4 and fee project=1.
|
|
39
|
-
// =====================================================================
|
|
40
|
-
{
|
|
41
|
-
JBRulesetConfig[] memory emptyRuleset = new JBRulesetConfig[](1);
|
|
42
|
-
emptyRuleset[0].mustStartAtOrAfter = 0;
|
|
43
|
-
emptyRuleset[0].duration = 0;
|
|
44
|
-
emptyRuleset[0].weight = 0;
|
|
45
|
-
emptyRuleset[0].weightCutPercent = 0;
|
|
46
|
-
emptyRuleset[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
47
|
-
emptyRuleset[0].metadata = JBRulesetMetadata({
|
|
48
|
-
reservedPercent: 0,
|
|
49
|
-
cashOutTaxRate: 0,
|
|
50
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
51
|
-
pausePay: false,
|
|
52
|
-
pauseCreditTransfers: false,
|
|
53
|
-
allowOwnerMinting: false,
|
|
54
|
-
allowSetCustomToken: false,
|
|
55
|
-
allowTerminalMigration: false,
|
|
56
|
-
allowSetTerminals: false,
|
|
57
|
-
ownerMustSendPayouts: false,
|
|
58
|
-
allowSetController: false,
|
|
59
|
-
allowAddAccountingContext: true,
|
|
60
|
-
allowAddPriceFeed: false,
|
|
61
|
-
holdFees: false,
|
|
62
|
-
useTotalSurplusForCashOuts: false,
|
|
63
|
-
useDataHookForPay: false,
|
|
64
|
-
useDataHookForCashOut: false,
|
|
65
|
-
dataHook: address(0),
|
|
66
|
-
metadata: 0
|
|
67
|
-
});
|
|
68
|
-
emptyRuleset[0].splitGroups = new JBSplitGroup[](0);
|
|
69
|
-
emptyRuleset[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
70
|
-
|
|
71
|
-
JBTerminalConfig[] memory feeTerminalConfigs = new JBTerminalConfig[](1);
|
|
72
|
-
JBAccountingContext[] memory feeTokens = new JBAccountingContext[](1);
|
|
73
|
-
feeTokens[0] = JBAccountingContext({
|
|
74
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
75
|
-
});
|
|
76
|
-
feeTerminalConfigs[0] =
|
|
77
|
-
JBTerminalConfig({terminal: jbMultiTerminal(), accountingContextsToAccept: feeTokens});
|
|
78
|
-
|
|
79
|
-
uint256 feeProjectId = jbController()
|
|
80
|
-
.launchProjectFor({
|
|
81
|
-
owner: projectOwner,
|
|
82
|
-
projectUri: "FeeProject",
|
|
83
|
-
rulesetConfigurations: emptyRuleset,
|
|
84
|
-
terminalConfigurations: feeTerminalConfigs,
|
|
85
|
-
memo: ""
|
|
86
|
-
});
|
|
87
|
-
require(feeProjectId == 1, "Fee project must be #1");
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
// =====================================================================
|
|
91
|
-
// Project A: 20% reserved, 60% cash out tax, splits 50% to B
|
|
92
|
-
// =====================================================================
|
|
93
|
-
JBRulesetConfig[] memory rulesetConfigA = new JBRulesetConfig[](1);
|
|
94
|
-
rulesetConfigA[0].mustStartAtOrAfter = 0;
|
|
95
|
-
rulesetConfigA[0].duration = 0;
|
|
96
|
-
rulesetConfigA[0].weight = 1000e18;
|
|
97
|
-
rulesetConfigA[0].weightCutPercent = 0;
|
|
98
|
-
rulesetConfigA[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
99
|
-
rulesetConfigA[0].metadata = JBRulesetMetadata({
|
|
100
|
-
reservedPercent: 2000, // 20%
|
|
101
|
-
cashOutTaxRate: 6000, // 60%
|
|
102
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
103
|
-
pausePay: false,
|
|
104
|
-
pauseCreditTransfers: false,
|
|
105
|
-
allowOwnerMinting: false,
|
|
106
|
-
allowSetCustomToken: false,
|
|
107
|
-
allowTerminalMigration: false,
|
|
108
|
-
allowSetTerminals: false,
|
|
109
|
-
ownerMustSendPayouts: false,
|
|
110
|
-
allowSetController: false,
|
|
111
|
-
allowAddAccountingContext: true,
|
|
112
|
-
allowAddPriceFeed: false,
|
|
113
|
-
holdFees: false,
|
|
114
|
-
useTotalSurplusForCashOuts: false,
|
|
115
|
-
useDataHookForPay: false,
|
|
116
|
-
useDataHookForCashOut: false,
|
|
117
|
-
dataHook: address(0),
|
|
118
|
-
metadata: 0
|
|
119
|
-
});
|
|
120
|
-
rulesetConfigA[0].splitGroups = new JBSplitGroup[](0);
|
|
121
|
-
rulesetConfigA[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
122
|
-
|
|
123
|
-
JBTerminalConfig[] memory terminalConfigurations = new JBTerminalConfig[](1);
|
|
124
|
-
JBAccountingContext[] memory tokensToAccept = new JBAccountingContext[](1);
|
|
125
|
-
tokensToAccept[0] = JBAccountingContext({
|
|
126
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
127
|
-
});
|
|
128
|
-
terminalConfigurations[0] =
|
|
129
|
-
JBTerminalConfig({terminal: jbMultiTerminal(), accountingContextsToAccept: tokensToAccept});
|
|
130
|
-
|
|
131
|
-
projectA = jbController()
|
|
132
|
-
.launchProjectFor({
|
|
133
|
-
owner: projectOwner,
|
|
134
|
-
projectUri: "ProjectA",
|
|
135
|
-
rulesetConfigurations: rulesetConfigA,
|
|
136
|
-
terminalConfigurations: terminalConfigurations,
|
|
137
|
-
memo: ""
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
// =====================================================================
|
|
141
|
-
// Project B: 0% reserved, 0% cash out tax
|
|
142
|
-
// =====================================================================
|
|
143
|
-
JBRulesetConfig[] memory rulesetConfigB = new JBRulesetConfig[](1);
|
|
144
|
-
rulesetConfigB[0].mustStartAtOrAfter = 0;
|
|
145
|
-
rulesetConfigB[0].duration = 0;
|
|
146
|
-
rulesetConfigB[0].weight = 1000e18;
|
|
147
|
-
rulesetConfigB[0].weightCutPercent = 0;
|
|
148
|
-
rulesetConfigB[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
149
|
-
rulesetConfigB[0].metadata = JBRulesetMetadata({
|
|
150
|
-
reservedPercent: 0,
|
|
151
|
-
cashOutTaxRate: 0,
|
|
152
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
153
|
-
pausePay: false,
|
|
154
|
-
pauseCreditTransfers: false,
|
|
155
|
-
allowOwnerMinting: false,
|
|
156
|
-
allowSetCustomToken: false,
|
|
157
|
-
allowTerminalMigration: false,
|
|
158
|
-
allowSetTerminals: false,
|
|
159
|
-
ownerMustSendPayouts: false,
|
|
160
|
-
allowSetController: false,
|
|
161
|
-
allowAddAccountingContext: true,
|
|
162
|
-
allowAddPriceFeed: false,
|
|
163
|
-
holdFees: false,
|
|
164
|
-
useTotalSurplusForCashOuts: false,
|
|
165
|
-
useDataHookForPay: false,
|
|
166
|
-
useDataHookForCashOut: false,
|
|
167
|
-
dataHook: address(0),
|
|
168
|
-
metadata: 0
|
|
169
|
-
});
|
|
170
|
-
rulesetConfigB[0].splitGroups = new JBSplitGroup[](0);
|
|
171
|
-
rulesetConfigB[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
172
|
-
|
|
173
|
-
projectB = jbController()
|
|
174
|
-
.launchProjectFor({
|
|
175
|
-
owner: projectOwner,
|
|
176
|
-
projectUri: "ProjectB",
|
|
177
|
-
rulesetConfigurations: rulesetConfigB,
|
|
178
|
-
terminalConfigurations: terminalConfigurations,
|
|
179
|
-
memo: ""
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
// =====================================================================
|
|
183
|
-
// Project C: 50% reserved, 80% cash out tax
|
|
184
|
-
// =====================================================================
|
|
185
|
-
JBRulesetConfig[] memory rulesetConfigC = new JBRulesetConfig[](1);
|
|
186
|
-
rulesetConfigC[0].mustStartAtOrAfter = 0;
|
|
187
|
-
rulesetConfigC[0].duration = 0;
|
|
188
|
-
rulesetConfigC[0].weight = 1000e18;
|
|
189
|
-
rulesetConfigC[0].weightCutPercent = 0;
|
|
190
|
-
rulesetConfigC[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
191
|
-
rulesetConfigC[0].metadata = JBRulesetMetadata({
|
|
192
|
-
reservedPercent: 5000, // 50%
|
|
193
|
-
cashOutTaxRate: 8000, // 80%
|
|
194
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
195
|
-
pausePay: false,
|
|
196
|
-
pauseCreditTransfers: false,
|
|
197
|
-
allowOwnerMinting: false,
|
|
198
|
-
allowSetCustomToken: false,
|
|
199
|
-
allowTerminalMigration: false,
|
|
200
|
-
allowSetTerminals: false,
|
|
201
|
-
ownerMustSendPayouts: false,
|
|
202
|
-
allowSetController: false,
|
|
203
|
-
allowAddAccountingContext: true,
|
|
204
|
-
allowAddPriceFeed: false,
|
|
205
|
-
holdFees: false,
|
|
206
|
-
useTotalSurplusForCashOuts: false,
|
|
207
|
-
useDataHookForPay: false,
|
|
208
|
-
useDataHookForCashOut: false,
|
|
209
|
-
dataHook: address(0),
|
|
210
|
-
metadata: 0
|
|
211
|
-
});
|
|
212
|
-
rulesetConfigC[0].splitGroups = new JBSplitGroup[](0);
|
|
213
|
-
rulesetConfigC[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
214
|
-
|
|
215
|
-
projectC = jbController()
|
|
216
|
-
.launchProjectFor({
|
|
217
|
-
owner: projectOwner,
|
|
218
|
-
projectUri: "ProjectC",
|
|
219
|
-
rulesetConfigurations: rulesetConfigC,
|
|
220
|
-
terminalConfigurations: terminalConfigurations,
|
|
221
|
-
memo: ""
|
|
222
|
-
});
|
|
223
|
-
|
|
224
|
-
// =====================================================================
|
|
225
|
-
// Create handler and register
|
|
226
|
-
// =====================================================================
|
|
227
|
-
handler = new EconomicHandler(
|
|
228
|
-
jbMultiTerminal(), jbTerminalStore(), jbController(), jbTokens(), projectA, projectB, projectC, projectOwner
|
|
229
|
-
);
|
|
230
|
-
|
|
231
|
-
bytes4[] memory selectors = new bytes4[](15);
|
|
232
|
-
selectors[0] = EconomicHandler.payProjectA.selector;
|
|
233
|
-
selectors[1] = EconomicHandler.payProjectB.selector;
|
|
234
|
-
selectors[2] = EconomicHandler.payProjectC.selector;
|
|
235
|
-
selectors[3] = EconomicHandler.cashOutA.selector;
|
|
236
|
-
selectors[4] = EconomicHandler.cashOutB.selector;
|
|
237
|
-
selectors[5] = EconomicHandler.cashOutC.selector;
|
|
238
|
-
selectors[6] = EconomicHandler.sendPayoutsA.selector;
|
|
239
|
-
selectors[7] = EconomicHandler.sendPayoutsB.selector;
|
|
240
|
-
selectors[8] = EconomicHandler.sendPayoutsC.selector;
|
|
241
|
-
selectors[9] = EconomicHandler.addToBalanceA.selector;
|
|
242
|
-
selectors[10] = EconomicHandler.sendReservedTokensA.selector;
|
|
243
|
-
selectors[11] = EconomicHandler.sendReservedTokensC.selector;
|
|
244
|
-
selectors[12] = EconomicHandler.advanceTime.selector;
|
|
245
|
-
// Double-weight pay operations (more common in practice)
|
|
246
|
-
selectors[13] = EconomicHandler.payProjectA.selector;
|
|
247
|
-
selectors[14] = EconomicHandler.payProjectB.selector;
|
|
248
|
-
|
|
249
|
-
targetSelector(FuzzSelector({addr: address(handler), selectors: selectors}));
|
|
250
|
-
targetContract(address(handler));
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
// =========================================================================
|
|
254
|
-
// ECON1: Terminal balance >= sum of recorded balances for all projects
|
|
255
|
-
// =========================================================================
|
|
256
|
-
/// @notice The terminal's actual ETH balance must cover all recorded project balances.
|
|
257
|
-
function invariant_ECON1_terminalBalanceCoversAllProjects() public view {
|
|
258
|
-
uint256 balanceA = jbTerminalStore().balanceOf(address(jbMultiTerminal()), projectA, JBConstants.NATIVE_TOKEN);
|
|
259
|
-
uint256 balanceB = jbTerminalStore().balanceOf(address(jbMultiTerminal()), projectB, JBConstants.NATIVE_TOKEN);
|
|
260
|
-
uint256 balanceC = jbTerminalStore().balanceOf(address(jbMultiTerminal()), projectC, JBConstants.NATIVE_TOKEN);
|
|
261
|
-
uint256 balanceFee = jbTerminalStore().balanceOf(address(jbMultiTerminal()), 1, JBConstants.NATIVE_TOKEN);
|
|
262
|
-
|
|
263
|
-
uint256 totalRecorded = balanceA + balanceB + balanceC + balanceFee;
|
|
264
|
-
uint256 actualBalance = address(jbMultiTerminal()).balance;
|
|
265
|
-
|
|
266
|
-
assertGe(
|
|
267
|
-
actualBalance, totalRecorded, "ECON1: Terminal actual balance must >= sum of all project recorded balances"
|
|
268
|
-
);
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
// =========================================================================
|
|
272
|
-
// ECON2: Token supply consistency for each project
|
|
273
|
-
// =========================================================================
|
|
274
|
-
/// @notice For each project: totalSupplyOf >= 0 (non-negative, always true for uint).
|
|
275
|
-
/// Also verify total supply with reserves is >= raw supply.
|
|
276
|
-
function invariant_ECON2_tokenSupplyConsistency() public view {
|
|
277
|
-
uint256 supplyA = jbController().totalTokenSupplyWithReservedTokensOf(projectA);
|
|
278
|
-
uint256 supplyB = jbController().totalTokenSupplyWithReservedTokensOf(projectB);
|
|
279
|
-
uint256 supplyC = jbController().totalTokenSupplyWithReservedTokensOf(projectC);
|
|
280
|
-
|
|
281
|
-
// Supply with reserves should be >= 0 (always true for uint, but validates no underflow)
|
|
282
|
-
assertTrue(supplyA >= 0, "ECON2: Project A supply should be non-negative");
|
|
283
|
-
assertTrue(supplyB >= 0, "ECON2: Project B supply should be non-negative");
|
|
284
|
-
assertTrue(supplyC >= 0, "ECON2: Project C supply should be non-negative");
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
// =========================================================================
|
|
288
|
-
// ECON3: Conservation — total payments >= total outflows + remaining balances
|
|
289
|
-
// =========================================================================
|
|
290
|
-
/// @notice Accounting for fees: total inflows >= total outflows.
|
|
291
|
-
function invariant_ECON3_fundConservation() public view {
|
|
292
|
-
uint256 totalInflows = handler.ghost_totalPaidInA() + handler.ghost_totalPaidInB()
|
|
293
|
-
+ handler.ghost_totalPaidInC() + handler.ghost_totalAddedToBalanceA();
|
|
294
|
-
|
|
295
|
-
uint256 totalOutflows =
|
|
296
|
-
handler.ghost_totalCashedOutA() + handler.ghost_totalCashedOutB() + handler.ghost_totalCashedOutC();
|
|
297
|
-
|
|
298
|
-
// Inflows should always be >= outflows (fees are kept, not destroyed)
|
|
299
|
-
assertGe(totalInflows, totalOutflows, "ECON3: Total inflows must >= total outflows");
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
// =========================================================================
|
|
303
|
-
// ECON4: No agent extracts more from cashOut than they paid in
|
|
304
|
-
// (when cashOutTaxRate > 0 and no external addToBalance)
|
|
305
|
-
// =========================================================================
|
|
306
|
-
/// @notice With a 60% cash out tax on project A, no single actor should profit from cash outs alone.
|
|
307
|
-
/// Note: This invariant is only meaningful for project A (which has cash out tax).
|
|
308
|
-
function invariant_ECON4_noProfitFromCashOutAlone() public view {
|
|
309
|
-
// Check each actor's cash out vs paid in for Project A
|
|
310
|
-
for (uint256 i = 0; i < handler.NUM_ACTORS(); i++) {
|
|
311
|
-
address actor = handler.actors(i);
|
|
312
|
-
uint256 paidIn = handler.actorPaidInA(actor);
|
|
313
|
-
uint256 cashedOut = handler.actorCashedOutA(actor);
|
|
314
|
-
|
|
315
|
-
// With a 60% cash out tax rate, no actor should cash out more than they put in
|
|
316
|
-
// unless addToBalance was used (which inflates surplus without minting tokens)
|
|
317
|
-
if (handler.ghost_totalAddedToBalanceA() == 0) {
|
|
318
|
-
assertGe(paidIn, cashedOut, "ECON4: Actor should not profit from cash out with tax rate > 0");
|
|
319
|
-
}
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
|
|
323
|
-
// =========================================================================
|
|
324
|
-
// ECON5: Fee project balance monotonically increases
|
|
325
|
-
// =========================================================================
|
|
326
|
-
/// @notice Fee project (#1) balance should never decrease — fees only flow in.
|
|
327
|
-
function invariant_ECON5_feeProjectMonotonicallyIncreases() public view {
|
|
328
|
-
assertFalse(handler.ghost_feeProjectBalanceDecreased(), "ECON5: Fee project balance must never decrease");
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
// =========================================================================
|
|
332
|
-
// ECON6: Cross-project split cascade verification
|
|
333
|
-
// =========================================================================
|
|
334
|
-
/// @notice When project A sends payouts and has splits to project B,
|
|
335
|
-
/// project B's recorded balance should increase.
|
|
336
|
-
function invariant_ECON6_crossProjectSplitCascade() public view {
|
|
337
|
-
// This invariant verifies that if a split cascade occurred,
|
|
338
|
-
// it actually increased the target project's balance.
|
|
339
|
-
// The ghost variables track before/after for each payout.
|
|
340
|
-
if (handler.ghost_splitCascadeOccurred()) {
|
|
341
|
-
assertGt(
|
|
342
|
-
handler.ghost_projectBBalanceAfterSplit(),
|
|
343
|
-
handler.ghost_projectBBalanceBeforeSplit(),
|
|
344
|
-
"ECON6: Split to Project B should increase its balance"
|
|
345
|
-
);
|
|
346
|
-
}
|
|
347
|
-
}
|
|
348
|
-
}
|