@bananapus/core-v6 0.0.1
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/LICENSE +21 -0
- package/README.md +112 -0
- package/SKILLS.md +151 -0
- package/docs/book.css +13 -0
- package/docs/book.toml +12 -0
- package/docs/solidity.min.js +74 -0
- package/docs/src/README.md +703 -0
- package/docs/src/SUMMARY.md +94 -0
- package/docs/src/src/JBChainlinkV3PriceFeed.sol/contract.JBChainlinkV3PriceFeed.md +83 -0
- package/docs/src/src/JBChainlinkV3SequencerPriceFeed.sol/contract.JBChainlinkV3SequencerPriceFeed.md +88 -0
- package/docs/src/src/JBController.sol/contract.JBController.md +1121 -0
- package/docs/src/src/JBDeadline.sol/contract.JBDeadline.md +84 -0
- package/docs/src/src/JBDirectory.sol/contract.JBDirectory.md +294 -0
- package/docs/src/src/JBERC20.sol/contract.JBERC20.md +190 -0
- package/docs/src/src/JBFeelessAddresses.sol/contract.JBFeelessAddresses.md +80 -0
- package/docs/src/src/JBFundAccessLimits.sol/contract.JBFundAccessLimits.md +253 -0
- package/docs/src/src/JBMultiTerminal.sol/contract.JBMultiTerminal.md +1472 -0
- package/docs/src/src/JBPermissions.sol/contract.JBPermissions.md +199 -0
- package/docs/src/src/JBPrices.sol/contract.JBPrices.md +154 -0
- package/docs/src/src/JBProjects.sol/contract.JBProjects.md +131 -0
- package/docs/src/src/JBRulesets.sol/contract.JBRulesets.md +677 -0
- package/docs/src/src/JBSplits.sol/contract.JBSplits.md +237 -0
- package/docs/src/src/JBTerminalStore.sol/contract.JBTerminalStore.md +591 -0
- package/docs/src/src/JBTokens.sol/contract.JBTokens.md +353 -0
- package/docs/src/src/README.md +25 -0
- package/docs/src/src/abstract/JBControlled.sol/abstract.JBControlled.md +64 -0
- package/docs/src/src/abstract/JBPermissioned.sol/abstract.JBPermissioned.md +84 -0
- package/docs/src/src/abstract/README.md +5 -0
- package/docs/src/src/enums/JBApprovalStatus.sol/enum.JBApprovalStatus.md +17 -0
- package/docs/src/src/enums/README.md +4 -0
- package/docs/src/src/interfaces/IJBCashOutHook.sol/interface.IJBCashOutHook.md +29 -0
- package/docs/src/src/interfaces/IJBCashOutTerminal.sol/interface.IJBCashOutTerminal.md +57 -0
- package/docs/src/src/interfaces/IJBControlled.sol/interface.IJBControlled.md +12 -0
- package/docs/src/src/interfaces/IJBController.sol/interface.IJBController.md +334 -0
- package/docs/src/src/interfaces/IJBDirectory.sol/interface.IJBDirectory.md +108 -0
- package/docs/src/src/interfaces/IJBDirectoryAccessControl.sol/interface.IJBDirectoryAccessControl.md +19 -0
- package/docs/src/src/interfaces/IJBFeeTerminal.sol/interface.IJBFeeTerminal.md +91 -0
- package/docs/src/src/interfaces/IJBFeelessAddresses.sol/interface.IJBFeelessAddresses.md +26 -0
- package/docs/src/src/interfaces/IJBFundAccessLimits.sol/interface.IJBFundAccessLimits.md +88 -0
- package/docs/src/src/interfaces/IJBMigratable.sol/interface.IJBMigratable.md +29 -0
- package/docs/src/src/interfaces/IJBMultiTerminal.sol/interface.IJBMultiTerminal.md +50 -0
- package/docs/src/src/interfaces/IJBPayHook.sol/interface.IJBPayHook.md +28 -0
- package/docs/src/src/interfaces/IJBPayoutTerminal.sol/interface.IJBPayoutTerminal.md +105 -0
- package/docs/src/src/interfaces/IJBPermissioned.sol/interface.IJBPermissioned.md +12 -0
- package/docs/src/src/interfaces/IJBPermissions.sol/interface.IJBPermissions.md +74 -0
- package/docs/src/src/interfaces/IJBPermitTerminal.sol/interface.IJBPermitTerminal.md +15 -0
- package/docs/src/src/interfaces/IJBPriceFeed.sol/interface.IJBPriceFeed.md +12 -0
- package/docs/src/src/interfaces/IJBPrices.sol/interface.IJBPrices.md +74 -0
- package/docs/src/src/interfaces/IJBProjectUriRegistry.sol/interface.IJBProjectUriRegistry.md +19 -0
- package/docs/src/src/interfaces/IJBProjects.sol/interface.IJBProjects.md +49 -0
- package/docs/src/src/interfaces/IJBRulesetApprovalHook.sol/interface.IJBRulesetApprovalHook.md +35 -0
- package/docs/src/src/interfaces/IJBRulesetDataHook.sol/interface.IJBRulesetDataHook.md +97 -0
- package/docs/src/src/interfaces/IJBRulesets.sol/interface.IJBRulesets.md +165 -0
- package/docs/src/src/interfaces/IJBSplitHook.sol/interface.IJBSplitHook.md +31 -0
- package/docs/src/src/interfaces/IJBSplits.sol/interface.IJBSplits.md +35 -0
- package/docs/src/src/interfaces/IJBTerminal.sol/interface.IJBTerminal.md +141 -0
- package/docs/src/src/interfaces/IJBTerminalStore.sol/interface.IJBTerminalStore.md +198 -0
- package/docs/src/src/interfaces/IJBToken.sol/interface.IJBToken.md +54 -0
- package/docs/src/src/interfaces/IJBTokenUriResolver.sol/interface.IJBTokenUriResolver.md +12 -0
- package/docs/src/src/interfaces/IJBTokens.sol/interface.IJBTokens.md +151 -0
- package/docs/src/src/interfaces/README.md +33 -0
- package/docs/src/src/libraries/JBCashOuts.sol/library.JBCashOuts.md +40 -0
- package/docs/src/src/libraries/JBConstants.sol/library.JBConstants.md +52 -0
- package/docs/src/src/libraries/JBCurrencyIds.sol/library.JBCurrencyIds.md +19 -0
- package/docs/src/src/libraries/JBFees.sol/library.JBFees.md +52 -0
- package/docs/src/src/libraries/JBFixedPointNumber.sol/library.JBFixedPointNumber.md +12 -0
- package/docs/src/src/libraries/JBMetadataResolver.sol/library.JBMetadataResolver.md +242 -0
- package/docs/src/src/libraries/JBRulesetMetadataResolver.sol/library.JBRulesetMetadataResolver.md +180 -0
- package/docs/src/src/libraries/JBSplitGroupIds.sol/library.JBSplitGroupIds.md +14 -0
- package/docs/src/src/libraries/JBSurplus.sol/library.JBSurplus.md +44 -0
- package/docs/src/src/libraries/README.md +12 -0
- package/docs/src/src/periphery/JBDeadline1Day.sol/contract.JBDeadline1Day.md +15 -0
- package/docs/src/src/periphery/JBDeadline3Days.sol/contract.JBDeadline3Days.md +15 -0
- package/docs/src/src/periphery/JBDeadline3Hours.sol/contract.JBDeadline3Hours.md +15 -0
- package/docs/src/src/periphery/JBDeadline7Days.sol/contract.JBDeadline7Days.md +15 -0
- package/docs/src/src/periphery/JBMatchingPriceFeed.sol/contract.JBMatchingPriceFeed.md +22 -0
- package/docs/src/src/periphery/README.md +8 -0
- package/docs/src/src/structs/JBAccountingContext.sol/struct.JBAccountingContext.md +20 -0
- package/docs/src/src/structs/JBAfterCashOutRecordedContext.sol/struct.JBAfterCashOutRecordedContext.md +43 -0
- package/docs/src/src/structs/JBAfterPayRecordedContext.sol/struct.JBAfterPayRecordedContext.md +42 -0
- package/docs/src/src/structs/JBBeforeCashOutRecordedContext.sol/struct.JBBeforeCashOutRecordedContext.md +45 -0
- package/docs/src/src/structs/JBBeforePayRecordedContext.sol/struct.JBBeforePayRecordedContext.md +41 -0
- package/docs/src/src/structs/JBCashOutHookSpecification.sol/struct.JBCashOutHookSpecification.md +22 -0
- package/docs/src/src/structs/JBCurrencyAmount.sol/struct.JBCurrencyAmount.md +17 -0
- package/docs/src/src/structs/JBFee.sol/struct.JBFee.md +20 -0
- package/docs/src/src/structs/JBFundAccessLimitGroup.sol/struct.JBFundAccessLimitGroup.md +39 -0
- package/docs/src/src/structs/JBPayHookSpecification.sol/struct.JBPayHookSpecification.md +22 -0
- package/docs/src/src/structs/JBPermissionsData.sol/struct.JBPermissionsData.md +21 -0
- package/docs/src/src/structs/JBRuleset.sol/struct.JBRuleset.md +55 -0
- package/docs/src/src/structs/JBRulesetConfig.sol/struct.JBRulesetConfig.md +51 -0
- package/docs/src/src/structs/JBRulesetMetadata.sol/struct.JBRulesetMetadata.md +79 -0
- package/docs/src/src/structs/JBRulesetWeightCache.sol/struct.JBRulesetWeightCache.md +16 -0
- package/docs/src/src/structs/JBRulesetWithMetadata.sol/struct.JBRulesetWithMetadata.md +16 -0
- package/docs/src/src/structs/JBSingleAllowance.sol/struct.JBSingleAllowance.md +26 -0
- package/docs/src/src/structs/JBSplit.sol/struct.JBSplit.md +49 -0
- package/docs/src/src/structs/JBSplitGroup.sol/struct.JBSplitGroup.md +17 -0
- package/docs/src/src/structs/JBSplitHookContext.sol/struct.JBSplitHookContext.md +29 -0
- package/docs/src/src/structs/JBTerminalConfig.sol/struct.JBTerminalConfig.md +16 -0
- package/docs/src/src/structs/JBTokenAmount.sol/struct.JBTokenAmount.md +23 -0
- package/docs/src/src/structs/README.md +25 -0
- package/foundry.lock +11 -0
- package/foundry.toml +41 -0
- package/package.json +38 -0
- package/remappings.txt +1 -0
- package/script/Deploy.s.sol +111 -0
- package/script/DeployPeriphery.s.sol +287 -0
- package/script/helpers/CoreDeploymentLib.sol +121 -0
- package/slither-ci.config.json +10 -0
- package/sphinx.lock +507 -0
- package/src/JBChainlinkV3PriceFeed.sol +77 -0
- package/src/JBChainlinkV3SequencerPriceFeed.sol +75 -0
- package/src/JBController.sol +1186 -0
- package/src/JBDeadline.sol +73 -0
- package/src/JBDirectory.sol +343 -0
- package/src/JBERC20.sol +131 -0
- package/src/JBFeelessAddresses.sol +54 -0
- package/src/JBFundAccessLimits.sol +308 -0
- package/src/JBMultiTerminal.sol +2024 -0
- package/src/JBPermissions.sol +252 -0
- package/src/JBPrices.sol +227 -0
- package/src/JBProjects.sol +126 -0
- package/src/JBRulesets.sol +1093 -0
- package/src/JBSplits.sol +324 -0
- package/src/JBTerminalStore.sol +908 -0
- package/src/JBTokens.sol +376 -0
- package/src/abstract/JBControlled.sol +48 -0
- package/src/abstract/JBPermissioned.sol +77 -0
- package/src/enums/JBApprovalStatus.sol +12 -0
- package/src/interfaces/IJBCashOutHook.sol +15 -0
- package/src/interfaces/IJBCashOutTerminal.sol +51 -0
- package/src/interfaces/IJBControlled.sol +10 -0
- package/src/interfaces/IJBController.sol +280 -0
- package/src/interfaces/IJBDirectory.sol +69 -0
- package/src/interfaces/IJBDirectoryAccessControl.sol +15 -0
- package/src/interfaces/IJBFeeTerminal.sol +61 -0
- package/src/interfaces/IJBFeelessAddresses.sol +17 -0
- package/src/interfaces/IJBFundAccessLimits.sol +94 -0
- package/src/interfaces/IJBMigratable.sol +24 -0
- package/src/interfaces/IJBMultiTerminal.sol +36 -0
- package/src/interfaces/IJBPayHook.sol +14 -0
- package/src/interfaces/IJBPayoutTerminal.sol +92 -0
- package/src/interfaces/IJBPermissioned.sol +10 -0
- package/src/interfaces/IJBPermissions.sol +71 -0
- package/src/interfaces/IJBPermitTerminal.sol +14 -0
- package/src/interfaces/IJBPriceFeed.sol +10 -0
- package/src/interfaces/IJBPrices.sol +65 -0
- package/src/interfaces/IJBProjectUriRegistry.sol +15 -0
- package/src/interfaces/IJBProjects.sol +27 -0
- package/src/interfaces/IJBRulesetApprovalHook.sol +21 -0
- package/src/interfaces/IJBRulesetDataHook.sol +56 -0
- package/src/interfaces/IJBRulesets.sol +151 -0
- package/src/interfaces/IJBSplitHook.sol +16 -0
- package/src/interfaces/IJBSplits.sol +28 -0
- package/src/interfaces/IJBTerminal.sol +120 -0
- package/src/interfaces/IJBTerminalStore.sol +225 -0
- package/src/interfaces/IJBToken.sol +39 -0
- package/src/interfaces/IJBTokenUriResolver.sol +10 -0
- package/src/interfaces/IJBTokens.sol +113 -0
- package/src/libraries/JBCashOuts.sol +120 -0
- package/src/libraries/JBConstants.sol +14 -0
- package/src/libraries/JBCurrencyIds.sol +7 -0
- package/src/libraries/JBFees.sol +28 -0
- package/src/libraries/JBFixedPointNumber.sol +12 -0
- package/src/libraries/JBMetadataResolver.sol +306 -0
- package/src/libraries/JBRulesetMetadataResolver.sol +160 -0
- package/src/libraries/JBSplitGroupIds.sol +7 -0
- package/src/libraries/JBSurplus.sol +40 -0
- package/src/periphery/JBDeadline1Day.sol +8 -0
- package/src/periphery/JBDeadline3Days.sol +8 -0
- package/src/periphery/JBDeadline3Hours.sol +8 -0
- package/src/periphery/JBDeadline7Days.sol +8 -0
- package/src/periphery/JBMatchingPriceFeed.sol +13 -0
- package/src/structs/JBAccountingContext.sol +12 -0
- package/src/structs/JBAfterCashOutRecordedContext.sol +30 -0
- package/src/structs/JBAfterPayRecordedContext.sol +29 -0
- package/src/structs/JBBeforeCashOutRecordedContext.sol +31 -0
- package/src/structs/JBBeforePayRecordedContext.sol +28 -0
- package/src/structs/JBCashOutHookSpecification.sol +15 -0
- package/src/structs/JBCurrencyAmount.sol +10 -0
- package/src/structs/JBFee.sol +12 -0
- package/src/structs/JBFundAccessLimitGroup.sol +28 -0
- package/src/structs/JBPayHookSpecification.sol +15 -0
- package/src/structs/JBPermissionsData.sol +13 -0
- package/src/structs/JBRuleset.sol +42 -0
- package/src/structs/JBRulesetConfig.sol +43 -0
- package/src/structs/JBRulesetMetadata.sol +56 -0
- package/src/structs/JBRulesetWeightCache.sol +9 -0
- package/src/structs/JBRulesetWithMetadata.sol +12 -0
- package/src/structs/JBSingleAllowance.sol +16 -0
- package/src/structs/JBSplit.sol +37 -0
- package/src/structs/JBSplitGroup.sol +12 -0
- package/src/structs/JBSplitHookContext.sol +20 -0
- package/src/structs/JBTerminalConfig.sol +12 -0
- package/src/structs/JBTokenAmount.sol +14 -0
- package/test/AuditExploits.t.sol +2710 -0
- package/test/ComprehensiveInvariant.t.sol +298 -0
- package/test/EconomicSimulation.t.sol +340 -0
- package/test/EntryPointPermutations.t.sol +671 -0
- package/test/FlashLoanAttacks.t.sol +792 -0
- package/test/PermissionEscalation.t.sol +679 -0
- package/test/RulesetTransitions.t.sol +699 -0
- package/test/SplitLoopTests.t.sol +731 -0
- package/test/TestAccessToFunds.sol +2644 -0
- package/test/TestCashOut.sol +185 -0
- package/test/TestCashOutCountFor.sol +272 -0
- package/test/TestCashOutHooks.sol +317 -0
- package/test/TestCashOutTimingEdge.sol +229 -0
- package/test/TestDurationUnderflow.sol +220 -0
- package/test/TestFeeProcessingFailure.sol +208 -0
- package/test/TestFees.sol +604 -0
- package/test/TestInterfaceSupport.sol +62 -0
- package/test/TestJBERC20Inheritance.sol +91 -0
- package/test/TestLaunchProject.sol +176 -0
- package/test/TestMetaTx.sol +203 -0
- package/test/TestMetadataParserLib.sol +438 -0
- package/test/TestMigrationHeldFees.sol +249 -0
- package/test/TestMintTokensOf.sol +172 -0
- package/test/TestMultiTokenSurplus.sol +206 -0
- package/test/TestMultipleAccessLimits.sol +642 -0
- package/test/TestPayBurnRedeemFlow.sol +180 -0
- package/test/TestPayHooks.sol +190 -0
- package/test/TestPermissions.sol +305 -0
- package/test/TestPermissionsEdge.sol +286 -0
- package/test/TestPermit2Terminal.sol +339 -0
- package/test/TestRulesetQueueing.sol +1001 -0
- package/test/TestRulesetQueuingStress.sol +778 -0
- package/test/TestRulesetWeightCaching.sol +177 -0
- package/test/TestSplits.sol +369 -0
- package/test/TestTerminalMigration.sol +167 -0
- package/test/TestTokenFlow.sol +174 -0
- package/test/WeirdTokenTests.t.sol +764 -0
- package/test/formal/BondingCurveProperties.t.sol +411 -0
- package/test/formal/FeeProperties.t.sol +246 -0
- package/test/helpers/JBTest.sol +129 -0
- package/test/helpers/MetadataResolverHelper.sol +116 -0
- package/test/helpers/TestBaseWorkflow.sol +317 -0
- package/test/invariants/Phase3DeepInvariant.t.sol +404 -0
- package/test/invariants/RulesetsInvariant.t.sol +115 -0
- package/test/invariants/TerminalStoreInvariant.t.sol +220 -0
- package/test/invariants/TokensInvariant.t.sol +184 -0
- package/test/invariants/handlers/ComprehensiveHandler.sol +285 -0
- package/test/invariants/handlers/EconomicHandler.sol +347 -0
- package/test/invariants/handlers/Phase3Handler.sol +414 -0
- package/test/invariants/handlers/RulesetsHandler.sol +111 -0
- package/test/invariants/handlers/TerminalStoreHandler.sol +146 -0
- package/test/invariants/handlers/TokensHandler.sol +127 -0
- package/test/mock/ERC2771ForwarderMock.sol +37 -0
- package/test/mock/MockERC20.sol +18 -0
- package/test/mock/MockMaliciousBeneficiary.sol +67 -0
- package/test/mock/MockMaliciousSplitHook.sol +42 -0
- package/test/mock/MockPriceFeed.sol +20 -0
- package/test/trees/JBController/burnTokensOf.tree +9 -0
- package/test/trees/JBController/claimTokensFor.tree +5 -0
- package/test/trees/JBController/deployERC20For.tree +5 -0
- package/test/trees/JBController/getRulesetOf.tree +5 -0
- package/test/trees/JBController/launchProjectFor.tree +12 -0
- package/test/trees/JBController/launchRulesetsFor.tree +8 -0
- package/test/trees/JBController/migrateController.tree +12 -0
- package/test/trees/JBController/mintTokensOf.tree +12 -0
- package/test/trees/JBController/payReservedTokenToTerminal.tree +8 -0
- package/test/trees/JBController/receiveMigrationFrom.tree +4 -0
- package/test/trees/JBController/sendReservedTokensToSplitsOf.tree +12 -0
- package/test/trees/JBController/setMetadataOf.tree +5 -0
- package/test/trees/JBController/setSplitGroupsOf.tree +5 -0
- package/test/trees/JBController/setTokenFor.tree +5 -0
- package/test/trees/JBController/transferCreditsFrom.tree +8 -0
- package/test/trees/JBDirectory/primaryTerminalOf.tree +8 -0
- package/test/trees/JBDirectory/setControllerOf.tree +11 -0
- package/test/trees/JBDirectory/setPrimaryTerminalOf.tree +15 -0
- package/test/trees/JBDirectory/setTerminalsOf.tree +11 -0
- package/test/trees/JBERC20/initialize.tree +7 -0
- package/test/trees/JBERC20/name.tree +5 -0
- package/test/trees/JBERC20/nonces.tree +5 -0
- package/test/trees/JBERC20/symbol.tree +5 -0
- package/test/trees/JBFeelessAddresses/setFeelessAddress.tree +5 -0
- package/test/trees/JBFeelessAddresses/supportsInterface.tree +5 -0
- package/test/trees/JBFundAccessLimits/payoutLimitOf.tree +5 -0
- package/test/trees/JBFundAccessLimits/payoutLimitsOf.tree +8 -0
- package/test/trees/JBFundAccessLimits/setFundAccessLimitsFor.tree +18 -0
- package/test/trees/JBFundAccessLimits/surplusAllowanceOf.tree +5 -0
- package/test/trees/JBFundAccessLimits/surplusAllowancesOf.tree +8 -0
- package/test/trees/JBMetadataResolver/getDataFor.tree +8 -0
- package/test/trees/JBMultiTerminal/accountingContextsOf.tree +5 -0
- package/test/trees/JBMultiTerminal/addAccountingContextsFor.tree +10 -0
- package/test/trees/JBMultiTerminal/addToBalanceOf.tree +23 -0
- package/test/trees/JBMultiTerminal/cashOutTokensOf.tree +23 -0
- package/test/trees/JBMultiTerminal/executePayout.tree +32 -0
- package/test/trees/JBMultiTerminal/executeProcessFee.tree +14 -0
- package/test/trees/JBMultiTerminal/migrateBalanceOf.tree +12 -0
- package/test/trees/JBMultiTerminal/pay.tree +23 -0
- package/test/trees/JBMultiTerminal/processHeldFeesOf.tree +8 -0
- package/test/trees/JBMultiTerminal/sendPayoutsOf.tree +34 -0
- package/test/trees/JBMultiTerminal/useAllowanceOf.tree +16 -0
- package/test/trees/JBPermissions/hasPermission.tree +8 -0
- package/test/trees/JBPermissions/hasPermissions.tree +8 -0
- package/test/trees/JBPermissions/setPermissionsFor.tree +5 -0
- package/test/trees/JBPrices/addPriceFeedFor.tree +14 -0
- package/test/trees/JBPrices/pricePerUnitOf.tree +11 -0
- package/test/trees/JBProjects/createFor.tree +11 -0
- package/test/trees/JBProjects/setTokenUriResolver.tree +5 -0
- package/test/trees/JBProjects/supportsInterface.tree +9 -0
- package/test/trees/JBProjects/tokenURI.tree +5 -0
- package/test/trees/JBRulesets/currentApprovalStatusForLatestRulesetOf.tree +8 -0
- package/test/trees/JBRulesets/currentOf.tree +12 -0
- package/test/trees/JBRulesets/getRulesetOf.tree +5 -0
- package/test/trees/JBRulesets/latestQueuedRulesetOf.tree +10 -0
- package/test/trees/JBRulesets/rulesetsOf.tree +11 -0
- package/test/trees/JBRulesets/upcomingRulesetOf.tree +20 -0
- package/test/trees/JBRulesets/updateRulesetWeightCache.tree +5 -0
- package/test/trees/JBSplits/setSplitGroupsOf.tree +17 -0
- package/test/trees/JBSplits/splitsOf.tree +5 -0
- package/test/trees/JBTerminalStore/currentReclaimableSurplusOf.tree +16 -0
- package/test/trees/JBTerminalStore/currentSurplusOf.tree +25 -0
- package/test/trees/JBTerminalStore/currentTotalSurplusOf.tree +5 -0
- package/test/trees/JBTerminalStore/recordCashOutsFor.tree +16 -0
- package/test/trees/JBTerminalStore/recordPaymentFrom.tree +14 -0
- package/test/trees/JBTerminalStore/recordPayoutFor.tree +10 -0
- package/test/trees/JBTerminalStore/recordTerminalMigration.tree +5 -0
- package/test/trees/JBTerminalStore/recordUsedAllowanceOf.tree +10 -0
- package/test/trees/JBTokens/burnFrom.tree +10 -0
- package/test/trees/JBTokens/claimTokensFor.tree +10 -0
- package/test/trees/JBTokens/deployERC20For.tree +12 -0
- package/test/trees/JBTokens/mintFor.tree +10 -0
- package/test/trees/JBTokens/setTokenFor.tree +11 -0
- package/test/trees/JBTokens/totalBalanceOf.tree +5 -0
- package/test/trees/JBTokens/totalSupplyOf.tree +5 -0
- package/test/trees/JBTokens/transferCreditsFrom.tree +8 -0
- package/test/trees/mintTokensOf.tree +12 -0
- package/test/units/static/JBChainlinkV3PriceFeed/TestPriceFeed.sol +220 -0
- package/test/units/static/JBController/JBControllerSetup.sol +40 -0
- package/test/units/static/JBController/TestBurnTokensOf.sol +107 -0
- package/test/units/static/JBController/TestClaimTokensFor.sol +60 -0
- package/test/units/static/JBController/TestDeployErc20For.sol +80 -0
- package/test/units/static/JBController/TestLaunchProjectFor.sol +282 -0
- package/test/units/static/JBController/TestLaunchRulesetsFor.sol +322 -0
- package/test/units/static/JBController/TestMigrateController.sol +148 -0
- package/test/units/static/JBController/TestMintTokensOfUnits.sol +102 -0
- package/test/units/static/JBController/TestPayReservedTokenToTerminal.sol +71 -0
- package/test/units/static/JBController/TestReceiveMigrationFrom.sol +95 -0
- package/test/units/static/JBController/TestRulesetViews.sol +219 -0
- package/test/units/static/JBController/TestSendReservedTokensToSplitsOf.sol +595 -0
- package/test/units/static/JBController/TestSetSplitGroupsOf.sol +63 -0
- package/test/units/static/JBController/TestSetTokenFor.sol +227 -0
- package/test/units/static/JBController/TestSetUriOf.sol +53 -0
- package/test/units/static/JBController/TestTransferCreditsFrom.sol +159 -0
- package/test/units/static/JBDeadline/TestDeadlineFuzz.sol +194 -0
- package/test/units/static/JBDirectory/JBDirectorySetup.sol +22 -0
- package/test/units/static/JBDirectory/TestPrimaryTerminalOf.sol +122 -0
- package/test/units/static/JBDirectory/TestSetControllerOf.sol +173 -0
- package/test/units/static/JBDirectory/TestSetControllerOfMigrationOrder.sol +98 -0
- package/test/units/static/JBDirectory/TestSetPrimaryTerminalOf.sol +169 -0
- package/test/units/static/JBDirectory/TestSetTerminalsOf.sol +128 -0
- package/test/units/static/JBERC20/JBERC20Setup.sol +20 -0
- package/test/units/static/JBERC20/SigUtils.sol +34 -0
- package/test/units/static/JBERC20/TestInitialize.sol +54 -0
- package/test/units/static/JBERC20/TestName.sol +30 -0
- package/test/units/static/JBERC20/TestNonces.sol +59 -0
- package/test/units/static/JBERC20/TestSymbol.sol +31 -0
- package/test/units/static/JBFeelessAdresses/JBFeelessSetup.sol +20 -0
- package/test/units/static/JBFeelessAdresses/TestInterfaces.sol +29 -0
- package/test/units/static/JBFeelessAdresses/TestSetFeelessAddress.sol +35 -0
- package/test/units/static/JBFees/TestFeesFuzz.sol +78 -0
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimals.sol +16 -0
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimalsFuzz.sol +71 -0
- package/test/units/static/JBFundAccessLimits/JBFundAccessSetup.sol +21 -0
- package/test/units/static/JBFundAccessLimits/TestFundAccessLimitsEdge.sol +159 -0
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitOf.sol +56 -0
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitsOf.sol +94 -0
- package/test/units/static/JBFundAccessLimits/TestSetFundAccessLimitsFor.sol +182 -0
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowanceOf.sol +61 -0
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowancesOf.sol +96 -0
- package/test/units/static/JBMetadataResolver/TestGetDataFor.sol +89 -0
- package/test/units/static/JBMetadataResolver/TestMetadataResolverFuzz.sol +227 -0
- package/test/units/static/JBMetadataResolver/TestMetadataResolverM20M21.sol +245 -0
- package/test/units/static/JBMultiTerminal/JBMultiTerminalSetup.sol +39 -0
- package/test/units/static/JBMultiTerminal/TestAccountingContextsOf.sol +65 -0
- package/test/units/static/JBMultiTerminal/TestAddAccountingContextsFor.sol +313 -0
- package/test/units/static/JBMultiTerminal/TestAddToBalanceOf.sol +432 -0
- package/test/units/static/JBMultiTerminal/TestCashOutTokensOf.sol +478 -0
- package/test/units/static/JBMultiTerminal/TestExecutePayout.sol +577 -0
- package/test/units/static/JBMultiTerminal/TestExecuteProcessFee.sol +176 -0
- package/test/units/static/JBMultiTerminal/TestMigrateBalanceOf.sol +190 -0
- package/test/units/static/JBMultiTerminal/TestPay.sol +514 -0
- package/test/units/static/JBMultiTerminal/TestProcessHeldFeesOf.sol +29 -0
- package/test/units/static/JBMultiTerminal/TestSendPayoutsOf.sol +243 -0
- package/test/units/static/JBMultiTerminal/TestUseAllowanceOf.sol +310 -0
- package/test/units/static/JBPermissions/JBPermissionsSetup.sol +18 -0
- package/test/units/static/JBPermissions/TestHasPermission.sol +50 -0
- package/test/units/static/JBPermissions/TestHasPermissions.sol +93 -0
- package/test/units/static/JBPermissions/TestSetPermissionsFor.sol +62 -0
- package/test/units/static/JBPrices/JBPricesSetup.sol +26 -0
- package/test/units/static/JBPrices/TestAddPriceFeedFor.sol +102 -0
- package/test/units/static/JBPrices/TestPricePerUnitOf.sol +129 -0
- package/test/units/static/JBPrices/TestPrices.sol +262 -0
- package/test/units/static/JBProjects/JBProjectsSetup.sol +20 -0
- package/test/units/static/JBProjects/TestCreateFor.sol +69 -0
- package/test/units/static/JBProjects/TestInitialProject.sol +19 -0
- package/test/units/static/JBProjects/TestInterfaces.sol +27 -0
- package/test/units/static/JBProjects/TestSetResolver.sol +36 -0
- package/test/units/static/JBProjects/TestTokenUri.sol +38 -0
- package/test/units/static/JBRulesetMetadataResolver/TestSetCashOutTaxRateTo.sol +99 -0
- package/test/units/static/JBRulesets/JBRulesetsSetup.sol +21 -0
- package/test/units/static/JBRulesets/TestCurrentApprovalStatusForLatestRulesetOf.sol +257 -0
- package/test/units/static/JBRulesets/TestCurrentOf.sol +231 -0
- package/test/units/static/JBRulesets/TestGetRulesetOf.sol +94 -0
- package/test/units/static/JBRulesets/TestLatestQueuedRulesetOf.sol +252 -0
- package/test/units/static/JBRulesets/TestRulesets.sol +617 -0
- package/test/units/static/JBRulesets/TestRulesetsOf.sol +37 -0
- package/test/units/static/JBRulesets/TestUpcomingRulesetOf.sol +526 -0
- package/test/units/static/JBRulesets/TestUpdateRulesetWeightCache.sol +91 -0
- package/test/units/static/JBSplits/JBSplitsSetup.sol +23 -0
- package/test/units/static/JBSplits/TestSelfManagedSplitGroups.sol +502 -0
- package/test/units/static/JBSplits/TestSetSplitGroupsOf.sol +370 -0
- package/test/units/static/JBSplits/TestSplitsLockedEdge.sol +262 -0
- package/test/units/static/JBSplits/TestSplitsOf.sol +24 -0
- package/test/units/static/JBSplits/TestSplitsPacking.sol +33 -0
- package/test/units/static/JBSurplus/TestSurplusFuzz.sol +125 -0
- package/test/units/static/JBTerminalStore/JBTerminalStoreSetup.sol +23 -0
- package/test/units/static/JBTerminalStore/TestCurrentReclaimableSurplusOf.sol +434 -0
- package/test/units/static/JBTerminalStore/TestCurrentSurplusOf.sol +428 -0
- package/test/units/static/JBTerminalStore/TestCurrentTotalSurplusOf.sol +65 -0
- package/test/units/static/JBTerminalStore/TestRecordCashOutsFor.sol +479 -0
- package/test/units/static/JBTerminalStore/TestRecordPaymentFrom.sol +508 -0
- package/test/units/static/JBTerminalStore/TestRecordPayoutFor.sol +257 -0
- package/test/units/static/JBTerminalStore/TestRecordTerminalMigration.sol +131 -0
- package/test/units/static/JBTerminalStore/TestRecordUsedAllowanceOf.sol +390 -0
- package/test/units/static/JBTerminalStore/TestUint224Overflow.sol +187 -0
- package/test/units/static/JBTokens/JBTokensSetup.sol +23 -0
- package/test/units/static/JBTokens/TestBurnFrom.sol +104 -0
- package/test/units/static/JBTokens/TestClaimTokensFor.sol +107 -0
- package/test/units/static/JBTokens/TestDeployERC20ForUnits.sol +89 -0
- package/test/units/static/JBTokens/TestMintFor.sol +97 -0
- package/test/units/static/JBTokens/TestSetTokenFor.sol +95 -0
- package/test/units/static/JBTokens/TestTotalBalanceOf.sol +65 -0
- package/test/units/static/JBTokens/TestTotalSupplyOf.sol +56 -0
- package/test/units/static/JBTokens/TestTransferCreditsFrom.sol +54 -0
|
@@ -0,0 +1,370 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
|
2
|
+
pragma solidity 0.8.23;
|
|
3
|
+
|
|
4
|
+
import /* {*} from */ "../../../helpers/TestBaseWorkflow.sol";
|
|
5
|
+
import {JBSplitsSetup} from "./JBSplitsSetup.sol";
|
|
6
|
+
|
|
7
|
+
contract TestSetSplitGroupsOf_Local is JBSplitsSetup {
|
|
8
|
+
address _notThis = makeAddr("notThis");
|
|
9
|
+
address payable _bene = payable(makeAddr("guy"));
|
|
10
|
+
uint64 _projectId = 1;
|
|
11
|
+
uint256 _rulesetId = block.timestamp;
|
|
12
|
+
|
|
13
|
+
function setUp() public {
|
|
14
|
+
super.splitsSetup();
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
function test_WhenCallerIsNotController() external {
|
|
18
|
+
// it will revert with CONTROLLER_UNAUTHORIZED
|
|
19
|
+
|
|
20
|
+
// data for call
|
|
21
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
22
|
+
JBSplit[] memory _splitsArray = new JBSplit[](1);
|
|
23
|
+
|
|
24
|
+
// Set up a payout split recipient.
|
|
25
|
+
_splitsArray[0] = JBSplit({
|
|
26
|
+
preferAddToBalance: false,
|
|
27
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
28
|
+
projectId: _projectId,
|
|
29
|
+
beneficiary: _bene,
|
|
30
|
+
lockedUntil: 0,
|
|
31
|
+
hook: IJBSplitHook(address(0))
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
// outer structure
|
|
35
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
36
|
+
|
|
37
|
+
// mock the directory controllerOf call
|
|
38
|
+
bytes memory _controllerCall = abi.encodeCall(IJBDirectory.controllerOf, (1));
|
|
39
|
+
bytes memory _return = abi.encode(_notThis);
|
|
40
|
+
mockExpect(address(directory), _controllerCall, _return);
|
|
41
|
+
|
|
42
|
+
// not controller so revert
|
|
43
|
+
vm.expectRevert(abi.encodeWithSelector(JBControlled.JBControlled_ControllerUnauthorized.selector, _notThis));
|
|
44
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
modifier whenCallerIsController() {
|
|
48
|
+
// mock the directory controllerOf call
|
|
49
|
+
bytes memory _controllerCall = abi.encodeCall(IJBDirectory.controllerOf, (1));
|
|
50
|
+
bytes memory _return = abi.encode(address(this));
|
|
51
|
+
mockExpect(address(directory), _controllerCall, _return);
|
|
52
|
+
_;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function test_GivenPreviouslyLockedSplitsAreNotIncluded() external whenCallerIsController {
|
|
56
|
+
// it will revert with PREVIOUS_LOCKED_SPLITS_NOT_INCLUDED
|
|
57
|
+
|
|
58
|
+
// data for first call to set locked splits
|
|
59
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
60
|
+
JBSplit[] memory _splitsArray = new JBSplit[](1);
|
|
61
|
+
|
|
62
|
+
// Set up a payout split recipient.
|
|
63
|
+
_splitsArray[0] = JBSplit({
|
|
64
|
+
preferAddToBalance: false,
|
|
65
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
66
|
+
projectId: _projectId,
|
|
67
|
+
beneficiary: _bene,
|
|
68
|
+
lockedUntil: uint48(block.timestamp + 100),
|
|
69
|
+
hook: IJBSplitHook(address(0))
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
// outer structure
|
|
73
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
74
|
+
|
|
75
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
76
|
+
|
|
77
|
+
// Re-set up a payout split recipient.
|
|
78
|
+
_splitsArray[0] = JBSplit({
|
|
79
|
+
preferAddToBalance: false,
|
|
80
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
81
|
+
projectId: _projectId,
|
|
82
|
+
beneficiary: _bene,
|
|
83
|
+
lockedUntil: 0,
|
|
84
|
+
hook: IJBSplitHook(address(0))
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
// outer structure
|
|
88
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
89
|
+
|
|
90
|
+
vm.expectRevert(
|
|
91
|
+
abi.encodeWithSelector(JBSplits.JBSplits_PreviousLockedSplitsNotIncluded.selector, _projectId, _rulesetId)
|
|
92
|
+
);
|
|
93
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
function test_GivenAnyConfiguredSplitPercentIsZero() external whenCallerIsController {
|
|
97
|
+
// it will revert with INVALID_SPLIT_PERCENT
|
|
98
|
+
|
|
99
|
+
// data for call to set invalid splits
|
|
100
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
101
|
+
JBSplit[] memory _splitsArray = new JBSplit[](1);
|
|
102
|
+
|
|
103
|
+
// Set up a payout split recipient.
|
|
104
|
+
_splitsArray[0] = JBSplit({
|
|
105
|
+
preferAddToBalance: false,
|
|
106
|
+
// invalid percent
|
|
107
|
+
percent: 0,
|
|
108
|
+
projectId: _projectId,
|
|
109
|
+
beneficiary: _bene,
|
|
110
|
+
lockedUntil: 0,
|
|
111
|
+
hook: IJBSplitHook(address(0))
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
// outer structure
|
|
115
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
116
|
+
|
|
117
|
+
vm.expectRevert(JBSplits.JBSplits_ZeroSplitPercent.selector);
|
|
118
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
function test_GivenSplitsTotalToGtSPLITS_TOTAL_PERCENT() external whenCallerIsController {
|
|
122
|
+
// it will revert with INVALID_TOTAL_PERCENT
|
|
123
|
+
|
|
124
|
+
// data for call with total percent > 100
|
|
125
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
126
|
+
JBSplit[] memory _splitsArray = new JBSplit[](2);
|
|
127
|
+
|
|
128
|
+
// Set up a payout split recipient.
|
|
129
|
+
_splitsArray[0] = JBSplit({
|
|
130
|
+
preferAddToBalance: false,
|
|
131
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
132
|
+
projectId: _projectId,
|
|
133
|
+
beneficiary: _bene,
|
|
134
|
+
lockedUntil: 0,
|
|
135
|
+
hook: IJBSplitHook(address(0))
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
// Set up a second payout split recipient.
|
|
139
|
+
_splitsArray[1] = JBSplit({
|
|
140
|
+
preferAddToBalance: false,
|
|
141
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT,
|
|
142
|
+
projectId: _projectId,
|
|
143
|
+
beneficiary: _bene,
|
|
144
|
+
lockedUntil: 0,
|
|
145
|
+
hook: IJBSplitHook(address(0))
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
// outer structure
|
|
149
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
150
|
+
|
|
151
|
+
vm.expectRevert(JBSplits.JBSplits_TotalPercentExceeds100.selector);
|
|
152
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
function test_HappyPath() external whenCallerIsController {
|
|
156
|
+
// it will store splits and emit SetSplit for each configured
|
|
157
|
+
|
|
158
|
+
// data for call
|
|
159
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
160
|
+
JBSplit[] memory _splitsArray = new JBSplit[](2);
|
|
161
|
+
|
|
162
|
+
// Set up a valid payout split recipient.
|
|
163
|
+
_splitsArray[0] = JBSplit({
|
|
164
|
+
preferAddToBalance: false,
|
|
165
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
166
|
+
projectId: _projectId,
|
|
167
|
+
beneficiary: _bene,
|
|
168
|
+
lockedUntil: 0,
|
|
169
|
+
hook: IJBSplitHook(address(0))
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
// Set up a second valid payout split recipient.
|
|
173
|
+
_splitsArray[1] = JBSplit({
|
|
174
|
+
preferAddToBalance: false,
|
|
175
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
176
|
+
projectId: _projectId,
|
|
177
|
+
beneficiary: payable(makeAddr("anotherBene")),
|
|
178
|
+
lockedUntil: 0,
|
|
179
|
+
hook: IJBSplitHook(address(0))
|
|
180
|
+
});
|
|
181
|
+
|
|
182
|
+
// outer structure
|
|
183
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
184
|
+
|
|
185
|
+
// should emit an event for each split
|
|
186
|
+
vm.expectEmit();
|
|
187
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _splitsArray[0], address(this));
|
|
188
|
+
|
|
189
|
+
vm.expectEmit();
|
|
190
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _splitsArray[1], address(this));
|
|
191
|
+
|
|
192
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
function test_GivenSettingExistingIdDomainAndGroup() external whenCallerIsController {
|
|
196
|
+
// it will overwrite
|
|
197
|
+
|
|
198
|
+
// data for call
|
|
199
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
200
|
+
JBSplit[] memory _splitsArray = new JBSplit[](1);
|
|
201
|
+
|
|
202
|
+
// Set up a payout split recipient.
|
|
203
|
+
_splitsArray[0] = JBSplit({
|
|
204
|
+
preferAddToBalance: false,
|
|
205
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
206
|
+
projectId: _projectId,
|
|
207
|
+
beneficiary: _bene,
|
|
208
|
+
lockedUntil: 0,
|
|
209
|
+
hook: IJBSplitHook(address(0))
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
// outer structure
|
|
213
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
214
|
+
|
|
215
|
+
vm.expectEmit();
|
|
216
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _splitsArray[0], address(this));
|
|
217
|
+
|
|
218
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
219
|
+
|
|
220
|
+
// Second or "reconfig" call
|
|
221
|
+
|
|
222
|
+
// Re-Set up a payout split recipient.
|
|
223
|
+
_splitsArray[0] = JBSplit({
|
|
224
|
+
// Different attributes
|
|
225
|
+
preferAddToBalance: true,
|
|
226
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 3,
|
|
227
|
+
projectId: _projectId,
|
|
228
|
+
beneficiary: _bene,
|
|
229
|
+
lockedUntil: 0,
|
|
230
|
+
hook: IJBSplitHook(address(0))
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
// outer structure
|
|
234
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
235
|
+
|
|
236
|
+
vm.expectEmit();
|
|
237
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _splitsArray[0], address(this));
|
|
238
|
+
|
|
239
|
+
_splits.setSplitGroupsOf(_projectId, block.timestamp, _splitsGroup);
|
|
240
|
+
|
|
241
|
+
JBSplit[] memory _current = _splits.splitsOf(_projectId, block.timestamp, 0);
|
|
242
|
+
|
|
243
|
+
assertEq(_current[0].preferAddToBalance, true);
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
function test_GivenAddingNewLockedSplitsIncludingPreviouslyLocked() external whenCallerIsController {
|
|
247
|
+
// it will reconfigure and extend previously locked splits
|
|
248
|
+
|
|
249
|
+
// data for call
|
|
250
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
251
|
+
JBSplit[] memory _splitsArray = new JBSplit[](1);
|
|
252
|
+
|
|
253
|
+
// Set up a payout split recipient.
|
|
254
|
+
_splitsArray[0] = JBSplit({
|
|
255
|
+
preferAddToBalance: false,
|
|
256
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
257
|
+
projectId: _projectId,
|
|
258
|
+
beneficiary: _bene,
|
|
259
|
+
lockedUntil: uint48(block.timestamp + 100),
|
|
260
|
+
hook: IJBSplitHook(address(0))
|
|
261
|
+
});
|
|
262
|
+
|
|
263
|
+
// outer structure
|
|
264
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
265
|
+
|
|
266
|
+
vm.expectEmit();
|
|
267
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _splitsArray[0], address(this));
|
|
268
|
+
|
|
269
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
270
|
+
|
|
271
|
+
// Second or "reconfig" call
|
|
272
|
+
|
|
273
|
+
JBSplit[] memory _splitsArray2 = new JBSplit[](2);
|
|
274
|
+
|
|
275
|
+
// Re-Set up a payout split recipient.
|
|
276
|
+
_splitsArray2[0] = JBSplit({
|
|
277
|
+
preferAddToBalance: false,
|
|
278
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
279
|
+
projectId: _projectId,
|
|
280
|
+
beneficiary: _bene,
|
|
281
|
+
lockedUntil: uint48(block.timestamp + 100),
|
|
282
|
+
hook: IJBSplitHook(address(0))
|
|
283
|
+
});
|
|
284
|
+
|
|
285
|
+
// Re-Set up a payout split recipient.
|
|
286
|
+
_splitsArray2[1] = JBSplit({
|
|
287
|
+
preferAddToBalance: true,
|
|
288
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
289
|
+
projectId: _projectId,
|
|
290
|
+
beneficiary: _bene,
|
|
291
|
+
lockedUntil: uint48(block.timestamp + 200),
|
|
292
|
+
hook: IJBSplitHook(address(0))
|
|
293
|
+
});
|
|
294
|
+
|
|
295
|
+
// outer structure
|
|
296
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray2});
|
|
297
|
+
|
|
298
|
+
vm.expectEmit();
|
|
299
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _splitsArray2[0], address(this));
|
|
300
|
+
|
|
301
|
+
_splits.setSplitGroupsOf(_projectId, block.timestamp, _splitsGroup);
|
|
302
|
+
|
|
303
|
+
JBSplit[] memory _current = _splits.splitsOf(_projectId, block.timestamp, 0);
|
|
304
|
+
|
|
305
|
+
assertEq(_current[0].lockedUntil, block.timestamp + 100);
|
|
306
|
+
assertEq(_current[1].lockedUntil, block.timestamp + 200);
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
function test_GivenOverwritingExistingLockedSplitWithReorderedGroup() external whenCallerIsController {
|
|
310
|
+
// it will overwrite
|
|
311
|
+
|
|
312
|
+
// data for call
|
|
313
|
+
JBSplitGroup[] memory _splitsGroup = new JBSplitGroup[](1);
|
|
314
|
+
JBSplit[] memory _splitsArray = new JBSplit[](1);
|
|
315
|
+
|
|
316
|
+
// Set up a payout split recipient.
|
|
317
|
+
_splitsArray[0] = JBSplit({
|
|
318
|
+
preferAddToBalance: false,
|
|
319
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
320
|
+
projectId: _projectId,
|
|
321
|
+
beneficiary: _bene,
|
|
322
|
+
lockedUntil: uint48(block.timestamp + 100),
|
|
323
|
+
hook: IJBSplitHook(address(0))
|
|
324
|
+
});
|
|
325
|
+
|
|
326
|
+
// outer structure
|
|
327
|
+
_splitsGroup[0] = JBSplitGroup({groupId: 0, splits: _splitsArray});
|
|
328
|
+
|
|
329
|
+
vm.expectEmit();
|
|
330
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _splitsArray[0], address(this));
|
|
331
|
+
|
|
332
|
+
_splits.setSplitGroupsOf(_projectId, _rulesetId, _splitsGroup);
|
|
333
|
+
|
|
334
|
+
// Second or "reconfig" call
|
|
335
|
+
JBSplitGroup[] memory _secondSplitsGroup = new JBSplitGroup[](1);
|
|
336
|
+
JBSplit[] memory _secondSplitsArray = new JBSplit[](2);
|
|
337
|
+
|
|
338
|
+
// Re-Set up a payout split recipient.
|
|
339
|
+
_secondSplitsArray[1] = JBSplit({
|
|
340
|
+
preferAddToBalance: false,
|
|
341
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
342
|
+
projectId: _projectId,
|
|
343
|
+
beneficiary: _bene,
|
|
344
|
+
lockedUntil: uint48(block.timestamp + 100),
|
|
345
|
+
hook: IJBSplitHook(address(0))
|
|
346
|
+
});
|
|
347
|
+
|
|
348
|
+
_secondSplitsArray[0] = JBSplit({
|
|
349
|
+
preferAddToBalance: false,
|
|
350
|
+
percent: JBConstants.SPLITS_TOTAL_PERCENT / 2,
|
|
351
|
+
projectId: _projectId,
|
|
352
|
+
beneficiary: _bene,
|
|
353
|
+
lockedUntil: 0,
|
|
354
|
+
hook: IJBSplitHook(address(0))
|
|
355
|
+
});
|
|
356
|
+
|
|
357
|
+
// outer structure
|
|
358
|
+
_secondSplitsGroup[0] = JBSplitGroup({groupId: 0, splits: _secondSplitsArray});
|
|
359
|
+
|
|
360
|
+
vm.expectEmit();
|
|
361
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _secondSplitsArray[0], address(this));
|
|
362
|
+
emit IJBSplits.SetSplit(_projectId, block.timestamp, 0, _secondSplitsArray[1], address(this));
|
|
363
|
+
|
|
364
|
+
_splits.setSplitGroupsOf(_projectId, block.timestamp, _secondSplitsGroup);
|
|
365
|
+
|
|
366
|
+
JBSplit[] memory _current = _splits.splitsOf(_projectId, block.timestamp, 0);
|
|
367
|
+
|
|
368
|
+
assertEq(_current[0].preferAddToBalance, false);
|
|
369
|
+
}
|
|
370
|
+
}
|
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
|
2
|
+
pragma solidity 0.8.23;
|
|
3
|
+
|
|
4
|
+
import /* {*} from */ "../../../helpers/TestBaseWorkflow.sol";
|
|
5
|
+
import {JBSplitsSetup} from "./JBSplitsSetup.sol";
|
|
6
|
+
|
|
7
|
+
/// @notice Edge case tests for JBSplits lock enforcement.
|
|
8
|
+
/// Key finding: locks only enforce within the SAME rulesetId. A project owner
|
|
9
|
+
/// can bypass a locked split by setting splits under a different rulesetId.
|
|
10
|
+
contract TestSplitsLockedEdge_Local is JBSplitsSetup {
|
|
11
|
+
uint256 constant PROJECT_ID = 1;
|
|
12
|
+
uint256 constant RULESET_ID_A = 100;
|
|
13
|
+
uint256 constant RULESET_ID_B = 200;
|
|
14
|
+
uint256 constant GROUP_ID = 1;
|
|
15
|
+
address constant BENEFICIARY = address(0xBEEF);
|
|
16
|
+
|
|
17
|
+
IJBSplits public splits;
|
|
18
|
+
|
|
19
|
+
function setUp() public {
|
|
20
|
+
super.splitsSetup();
|
|
21
|
+
splits = IJBSplits(address(_splits));
|
|
22
|
+
|
|
23
|
+
// Mock controllerOf to return this contract.
|
|
24
|
+
vm.mockCall(
|
|
25
|
+
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (PROJECT_ID)), abi.encode(address(this))
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
// Helper to create a split with specified parameters.
|
|
30
|
+
function _makeSplit(
|
|
31
|
+
uint32 percent,
|
|
32
|
+
address beneficiary_,
|
|
33
|
+
uint48 lockedUntil
|
|
34
|
+
)
|
|
35
|
+
internal
|
|
36
|
+
pure
|
|
37
|
+
returns (JBSplit memory)
|
|
38
|
+
{
|
|
39
|
+
return JBSplit({
|
|
40
|
+
percent: percent,
|
|
41
|
+
projectId: 0,
|
|
42
|
+
beneficiary: payable(beneficiary_),
|
|
43
|
+
preferAddToBalance: false,
|
|
44
|
+
lockedUntil: lockedUntil,
|
|
45
|
+
hook: IJBSplitHook(address(0))
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// ───────────────────── Lock enforcement within same ruleset
|
|
50
|
+
// ─────────────────────
|
|
51
|
+
|
|
52
|
+
/// @notice Removing a locked split within the same rulesetId should revert.
|
|
53
|
+
function test_lockEnforcement_withinSameRuleset() external {
|
|
54
|
+
// Set a locked split.
|
|
55
|
+
JBSplit[] memory initialSplits = new JBSplit[](1);
|
|
56
|
+
initialSplits[0] = _makeSplit(500_000_000, BENEFICIARY, uint48(block.timestamp + 365 days));
|
|
57
|
+
|
|
58
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
59
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: initialSplits});
|
|
60
|
+
|
|
61
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
62
|
+
|
|
63
|
+
// Try to remove the locked split.
|
|
64
|
+
JBSplit[] memory newSplits = new JBSplit[](1);
|
|
65
|
+
newSplits[0] = _makeSplit(500_000_000, address(0xDEAD), 0); // Different beneficiary.
|
|
66
|
+
|
|
67
|
+
JBSplitGroup[] memory newGroups = new JBSplitGroup[](1);
|
|
68
|
+
newGroups[0] = JBSplitGroup({groupId: GROUP_ID, splits: newSplits});
|
|
69
|
+
|
|
70
|
+
vm.expectRevert(
|
|
71
|
+
abi.encodeWithSelector(JBSplits.JBSplits_PreviousLockedSplitsNotIncluded.selector, PROJECT_ID, RULESET_ID_A)
|
|
72
|
+
);
|
|
73
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, newGroups);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// ───────────────────── Lock DOES NOT carry across rulesets
|
|
77
|
+
// ─────────────────────
|
|
78
|
+
|
|
79
|
+
/// @notice DESIGN ISSUE: Locked splits in rulesetId A don't constrain rulesetId B.
|
|
80
|
+
/// A project owner can bypass a lock by queuing a new ruleset without the split.
|
|
81
|
+
function test_lockEnforcement_acrossRulesets() external {
|
|
82
|
+
// Set a locked split in rulesetId A.
|
|
83
|
+
JBSplit[] memory initialSplits = new JBSplit[](1);
|
|
84
|
+
initialSplits[0] = _makeSplit(500_000_000, BENEFICIARY, uint48(block.timestamp + 365 days));
|
|
85
|
+
|
|
86
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
87
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: initialSplits});
|
|
88
|
+
|
|
89
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
90
|
+
|
|
91
|
+
// Set completely different splits in rulesetId B — this SUCCEEDS even though
|
|
92
|
+
// the locked split from rulesetId A is not included.
|
|
93
|
+
JBSplit[] memory newSplits = new JBSplit[](1);
|
|
94
|
+
newSplits[0] = _makeSplit(500_000_000, address(0xDEAD), 0); // No lock, different beneficiary.
|
|
95
|
+
|
|
96
|
+
JBSplitGroup[] memory newGroups = new JBSplitGroup[](1);
|
|
97
|
+
newGroups[0] = JBSplitGroup({groupId: GROUP_ID, splits: newSplits});
|
|
98
|
+
|
|
99
|
+
// This should succeed — locks don't carry across rulesets.
|
|
100
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_B, newGroups);
|
|
101
|
+
|
|
102
|
+
// Verify the new ruleset has different splits.
|
|
103
|
+
JBSplit[] memory rulesetsB = splits.splitsOf(PROJECT_ID, RULESET_ID_B, GROUP_ID);
|
|
104
|
+
assertEq(rulesetsB.length, 1, "Ruleset B should have splits");
|
|
105
|
+
assertEq(rulesetsB[0].beneficiary, address(0xDEAD), "Locked split bypassed via new rulesetId");
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// ───────────────────── Lock extension allowed
|
|
109
|
+
// ─────────────────────
|
|
110
|
+
|
|
111
|
+
/// @notice Extending lockedUntil to a later time should succeed.
|
|
112
|
+
function test_lockExtension_allowed() external {
|
|
113
|
+
uint48 originalLock = uint48(block.timestamp + 180 days);
|
|
114
|
+
uint48 extendedLock = uint48(block.timestamp + 365 days);
|
|
115
|
+
|
|
116
|
+
JBSplit[] memory initialSplits = new JBSplit[](1);
|
|
117
|
+
initialSplits[0] = _makeSplit(500_000_000, BENEFICIARY, originalLock);
|
|
118
|
+
|
|
119
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
120
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: initialSplits});
|
|
121
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
122
|
+
|
|
123
|
+
// Extend the lock.
|
|
124
|
+
JBSplit[] memory extendedSplits = new JBSplit[](1);
|
|
125
|
+
extendedSplits[0] = _makeSplit(500_000_000, BENEFICIARY, extendedLock);
|
|
126
|
+
|
|
127
|
+
JBSplitGroup[] memory extendedGroups = new JBSplitGroup[](1);
|
|
128
|
+
extendedGroups[0] = JBSplitGroup({groupId: GROUP_ID, splits: extendedSplits});
|
|
129
|
+
|
|
130
|
+
// Should succeed — lock extension is allowed.
|
|
131
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, extendedGroups);
|
|
132
|
+
|
|
133
|
+
JBSplit[] memory result = splits.splitsOf(PROJECT_ID, RULESET_ID_A, GROUP_ID);
|
|
134
|
+
assertEq(result[0].lockedUntil, extendedLock, "Lock should be extended");
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// ───────────────────── Lock reduction blocked
|
|
138
|
+
// ─────────────────────
|
|
139
|
+
|
|
140
|
+
/// @notice Reducing lockedUntil (while still locked) should revert.
|
|
141
|
+
function test_lockReduction_blocked() external {
|
|
142
|
+
uint48 originalLock = uint48(block.timestamp + 365 days);
|
|
143
|
+
uint48 reducedLock = uint48(block.timestamp + 90 days);
|
|
144
|
+
|
|
145
|
+
JBSplit[] memory initialSplits = new JBSplit[](1);
|
|
146
|
+
initialSplits[0] = _makeSplit(500_000_000, BENEFICIARY, originalLock);
|
|
147
|
+
|
|
148
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
149
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: initialSplits});
|
|
150
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
151
|
+
|
|
152
|
+
// Try to reduce the lock — should fail.
|
|
153
|
+
JBSplit[] memory reducedSplits = new JBSplit[](1);
|
|
154
|
+
reducedSplits[0] = _makeSplit(500_000_000, BENEFICIARY, reducedLock);
|
|
155
|
+
|
|
156
|
+
JBSplitGroup[] memory reducedGroups = new JBSplitGroup[](1);
|
|
157
|
+
reducedGroups[0] = JBSplitGroup({groupId: GROUP_ID, splits: reducedSplits});
|
|
158
|
+
|
|
159
|
+
vm.expectRevert(
|
|
160
|
+
abi.encodeWithSelector(JBSplits.JBSplits_PreviousLockedSplitsNotIncluded.selector, PROJECT_ID, RULESET_ID_A)
|
|
161
|
+
);
|
|
162
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, reducedGroups);
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
// ───────────────────── Lock expired allows removal
|
|
166
|
+
// ─────────────────────
|
|
167
|
+
|
|
168
|
+
/// @notice After lockedUntil passes, split can be removed.
|
|
169
|
+
function test_lockExpired_canRemove() external {
|
|
170
|
+
uint48 lockTime = uint48(block.timestamp + 30 days);
|
|
171
|
+
|
|
172
|
+
JBSplit[] memory initialSplits = new JBSplit[](1);
|
|
173
|
+
initialSplits[0] = _makeSplit(500_000_000, BENEFICIARY, lockTime);
|
|
174
|
+
|
|
175
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
176
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: initialSplits});
|
|
177
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
178
|
+
|
|
179
|
+
// Warp past lock expiry.
|
|
180
|
+
vm.warp(lockTime + 1);
|
|
181
|
+
|
|
182
|
+
// Now remove the split — should succeed.
|
|
183
|
+
JBSplit[] memory newSplits = new JBSplit[](1);
|
|
184
|
+
newSplits[0] = _makeSplit(500_000_000, address(0xDEAD), 0);
|
|
185
|
+
|
|
186
|
+
JBSplitGroup[] memory newGroups = new JBSplitGroup[](1);
|
|
187
|
+
newGroups[0] = JBSplitGroup({groupId: GROUP_ID, splits: newSplits});
|
|
188
|
+
|
|
189
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, newGroups);
|
|
190
|
+
|
|
191
|
+
JBSplit[] memory result = splits.splitsOf(PROJECT_ID, RULESET_ID_A, GROUP_ID);
|
|
192
|
+
assertEq(result[0].beneficiary, address(0xDEAD), "Expired lock allows removal");
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
// ───────────────────── Percent validation
|
|
196
|
+
// ─────────────────────
|
|
197
|
+
|
|
198
|
+
/// @notice Total percent > SPLITS_TOTAL_PERCENT should revert.
|
|
199
|
+
function test_percentExceeds100_reverts() external {
|
|
200
|
+
JBSplit[] memory splitArray = new JBSplit[](2);
|
|
201
|
+
splitArray[0] = _makeSplit(600_000_000, BENEFICIARY, 0); // 60%
|
|
202
|
+
splitArray[1] = _makeSplit(500_000_000, address(0xDEAD), 0); // 50% → total 110%
|
|
203
|
+
|
|
204
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
205
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: splitArray});
|
|
206
|
+
|
|
207
|
+
vm.expectRevert(JBSplits.JBSplits_TotalPercentExceeds100.selector);
|
|
208
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
/// @notice Any split with percent=0 should revert.
|
|
212
|
+
function test_zeroPercent_reverts() external {
|
|
213
|
+
JBSplit[] memory splitArray = new JBSplit[](1);
|
|
214
|
+
splitArray[0] = _makeSplit(0, BENEFICIARY, 0);
|
|
215
|
+
|
|
216
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
217
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: splitArray});
|
|
218
|
+
|
|
219
|
+
vm.expectRevert(JBSplits.JBSplits_ZeroSplitPercent.selector);
|
|
220
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
// ───────────────────── Hook and beneficiary edge cases
|
|
224
|
+
// ─────────────────────
|
|
225
|
+
|
|
226
|
+
/// @notice Arbitrary address as hook is accepted (no interface check).
|
|
227
|
+
function test_hookAddress_notValidated() external {
|
|
228
|
+
JBSplit[] memory splitArray = new JBSplit[](1);
|
|
229
|
+
splitArray[0] = JBSplit({
|
|
230
|
+
percent: 500_000_000,
|
|
231
|
+
projectId: 0,
|
|
232
|
+
beneficiary: payable(BENEFICIARY),
|
|
233
|
+
preferAddToBalance: false,
|
|
234
|
+
lockedUntil: 0,
|
|
235
|
+
hook: IJBSplitHook(address(0x1234)) // Arbitrary address — no interface validation.
|
|
236
|
+
});
|
|
237
|
+
|
|
238
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
239
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: splitArray});
|
|
240
|
+
|
|
241
|
+
// Should succeed — no ERC165 or interface check.
|
|
242
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
243
|
+
|
|
244
|
+
JBSplit[] memory result = splits.splitsOf(PROJECT_ID, RULESET_ID_A, GROUP_ID);
|
|
245
|
+
assertEq(address(result[0].hook), address(0x1234), "Arbitrary hook address accepted");
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
/// @notice address(0) beneficiary is valid (potential footgun).
|
|
249
|
+
function test_beneficiaryZero_accepted() external {
|
|
250
|
+
JBSplit[] memory splitArray = new JBSplit[](1);
|
|
251
|
+
splitArray[0] = _makeSplit(500_000_000, address(0), 0);
|
|
252
|
+
|
|
253
|
+
JBSplitGroup[] memory groups = new JBSplitGroup[](1);
|
|
254
|
+
groups[0] = JBSplitGroup({groupId: GROUP_ID, splits: splitArray});
|
|
255
|
+
|
|
256
|
+
// Should succeed — no zero-address check.
|
|
257
|
+
splits.setSplitGroupsOf(PROJECT_ID, RULESET_ID_A, groups);
|
|
258
|
+
|
|
259
|
+
JBSplit[] memory result = splits.splitsOf(PROJECT_ID, RULESET_ID_A, GROUP_ID);
|
|
260
|
+
assertEq(result[0].beneficiary, address(0), "Zero beneficiary accepted (footgun)");
|
|
261
|
+
}
|
|
262
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
|
2
|
+
pragma solidity 0.8.23;
|
|
3
|
+
|
|
4
|
+
import /* {*} from */ "../../../helpers/TestBaseWorkflow.sol";
|
|
5
|
+
import {JBSplitsSetup} from "./JBSplitsSetup.sol";
|
|
6
|
+
|
|
7
|
+
contract TestSplitsOf_Local is JBSplitsSetup {
|
|
8
|
+
function setUp() public {
|
|
9
|
+
super.splitsSetup();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
// This is covered under TestSetSplitGroupsOf
|
|
13
|
+
/* function test_WhenThereAreDefinedSplits() external {
|
|
14
|
+
// it should return the defined splits
|
|
15
|
+
} */
|
|
16
|
+
|
|
17
|
+
function test_WhenThereAreNoSplitsDefined() external view {
|
|
18
|
+
// it should return the default splits for FALLBACK_RULESET_ID
|
|
19
|
+
|
|
20
|
+
JBSplit[] memory _current = _splits.splitsOf(1, block.timestamp, 0);
|
|
21
|
+
|
|
22
|
+
assertEq(_current.length, 0);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
|
2
|
+
pragma solidity 0.8.23;
|
|
3
|
+
|
|
4
|
+
import "src/JBSplits.sol";
|
|
5
|
+
import "forge-std/Test.sol";
|
|
6
|
+
|
|
7
|
+
contract TestSplitsPacking_Local is JBSplits, Test {
|
|
8
|
+
constructor() JBSplits(IJBDirectory(address(0))) {}
|
|
9
|
+
|
|
10
|
+
function test_SplitsPacking(JBSplit calldata _split) external {
|
|
11
|
+
// Ensure the split percentage is within bounds.
|
|
12
|
+
vm.assume(_split.percent != 0 && _split.percent <= JBConstants.SPLITS_TOTAL_PERCENT);
|
|
13
|
+
|
|
14
|
+
JBSplit[] memory _splits = new JBSplit[](1);
|
|
15
|
+
_splits[0] = _split;
|
|
16
|
+
|
|
17
|
+
_setSplitsOf(1, 1, 1, _splits);
|
|
18
|
+
JBSplit memory _unpackedSplit = _getStructsFor(1, 1, 1)[0];
|
|
19
|
+
|
|
20
|
+
assertEq(_split.percent, _unpackedSplit.percent, "Percent packing is lossy");
|
|
21
|
+
assertEq(_split.projectId, _unpackedSplit.projectId, "Project ID packing is lossy");
|
|
22
|
+
assertEq(_split.beneficiary, _unpackedSplit.beneficiary, "Beneficiary packing is lossy");
|
|
23
|
+
assertEq(_split.preferAddToBalance, _unpackedSplit.preferAddToBalance, "preferAddToBalance packing is lossy");
|
|
24
|
+
assertEq(_split.lockedUntil, _unpackedSplit.lockedUntil, "lockedUntil packing is lossy");
|
|
25
|
+
assertEq(address(_split.hook), address(_unpackedSplit.hook), "hook packing is lossy");
|
|
26
|
+
|
|
27
|
+
assertEq(
|
|
28
|
+
keccak256(abi.encode(_split)),
|
|
29
|
+
keccak256(abi.encode(_unpackedSplit)),
|
|
30
|
+
"Packing and unpacking of a split is lossy"
|
|
31
|
+
);
|
|
32
|
+
}
|
|
33
|
+
}
|