@bananapus/core-v6 0.0.37 → 0.0.39
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/JBChainlinkV3PriceFeed.sol +4 -1
- package/src/JBChainlinkV3SequencerPriceFeed.sol +4 -2
- package/src/JBController.sol +71 -44
- package/src/JBDeadline.sol +4 -4
- package/src/JBDirectory.sol +34 -32
- package/src/JBERC20.sol +5 -4
- package/src/JBFeelessAddresses.sol +6 -3
- package/src/JBFundAccessLimits.sol +25 -21
- package/src/JBMultiTerminal.sol +121 -84
- package/src/JBPermissions.sol +34 -37
- package/src/JBPrices.sol +23 -18
- package/src/JBProjects.sol +6 -3
- package/src/JBRulesets.sol +44 -41
- package/src/JBSplits.sol +18 -16
- package/src/JBTerminalStore.sol +32 -25
- package/src/JBTokens.sol +36 -26
- package/src/abstract/JBControlled.sol +3 -1
- package/src/abstract/JBPermissioned.sol +3 -1
- package/src/enums/JBApprovalStatus.sol +7 -1
- package/src/interfaces/IJBController.sol +7 -3
- package/src/interfaces/IJBDirectory.sol +3 -1
- package/src/interfaces/IJBMultiTerminal.sol +3 -2
- package/src/interfaces/IJBPermissions.sol +2 -1
- package/src/interfaces/IJBPrices.sol +3 -1
- package/src/interfaces/IJBRulesets.sol +2 -1
- package/src/interfaces/IJBSplits.sol +2 -1
- package/src/interfaces/IJBTerminal.sol +3 -1
- package/src/interfaces/IJBTerminalStore.sol +3 -1
- package/src/interfaces/IJBTokens.sol +2 -1
- package/src/libraries/JBCashOuts.sol +6 -1
- package/src/libraries/JBConstants.sol +12 -3
- package/src/libraries/JBCurrencyIds.sol +2 -0
- package/src/libraries/JBFees.sol +52 -10
- package/src/libraries/JBFixedPointNumber.sol +2 -0
- package/src/libraries/JBPayoutSplitGroupLib.sol +7 -4
- package/src/libraries/JBRulesetMetadataResolver.sol +4 -0
- package/src/libraries/JBSplitGroupIds.sol +2 -1
- package/src/libraries/JBSurplus.sol +3 -1
- package/src/periphery/JBMatchingPriceFeed.sol +3 -1
- package/src/structs/JBAccountingContext.sol +7 -4
- package/src/structs/JBFundAccessLimitGroup.sol +10 -17
- package/src/structs/JBRuleset.sol +18 -26
- package/src/structs/JBRulesetConfig.sol +13 -25
- package/src/structs/JBRulesetMetadata.sol +25 -32
- package/test/mock/MockMaliciousBeneficiary.sol +15 -15
- package/ADMINISTRATION.md +0 -103
- package/ARCHITECTURE.md +0 -133
- package/AUDIT_INSTRUCTIONS.md +0 -139
- package/RISKS.md +0 -215
- package/SKILLS.md +0 -55
- package/STYLE_GUIDE.md +0 -610
- package/USER_JOURNEYS.md +0 -215
- package/script/Deploy.s.sol +0 -124
- package/script/DeployPeriphery.s.sol +0 -354
- package/slither-ci.config.json +0 -10
- package/test/AuditFixes.t.sol +0 -808
- package/test/ComprehensiveInvariant.t.sol +0 -306
- package/test/CoreExploitTests.t.sol +0 -2741
- package/test/EconomicSimulation.t.sol +0 -348
- package/test/EntryPointPermutations.t.sol +0 -684
- package/test/FlashLoanAttacks.t.sol +0 -797
- package/test/PermissionEscalation.t.sol +0 -711
- package/test/PermissionsInvariant.t.sol +0 -403
- package/test/RulesetTransitions.t.sol +0 -713
- package/test/SplitLoopTests.t.sol +0 -752
- package/test/TestAccessToFunds.sol +0 -2683
- package/test/TestAuditResponseDesignProofs.sol +0 -434
- package/test/TestCashOut.sol +0 -198
- package/test/TestCashOutCountFor.sol +0 -271
- package/test/TestCashOutHooks.sol +0 -351
- package/test/TestCashOutTimingEdge.sol +0 -241
- package/test/TestDataHookFuzzing.sol +0 -524
- package/test/TestDurationUnderflow.sol +0 -233
- package/test/TestFeeFreeCashOutBypass.sol +0 -949
- package/test/TestFeeProcessingFailure.sol +0 -218
- package/test/TestFees.sol +0 -619
- package/test/TestForwardedTokenConsumption.sol +0 -425
- package/test/TestInterfaceSupport.sol +0 -81
- package/test/TestJBERC20Inheritance.sol +0 -103
- package/test/TestL2SequencerPriceFeed.sol +0 -292
- package/test/TestLaunchProject.sol +0 -188
- package/test/TestMetaTx.sol +0 -217
- package/test/TestMetadataOffsetOverflow.sol +0 -179
- package/test/TestMetadataParserLib.sol +0 -471
- package/test/TestMigrationHeldFees.sol +0 -255
- package/test/TestMintTokensOf.sol +0 -185
- package/test/TestMultiTerminalSurplus.sol +0 -348
- package/test/TestMultiTokenSurplus.sol +0 -202
- package/test/TestMultipleAccessLimits.sol +0 -664
- package/test/TestPayBurnRedeemFlow.sol +0 -195
- package/test/TestPayHooks.sol +0 -209
- package/test/TestPermissions.sol +0 -324
- package/test/TestPermissionsEdge.sol +0 -290
- package/test/TestPermit2DataHook.t.sol +0 -360
- package/test/TestPermit2Terminal.sol +0 -372
- package/test/TestRulesetQueueing.sol +0 -1025
- package/test/TestRulesetQueuingStress.sol +0 -806
- package/test/TestRulesetWeightCaching.sol +0 -178
- package/test/TestSplits.sol +0 -391
- package/test/TestTerminalMigration.sol +0 -274
- package/test/TestTerminalPreviewParity.sol +0 -208
- package/test/TestTokenFlow.sol +0 -191
- package/test/TestWeightCacheStaleAfterRejection.sol +0 -303
- package/test/WeirdTokenTests.t.sol +0 -817
- package/test/audit/CashOutReenterPay.t.sol +0 -501
- package/test/audit/CodexHeldFeeRounding.t.sol +0 -159
- package/test/audit/CodexMigrationFeeFailure.t.sol +0 -163
- package/test/audit/CrossTerminalSurplusSpoof.t.sol +0 -140
- package/test/audit/CycledSurplusAllowanceReset.t.sol +0 -184
- package/test/audit/FeeFreeSurplusLifecycle.t.sol +0 -399
- package/test/audit/FeeFreeSurplusStale.t.sol +0 -248
- package/test/audit/USDTVoidReturnCompat.t.sol +0 -525
- package/test/fork/TestChainlinkPriceFeedFork.sol +0 -254
- package/test/fork/TestSequencerPriceFeedFork.sol +0 -168
- package/test/fork/TestTerminalPreviewParityFork.sol +0 -108
- package/test/formal/BondingCurveProperties.t.sol +0 -420
- package/test/formal/FeeProperties.t.sol +0 -252
- package/test/invariants/Phase3DeepInvariant.t.sol +0 -412
- package/test/invariants/RulesetsInvariant.t.sol +0 -125
- package/test/invariants/TerminalStoreInvariant.t.sol +0 -227
- package/test/invariants/TokensInvariant.t.sol +0 -195
- package/test/invariants/handlers/ComprehensiveHandler.sol +0 -303
- package/test/invariants/handlers/EconomicHandler.sol +0 -377
- package/test/invariants/handlers/Phase3Handler.sol +0 -443
- package/test/invariants/handlers/RulesetsHandler.sol +0 -115
- package/test/invariants/handlers/TerminalStoreHandler.sol +0 -151
- package/test/invariants/handlers/TokensHandler.sol +0 -126
- package/test/regression/HoldFeesCashOutReserved.t.sol +0 -415
- package/test/regression/WeightCacheBoundary.t.sol +0 -291
- package/test/trees/JBController/burnTokensOf.tree +0 -9
- package/test/trees/JBController/claimTokensFor.tree +0 -5
- package/test/trees/JBController/deployERC20For.tree +0 -5
- package/test/trees/JBController/getRulesetOf.tree +0 -5
- package/test/trees/JBController/launchProjectFor.tree +0 -12
- package/test/trees/JBController/launchRulesetsFor.tree +0 -8
- package/test/trees/JBController/migrateController.tree +0 -12
- package/test/trees/JBController/mintTokensOf.tree +0 -12
- package/test/trees/JBController/payReservedTokenToTerminal.tree +0 -8
- package/test/trees/JBController/receiveMigrationFrom.tree +0 -4
- package/test/trees/JBController/sendReservedTokensToSplitsOf.tree +0 -12
- package/test/trees/JBController/setMetadataOf.tree +0 -5
- package/test/trees/JBController/setSplitGroupsOf.tree +0 -5
- package/test/trees/JBController/setTokenFor.tree +0 -5
- package/test/trees/JBController/transferCreditsFrom.tree +0 -8
- package/test/trees/JBDirectory/primaryTerminalOf.tree +0 -8
- package/test/trees/JBDirectory/setControllerOf.tree +0 -11
- package/test/trees/JBDirectory/setPrimaryTerminalOf.tree +0 -15
- package/test/trees/JBDirectory/setTerminalsOf.tree +0 -11
- package/test/trees/JBERC20/initialize.tree +0 -7
- package/test/trees/JBERC20/name.tree +0 -5
- package/test/trees/JBERC20/nonces.tree +0 -5
- package/test/trees/JBERC20/symbol.tree +0 -5
- package/test/trees/JBFeelessAddresses/setFeelessAddress.tree +0 -5
- package/test/trees/JBFeelessAddresses/supportsInterface.tree +0 -5
- package/test/trees/JBFundAccessLimits/payoutLimitOf.tree +0 -5
- package/test/trees/JBFundAccessLimits/payoutLimitsOf.tree +0 -8
- package/test/trees/JBFundAccessLimits/setFundAccessLimitsFor.tree +0 -18
- package/test/trees/JBFundAccessLimits/surplusAllowanceOf.tree +0 -5
- package/test/trees/JBFundAccessLimits/surplusAllowancesOf.tree +0 -8
- package/test/trees/JBMetadataResolver/getDataFor.tree +0 -8
- package/test/trees/JBMultiTerminal/accountingContextsOf.tree +0 -5
- package/test/trees/JBMultiTerminal/addAccountingContextsFor.tree +0 -10
- package/test/trees/JBMultiTerminal/addToBalanceOf.tree +0 -23
- package/test/trees/JBMultiTerminal/cashOutTokensOf.tree +0 -23
- package/test/trees/JBMultiTerminal/executePayout.tree +0 -32
- package/test/trees/JBMultiTerminal/executeProcessFee.tree +0 -14
- package/test/trees/JBMultiTerminal/migrateBalanceOf.tree +0 -12
- package/test/trees/JBMultiTerminal/pay.tree +0 -23
- package/test/trees/JBMultiTerminal/processHeldFeesOf.tree +0 -8
- package/test/trees/JBMultiTerminal/sendPayoutsOf.tree +0 -34
- package/test/trees/JBMultiTerminal/useAllowanceOf.tree +0 -16
- package/test/trees/JBPermissions/hasPermission.tree +0 -8
- package/test/trees/JBPermissions/hasPermissions.tree +0 -8
- package/test/trees/JBPermissions/setPermissionsFor.tree +0 -5
- package/test/trees/JBPrices/addPriceFeedFor.tree +0 -14
- package/test/trees/JBPrices/pricePerUnitOf.tree +0 -11
- package/test/trees/JBProjects/createFor.tree +0 -11
- package/test/trees/JBProjects/setTokenUriResolver.tree +0 -5
- package/test/trees/JBProjects/supportsInterface.tree +0 -9
- package/test/trees/JBProjects/tokenURI.tree +0 -5
- package/test/trees/JBRulesets/currentApprovalStatusForLatestRulesetOf.tree +0 -8
- package/test/trees/JBRulesets/currentOf.tree +0 -12
- package/test/trees/JBRulesets/getRulesetOf.tree +0 -5
- package/test/trees/JBRulesets/latestQueuedRulesetOf.tree +0 -10
- package/test/trees/JBRulesets/rulesetsOf.tree +0 -11
- package/test/trees/JBRulesets/upcomingRulesetOf.tree +0 -20
- package/test/trees/JBRulesets/updateRulesetWeightCache.tree +0 -5
- package/test/trees/JBSplits/setSplitGroupsOf.tree +0 -17
- package/test/trees/JBSplits/splitsOf.tree +0 -5
- package/test/trees/JBTerminalStore/currentReclaimableSurplusOf.tree +0 -16
- package/test/trees/JBTerminalStore/currentSurplusOf.tree +0 -25
- package/test/trees/JBTerminalStore/currentTotalSurplusOf.tree +0 -5
- package/test/trees/JBTerminalStore/recordCashOutsFor.tree +0 -16
- package/test/trees/JBTerminalStore/recordPaymentFrom.tree +0 -14
- package/test/trees/JBTerminalStore/recordPayoutFor.tree +0 -10
- package/test/trees/JBTerminalStore/recordTerminalMigration.tree +0 -5
- package/test/trees/JBTerminalStore/recordUsedAllowanceOf.tree +0 -10
- package/test/trees/JBTokens/burnFrom.tree +0 -10
- package/test/trees/JBTokens/claimTokensFor.tree +0 -10
- package/test/trees/JBTokens/deployERC20For.tree +0 -12
- package/test/trees/JBTokens/mintFor.tree +0 -10
- package/test/trees/JBTokens/setTokenFor.tree +0 -11
- package/test/trees/JBTokens/totalBalanceOf.tree +0 -5
- package/test/trees/JBTokens/totalSupplyOf.tree +0 -5
- package/test/trees/JBTokens/transferCreditsFrom.tree +0 -8
- package/test/trees/mintTokensOf.tree +0 -12
- package/test/units/static/JBChainlinkV3PriceFeed/TestPriceFeed.sol +0 -223
- package/test/units/static/JBController/JBControllerSetup.sol +0 -50
- package/test/units/static/JBController/TestBurnTokensOf.sol +0 -114
- package/test/units/static/JBController/TestClaimTokensFor.sol +0 -63
- package/test/units/static/JBController/TestDeployErc20For.sol +0 -86
- package/test/units/static/JBController/TestLaunchProjectFor.sol +0 -302
- package/test/units/static/JBController/TestLaunchRulesetsFor.sol +0 -342
- package/test/units/static/JBController/TestMigrateController.sol +0 -157
- package/test/units/static/JBController/TestMintTokensOfUnits.sol +0 -111
- package/test/units/static/JBController/TestOmnichainRulesetOperator.sol +0 -324
- package/test/units/static/JBController/TestPayReservedTokenToTerminal.sol +0 -74
- package/test/units/static/JBController/TestPreviewMintOf.sol +0 -117
- package/test/units/static/JBController/TestReceiveMigrationFrom.sol +0 -99
- package/test/units/static/JBController/TestRulesetViews.sol +0 -225
- package/test/units/static/JBController/TestSendReservedTokensToSplitsOf.sol +0 -615
- package/test/units/static/JBController/TestSetSplitGroupsOf.sol +0 -68
- package/test/units/static/JBController/TestSetTokenFor.sol +0 -239
- package/test/units/static/JBController/TestSetUriOf.sol +0 -57
- package/test/units/static/JBController/TestTransferCreditsFrom.sol +0 -169
- package/test/units/static/JBDeadline/TestDeadlineFuzz.sol +0 -211
- package/test/units/static/JBDirectory/JBDirectorySetup.sol +0 -26
- package/test/units/static/JBDirectory/TestPrimaryTerminalOf.sol +0 -126
- package/test/units/static/JBDirectory/TestSetControllerOf.sol +0 -183
- package/test/units/static/JBDirectory/TestSetControllerOfMigrationOrder.sol +0 -104
- package/test/units/static/JBDirectory/TestSetPrimaryTerminalOf.sol +0 -179
- package/test/units/static/JBDirectory/TestSetTerminalsOf.sol +0 -137
- package/test/units/static/JBERC20/JBERC20Setup.sol +0 -34
- package/test/units/static/JBERC20/SigUtils.sol +0 -36
- package/test/units/static/JBERC20/TestInitialize.sol +0 -60
- package/test/units/static/JBERC20/TestName.sol +0 -30
- package/test/units/static/JBERC20/TestNonces.sol +0 -62
- package/test/units/static/JBERC20/TestSymbol.sol +0 -31
- package/test/units/static/JBFeelessAdresses/JBFeelessSetup.sol +0 -22
- package/test/units/static/JBFeelessAdresses/TestInterfaces.sol +0 -30
- package/test/units/static/JBFeelessAdresses/TestSetFeelessAddress.sol +0 -35
- package/test/units/static/JBFees/TestFeesFuzz.sol +0 -79
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimals.sol +0 -16
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimalsFuzz.sol +0 -71
- package/test/units/static/JBFundAccessLimits/JBFundAccessSetup.sol +0 -24
- package/test/units/static/JBFundAccessLimits/TestFundAccessLimitsEdge.sol +0 -163
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitOf.sol +0 -59
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitsOf.sol +0 -101
- package/test/units/static/JBFundAccessLimits/TestSetFundAccessLimitsFor.sol +0 -189
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowanceOf.sol +0 -64
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowancesOf.sol +0 -102
- package/test/units/static/JBMetadataResolver/TestGetDataFor.sol +0 -90
- package/test/units/static/JBMetadataResolver/TestMetadataResolverEdgeCases.sol +0 -247
- package/test/units/static/JBMetadataResolver/TestMetadataResolverFuzz.sol +0 -229
- package/test/units/static/JBMultiTerminal/JBMultiTerminalSetup.sol +0 -50
- package/test/units/static/JBMultiTerminal/TestAccountingContextsOf.sol +0 -72
- package/test/units/static/JBMultiTerminal/TestAddAccountingContextsFor.sol +0 -289
- package/test/units/static/JBMultiTerminal/TestAddToBalanceOf.sol +0 -474
- package/test/units/static/JBMultiTerminal/TestCashOutTokensOf.sol +0 -624
- package/test/units/static/JBMultiTerminal/TestExecutePayout.sol +0 -578
- package/test/units/static/JBMultiTerminal/TestExecuteProcessFee.sol +0 -202
- package/test/units/static/JBMultiTerminal/TestMigrateBalanceOf.sol +0 -222
- package/test/units/static/JBMultiTerminal/TestPay.sol +0 -604
- package/test/units/static/JBMultiTerminal/TestPreviewCashOutFrom.sol +0 -117
- package/test/units/static/JBMultiTerminal/TestPreviewPayFor.sol +0 -114
- package/test/units/static/JBMultiTerminal/TestProcessHeldFeesOf.sol +0 -228
- package/test/units/static/JBMultiTerminal/TestSelfPayRevert.sol +0 -55
- package/test/units/static/JBMultiTerminal/TestSendPayoutsOf.sol +0 -257
- package/test/units/static/JBMultiTerminal/TestUseAllowanceOf.sol +0 -611
- package/test/units/static/JBPermissions/JBPermissionsSetup.sol +0 -20
- package/test/units/static/JBPermissions/TestHasPermission.sol +0 -50
- package/test/units/static/JBPermissions/TestHasPermissions.sol +0 -93
- package/test/units/static/JBPermissions/TestSetPermissionsFor.sol +0 -64
- package/test/units/static/JBPrices/JBPricesSetup.sol +0 -32
- package/test/units/static/JBPrices/TestAddPriceFeedFor.sol +0 -107
- package/test/units/static/JBPrices/TestPricePerUnitOf.sol +0 -132
- package/test/units/static/JBPrices/TestPrices.sol +0 -265
- package/test/units/static/JBProjects/JBProjectsSetup.sol +0 -22
- package/test/units/static/JBProjects/TestCreateFor.sol +0 -71
- package/test/units/static/JBProjects/TestInitialProject.sol +0 -21
- package/test/units/static/JBProjects/TestInterfaces.sol +0 -26
- package/test/units/static/JBProjects/TestSetResolver.sol +0 -37
- package/test/units/static/JBProjects/TestTokenUri.sol +0 -40
- package/test/units/static/JBRulesetMetadataResolver/TestSetCashOutTaxRateTo.sol +0 -108
- package/test/units/static/JBRulesets/JBRulesetsSetup.sol +0 -24
- package/test/units/static/JBRulesets/TestCurrentApprovalStatusForLatestRulesetOf.sol +0 -265
- package/test/units/static/JBRulesets/TestCurrentOf.sol +0 -242
- package/test/units/static/JBRulesets/TestGetRulesetOf.sol +0 -100
- package/test/units/static/JBRulesets/TestLatestQueuedRulesetOf.sol +0 -260
- package/test/units/static/JBRulesets/TestRulesets.sol +0 -632
- package/test/units/static/JBRulesets/TestRulesetsOf.sol +0 -37
- package/test/units/static/JBRulesets/TestUpcomingRulesetOf.sol +0 -522
- package/test/units/static/JBRulesets/TestUpdateRulesetWeightCache.sol +0 -96
- package/test/units/static/JBSplits/JBSplitsSetup.sol +0 -26
- package/test/units/static/JBSplits/TestSelfManagedSplitGroups.sol +0 -552
- package/test/units/static/JBSplits/TestSetSplitGroupsOf.sol +0 -377
- package/test/units/static/JBSplits/TestSplitsLockedEdge.sol +0 -267
- package/test/units/static/JBSplits/TestSplitsOf.sol +0 -24
- package/test/units/static/JBSplits/TestSplitsPacking.sol +0 -36
- package/test/units/static/JBSurplus/TestSurplusFuzz.sol +0 -160
- package/test/units/static/JBTerminalStore/JBTerminalStoreSetup.sol +0 -45
- package/test/units/static/JBTerminalStore/TestCurrentReclaimableSurplusOf.sol +0 -536
- package/test/units/static/JBTerminalStore/TestCurrentSurplusOf.sol +0 -463
- package/test/units/static/JBTerminalStore/TestCurrentTotalSurplusOf.sol +0 -135
- package/test/units/static/JBTerminalStore/TestPreviewCashOutFrom.sol +0 -476
- package/test/units/static/JBTerminalStore/TestPreviewPayFrom.sol +0 -494
- package/test/units/static/JBTerminalStore/TestRecordCashOutsFor.sol +0 -652
- package/test/units/static/JBTerminalStore/TestRecordPaymentFrom.sol +0 -744
- package/test/units/static/JBTerminalStore/TestRecordPayoutFor.sol +0 -289
- package/test/units/static/JBTerminalStore/TestRecordTerminalMigration.sol +0 -138
- package/test/units/static/JBTerminalStore/TestRecordUsedAllowanceOf.sol +0 -415
- package/test/units/static/JBTerminalStore/TestUint224Overflow.sol +0 -219
- package/test/units/static/JBTokens/JBTokensSetup.sol +0 -32
- package/test/units/static/JBTokens/TestBurnFrom.sol +0 -107
- package/test/units/static/JBTokens/TestClaimTokensFor.sol +0 -110
- package/test/units/static/JBTokens/TestDeployERC20ForUnits.sol +0 -92
- package/test/units/static/JBTokens/TestMintFor.sol +0 -100
- package/test/units/static/JBTokens/TestSetTokenFor.sol +0 -98
- package/test/units/static/JBTokens/TestTotalBalanceOf.sol +0 -65
- package/test/units/static/JBTokens/TestTotalSupplyOf.sol +0 -56
- package/test/units/static/JBTokens/TestTransferCreditsFrom.sol +0 -56
|
@@ -1,291 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity >=0.8.6;
|
|
3
|
-
|
|
4
|
-
import {TestBaseWorkflow} from "../helpers/TestBaseWorkflow.sol";
|
|
5
|
-
import {IJBController} from "../../src/interfaces/IJBController.sol";
|
|
6
|
-
import {IJBRulesets} from "../../src/interfaces/IJBRulesets.sol";
|
|
7
|
-
import {IJBRulesetApprovalHook} from "../../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
8
|
-
import {JBConstants} from "../../src/libraries/JBConstants.sol";
|
|
9
|
-
import {JBRulesetMetadata} from "../../src/structs/JBRulesetMetadata.sol";
|
|
10
|
-
import {JBRulesetConfig} from "../../src/structs/JBRulesetConfig.sol";
|
|
11
|
-
import {JBRuleset} from "../../src/structs/JBRuleset.sol";
|
|
12
|
-
import {JBSplitGroup} from "../../src/structs/JBSplitGroup.sol";
|
|
13
|
-
import {JBFundAccessLimitGroup} from "../../src/structs/JBFundAccessLimitGroup.sol";
|
|
14
|
-
import {JBTerminalConfig} from "../../src/structs/JBTerminalConfig.sol";
|
|
15
|
-
import {JBRulesets} from "../../src/JBRulesets.sol";
|
|
16
|
-
|
|
17
|
-
import {mulDiv} from "@prb/math/src/Common.sol";
|
|
18
|
-
|
|
19
|
-
/// @notice Deterministic (non-fuzz) tests for the JBRulesets weight cache at the 20,000 iteration boundary.
|
|
20
|
-
/// The contract reverts with `JBRulesets_WeightCacheRequired` when the cycle gap exceeds the threshold
|
|
21
|
-
/// and the cache has not been populated. These tests verify:
|
|
22
|
-
/// 1. Exactly 20,000 cycles work without cache.
|
|
23
|
-
/// 2. 20,001 cycles revert without cache.
|
|
24
|
-
/// 3. Progressive `updateRulesetWeightCache()` calls unblock the revert.
|
|
25
|
-
/// 4. The cached weight equals the iteratively computed weight.
|
|
26
|
-
contract WeightCacheBoundary_Local is TestBaseWorkflow {
|
|
27
|
-
uint256 private constant _THRESHOLD = 20_000;
|
|
28
|
-
|
|
29
|
-
/// @dev 1-second duration makes each cycle = 1 second, so we can hit the boundary fast.
|
|
30
|
-
uint32 private constant _DURATION = 1;
|
|
31
|
-
|
|
32
|
-
/// @dev Tiny weight cut (0.1%) so the weight doesn't decay to zero over 20k cycles.
|
|
33
|
-
uint32 private constant _WEIGHT_CUT_PERCENT = 1_000_000; // 0.1% of MAX_WEIGHT_CUT_PERCENT (1e9)
|
|
34
|
-
|
|
35
|
-
uint112 private constant _INITIAL_WEIGHT = 1000e18;
|
|
36
|
-
|
|
37
|
-
IJBController private _controller;
|
|
38
|
-
IJBRulesets private _rulesets;
|
|
39
|
-
address private _projectOwner;
|
|
40
|
-
|
|
41
|
-
JBRulesetMetadata private _metadata;
|
|
42
|
-
|
|
43
|
-
function setUp() public override {
|
|
44
|
-
super.setUp();
|
|
45
|
-
|
|
46
|
-
_projectOwner = multisig();
|
|
47
|
-
_rulesets = jbRulesets();
|
|
48
|
-
_controller = jbController();
|
|
49
|
-
|
|
50
|
-
_metadata = JBRulesetMetadata({
|
|
51
|
-
reservedPercent: 0,
|
|
52
|
-
cashOutTaxRate: 0,
|
|
53
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
54
|
-
pausePay: false,
|
|
55
|
-
pauseCreditTransfers: false,
|
|
56
|
-
allowOwnerMinting: false,
|
|
57
|
-
allowSetCustomToken: false,
|
|
58
|
-
allowTerminalMigration: false,
|
|
59
|
-
allowSetTerminals: false,
|
|
60
|
-
ownerMustSendPayouts: false,
|
|
61
|
-
allowSetController: false,
|
|
62
|
-
allowAddAccountingContext: true,
|
|
63
|
-
allowAddPriceFeed: false,
|
|
64
|
-
holdFees: false,
|
|
65
|
-
useTotalSurplusForCashOuts: true,
|
|
66
|
-
useDataHookForPay: false,
|
|
67
|
-
useDataHookForCashOut: false,
|
|
68
|
-
dataHook: address(0),
|
|
69
|
-
metadata: 0
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
/// @dev Helper: launch a project with a 1-second duration and the given weight cut percent.
|
|
74
|
-
function _launchProject() internal returns (uint256 projectId) {
|
|
75
|
-
JBRulesetConfig[] memory configs = new JBRulesetConfig[](1);
|
|
76
|
-
configs[0].mustStartAtOrAfter = 0;
|
|
77
|
-
configs[0].duration = _DURATION;
|
|
78
|
-
configs[0].weight = _INITIAL_WEIGHT;
|
|
79
|
-
configs[0].weightCutPercent = _WEIGHT_CUT_PERCENT;
|
|
80
|
-
configs[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
81
|
-
configs[0].metadata = _metadata;
|
|
82
|
-
configs[0].splitGroups = new JBSplitGroup[](0);
|
|
83
|
-
configs[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
84
|
-
|
|
85
|
-
projectId = _controller.launchProjectFor({
|
|
86
|
-
owner: _projectOwner,
|
|
87
|
-
projectUri: "weightCacheBoundary",
|
|
88
|
-
rulesetConfigurations: configs,
|
|
89
|
-
terminalConfigurations: new JBTerminalConfig[](0),
|
|
90
|
-
memo: ""
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
/// @dev Compute expected weight by iterating the cut percent `n` times on the initial weight.
|
|
95
|
-
function _expectedWeight(uint256 n) internal pure returns (uint256 weight) {
|
|
96
|
-
weight = _INITIAL_WEIGHT;
|
|
97
|
-
for (uint256 i; i < n; i++) {
|
|
98
|
-
weight = mulDiv(
|
|
99
|
-
weight, JBConstants.MAX_WEIGHT_CUT_PERCENT - _WEIGHT_CUT_PERCENT, JBConstants.MAX_WEIGHT_CUT_PERCENT
|
|
100
|
-
);
|
|
101
|
-
if (weight == 0) break;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
106
|
-
// Test 1: Exactly 20,000 cycles works without cache
|
|
107
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
108
|
-
|
|
109
|
-
function test_exactlyAtThreshold_noCache_succeeds() public {
|
|
110
|
-
uint256 projectId = _launchProject();
|
|
111
|
-
|
|
112
|
-
// Warp forward exactly 20,000 durations.
|
|
113
|
-
vm.warp(block.timestamp + _DURATION * _THRESHOLD);
|
|
114
|
-
|
|
115
|
-
// currentOf should succeed — still within the iteration limit.
|
|
116
|
-
JBRuleset memory ruleset = _rulesets.currentOf(projectId);
|
|
117
|
-
|
|
118
|
-
// Verify weight matches the iterative calculation.
|
|
119
|
-
uint256 expected = _expectedWeight(_THRESHOLD);
|
|
120
|
-
assertEq(ruleset.weight, expected, "Weight at exactly 20,000 cycles should match iterative calculation");
|
|
121
|
-
assertTrue(ruleset.weight > 0, "Weight should not have decayed to zero at 20k cycles with 0.1% cut");
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
125
|
-
// Test 2: 20,001 cycles reverts without cache
|
|
126
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
127
|
-
|
|
128
|
-
function test_aboveThreshold_noCache_reverts() public {
|
|
129
|
-
uint256 projectId = _launchProject();
|
|
130
|
-
|
|
131
|
-
// Warp forward 20,001 durations.
|
|
132
|
-
vm.warp(block.timestamp + _DURATION * (_THRESHOLD + 1));
|
|
133
|
-
|
|
134
|
-
// currentOf should revert because the iteration count exceeds the threshold.
|
|
135
|
-
vm.expectRevert(abi.encodeWithSelector(JBRulesets.JBRulesets_WeightCacheRequired.selector, projectId));
|
|
136
|
-
_rulesets.currentOf(projectId);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
140
|
-
// Test 3: Single cache call unblocks 20,001 cycles
|
|
141
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
142
|
-
|
|
143
|
-
function test_aboveThreshold_singleCacheCall_succeeds() public {
|
|
144
|
-
uint256 projectId = _launchProject();
|
|
145
|
-
uint256 rulesetId = _rulesets.latestRulesetIdOf(projectId);
|
|
146
|
-
|
|
147
|
-
// Warp forward 20,001 durations.
|
|
148
|
-
vm.warp(block.timestamp + _DURATION * (_THRESHOLD + 1));
|
|
149
|
-
|
|
150
|
-
// Without cache, this reverts.
|
|
151
|
-
vm.expectRevert(abi.encodeWithSelector(JBRulesets.JBRulesets_WeightCacheRequired.selector, projectId));
|
|
152
|
-
_rulesets.currentOf(projectId);
|
|
153
|
-
|
|
154
|
-
// Populate the cache.
|
|
155
|
-
_rulesets.updateRulesetWeightCache(projectId, rulesetId);
|
|
156
|
-
|
|
157
|
-
// Now currentOf should succeed.
|
|
158
|
-
JBRuleset memory ruleset = _rulesets.currentOf(projectId);
|
|
159
|
-
|
|
160
|
-
// Verify weight matches iterative calculation.
|
|
161
|
-
uint256 expected = _expectedWeight(_THRESHOLD + 1);
|
|
162
|
-
assertEq(ruleset.weight, expected, "Weight at 20,001 cycles should match after single cache call");
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
166
|
-
// Test 4: Progressive caching for large gaps (40,001 cycles)
|
|
167
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
168
|
-
|
|
169
|
-
function test_largeGap_progressiveCaching_succeeds() public {
|
|
170
|
-
uint256 projectId = _launchProject();
|
|
171
|
-
uint256 rulesetId = _rulesets.latestRulesetIdOf(projectId);
|
|
172
|
-
|
|
173
|
-
// Warp forward 40,001 durations (needs 2 cache calls).
|
|
174
|
-
vm.warp(block.timestamp + _DURATION * (_THRESHOLD * 2 + 1));
|
|
175
|
-
|
|
176
|
-
// Without cache, reverts.
|
|
177
|
-
vm.expectRevert(abi.encodeWithSelector(JBRulesets.JBRulesets_WeightCacheRequired.selector, projectId));
|
|
178
|
-
_rulesets.currentOf(projectId);
|
|
179
|
-
|
|
180
|
-
// First cache call: advances cache by up to 20,000 iterations.
|
|
181
|
-
_rulesets.updateRulesetWeightCache(projectId, rulesetId);
|
|
182
|
-
|
|
183
|
-
// Still reverts — we need another cache call to cover the remaining gap.
|
|
184
|
-
vm.expectRevert(abi.encodeWithSelector(JBRulesets.JBRulesets_WeightCacheRequired.selector, projectId));
|
|
185
|
-
_rulesets.currentOf(projectId);
|
|
186
|
-
|
|
187
|
-
// Second cache call: covers the rest.
|
|
188
|
-
_rulesets.updateRulesetWeightCache(projectId, rulesetId);
|
|
189
|
-
|
|
190
|
-
// Now it should succeed.
|
|
191
|
-
JBRuleset memory ruleset = _rulesets.currentOf(projectId);
|
|
192
|
-
|
|
193
|
-
// Verify weight matches iterative calculation.
|
|
194
|
-
uint256 expected = _expectedWeight(_THRESHOLD * 2 + 1);
|
|
195
|
-
assertEq(ruleset.weight, expected, "Weight at 40,001 cycles should match after two cache calls");
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
199
|
-
// Test 5: Cache produces same weight as direct iteration
|
|
200
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
201
|
-
|
|
202
|
-
function test_cachedWeight_matchesDirect_atBoundary() public {
|
|
203
|
-
// Launch two identical projects.
|
|
204
|
-
uint256 projectA = _launchProject();
|
|
205
|
-
uint256 projectB = _launchProject();
|
|
206
|
-
|
|
207
|
-
uint256 rulesetIdB = _rulesets.latestRulesetIdOf(projectB);
|
|
208
|
-
|
|
209
|
-
// Warp to exactly 20,000 cycles (within threshold for both).
|
|
210
|
-
vm.warp(block.timestamp + _DURATION * _THRESHOLD);
|
|
211
|
-
|
|
212
|
-
// Project A: no cache, direct iteration.
|
|
213
|
-
JBRuleset memory rulesetA = _rulesets.currentOf(projectA);
|
|
214
|
-
|
|
215
|
-
// Project B: populate cache first, then query.
|
|
216
|
-
_rulesets.updateRulesetWeightCache(projectB, rulesetIdB);
|
|
217
|
-
JBRuleset memory rulesetB = _rulesets.currentOf(projectB);
|
|
218
|
-
|
|
219
|
-
// Both should produce identical weights.
|
|
220
|
-
assertEq(rulesetA.weight, rulesetB.weight, "Cached and uncached weights should be identical at threshold");
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
224
|
-
// Test 6: Zero weightCutPercent — cache is no-op
|
|
225
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
226
|
-
|
|
227
|
-
function test_zeroWeightCut_cacheNoOp() public {
|
|
228
|
-
// Launch a project with zero weight cut.
|
|
229
|
-
JBRulesetConfig[] memory configs = new JBRulesetConfig[](1);
|
|
230
|
-
configs[0].mustStartAtOrAfter = 0;
|
|
231
|
-
configs[0].duration = _DURATION;
|
|
232
|
-
configs[0].weight = _INITIAL_WEIGHT;
|
|
233
|
-
configs[0].weightCutPercent = 0; // No decay
|
|
234
|
-
configs[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
235
|
-
configs[0].metadata = _metadata;
|
|
236
|
-
configs[0].splitGroups = new JBSplitGroup[](0);
|
|
237
|
-
configs[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
238
|
-
|
|
239
|
-
uint256 projectId = _controller.launchProjectFor({
|
|
240
|
-
owner: _projectOwner,
|
|
241
|
-
projectUri: "zeroCut",
|
|
242
|
-
rulesetConfigurations: configs,
|
|
243
|
-
terminalConfigurations: new JBTerminalConfig[](0),
|
|
244
|
-
memo: ""
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
// Warp far beyond the threshold — since weightCutPercent = 0, no iterations needed.
|
|
248
|
-
vm.warp(block.timestamp + _DURATION * (_THRESHOLD * 5));
|
|
249
|
-
|
|
250
|
-
// Should succeed without any cache because the weight cut loop is skipped.
|
|
251
|
-
JBRuleset memory ruleset = _rulesets.currentOf(projectId);
|
|
252
|
-
assertEq(ruleset.weight, _INITIAL_WEIGHT, "Weight should remain unchanged with zero cut percent");
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
256
|
-
// Test 7: Cache with zero duration — updateRulesetWeightCache is no-op
|
|
257
|
-
// ═══════════════════════════════════════════════════════════════════
|
|
258
|
-
|
|
259
|
-
function test_zeroDuration_cacheNoOp() public {
|
|
260
|
-
// Launch a project with zero duration.
|
|
261
|
-
JBRulesetConfig[] memory configs = new JBRulesetConfig[](1);
|
|
262
|
-
configs[0].mustStartAtOrAfter = 0;
|
|
263
|
-
configs[0].duration = 0; // Never expires
|
|
264
|
-
configs[0].weight = _INITIAL_WEIGHT;
|
|
265
|
-
configs[0].weightCutPercent = _WEIGHT_CUT_PERCENT;
|
|
266
|
-
configs[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
267
|
-
configs[0].metadata = _metadata;
|
|
268
|
-
configs[0].splitGroups = new JBSplitGroup[](0);
|
|
269
|
-
configs[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
270
|
-
|
|
271
|
-
uint256 projectId = _controller.launchProjectFor({
|
|
272
|
-
owner: _projectOwner,
|
|
273
|
-
projectUri: "zeroDuration",
|
|
274
|
-
rulesetConfigurations: configs,
|
|
275
|
-
terminalConfigurations: new JBTerminalConfig[](0),
|
|
276
|
-
memo: ""
|
|
277
|
-
});
|
|
278
|
-
|
|
279
|
-
uint256 rulesetId = _rulesets.latestRulesetIdOf(projectId);
|
|
280
|
-
|
|
281
|
-
// Warp far ahead.
|
|
282
|
-
vm.warp(block.timestamp + 1_000_000);
|
|
283
|
-
|
|
284
|
-
// updateRulesetWeightCache should be a no-op (returns without caching).
|
|
285
|
-
_rulesets.updateRulesetWeightCache(projectId, rulesetId);
|
|
286
|
-
|
|
287
|
-
// currentOf should succeed — zero duration means the same ruleset is always current.
|
|
288
|
-
JBRuleset memory ruleset = _rulesets.currentOf(projectId);
|
|
289
|
-
assertEq(ruleset.weight, _INITIAL_WEIGHT, "Weight should remain unchanged with zero duration");
|
|
290
|
-
}
|
|
291
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
TestBurnTokensOf_Local
|
|
2
|
-
├── when caller is not permissioned or terminal
|
|
3
|
-
│ └── it should revert UNAUTHORIZED()
|
|
4
|
-
├── when caller is terminal and tokenCount gt zero
|
|
5
|
-
│ └── it should burn and emit BurnTokens
|
|
6
|
-
├── when caller has permission and tokenCount gt zero
|
|
7
|
-
│ └── it should burn and emit BurnTokens
|
|
8
|
-
└── when tokenCount eq zero
|
|
9
|
-
└── it should revert NO_BURNABLE_TOKENS
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
TestLaunchProjectFor_Local
|
|
2
|
-
└── when called
|
|
3
|
-
├── given metadata is provided
|
|
4
|
-
│ └── it will set metadata
|
|
5
|
-
├── given rulesets are provided
|
|
6
|
-
│ └── it will set rulesets
|
|
7
|
-
├── given terminals are provided
|
|
8
|
-
│ └── it will set terminals
|
|
9
|
-
├── given memo is provided
|
|
10
|
-
│ └── it will be included in the emit
|
|
11
|
-
└── given Directory exists
|
|
12
|
-
└── it will setControllerOf to itself
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
TestLaunchRulesetsFor
|
|
2
|
-
├── when caller does not have permission
|
|
3
|
-
│ └── it should revert
|
|
4
|
-
└── when caller has permission
|
|
5
|
-
├── given the project already has rulesets
|
|
6
|
-
│ └── it should revert
|
|
7
|
-
└── given the project does not yet have rulesets
|
|
8
|
-
└── it should set the controller, queue the rulesets, configure terminals, and emit LaunchRulesets
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
TestMigrateController
|
|
2
|
-
├── when caller does not have MIGRATE_CONTROLLER permission
|
|
3
|
-
│ └── it should revert
|
|
4
|
-
└── when caller has MIGRATE_CONTROLLER permission
|
|
5
|
-
├── given migration is not allowed by ruleset
|
|
6
|
-
│ └── it should revert
|
|
7
|
-
└── given migration is allowed by ruleset
|
|
8
|
-
├── given reserved token balance is pending
|
|
9
|
-
│ └── it should send reserved tokens to splits
|
|
10
|
-
└── given no reserved token balance is pending
|
|
11
|
-
├── it should prepare new controller for migration
|
|
12
|
-
└── it should emit MigrateController event
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
TestMintTokensOf_Local
|
|
2
|
-
├── when no ruleset is active
|
|
3
|
-
│ └── it should be able to mint
|
|
4
|
-
├── when minting is disabled in the funding cycle ruleset
|
|
5
|
-
│ └── it should revert
|
|
6
|
-
└── when minting is enabled in the funding cycle ruleset
|
|
7
|
-
├── given that there are tokens available to mint
|
|
8
|
-
│ └── it should be possible to mint
|
|
9
|
-
├── given that a data source is configured
|
|
10
|
-
│ └── it should be able to mint
|
|
11
|
-
└── given that a data source has permissioned another contract to mint
|
|
12
|
-
└── it should be able to mint
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
TestSendReservedTokensToSplitsOf_Local
|
|
2
|
-
├── when the project has no reserved token splits
|
|
3
|
-
│ └── it will mint to the project owner
|
|
4
|
-
└── when the project has reserved token splits
|
|
5
|
-
├── given a hook is configured
|
|
6
|
-
│ └── it will mint to hook and call its processSplitWith function
|
|
7
|
-
├── given a beneficiary is configured
|
|
8
|
-
│ └── it will mint for the beneficiary
|
|
9
|
-
├── given the projectId of split is nonzero and a beneficiary and hook are not configured
|
|
10
|
-
│ └── it will mint to the owner of the project
|
|
11
|
-
└── given projectId is zero and nothing is configured
|
|
12
|
-
└── it will mint to whoever called sendReservedTokens
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
TestTransferCreditsFrom_Local
|
|
2
|
-
├── when caller is permissioned
|
|
3
|
-
│ ├── given ruleset allows credit transfers
|
|
4
|
-
│ │ └── it will call JBTokens to transfer the credits
|
|
5
|
-
│ └── given ruleset does not allow credit transfers
|
|
6
|
-
│ └── it will revert CREDIT_TRANSFERS_PAUSED
|
|
7
|
-
└── when caller is not permissioned
|
|
8
|
-
└── it will revert UNAUTHORIZED
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
TestPrimaryTerminalOf_Local
|
|
2
|
-
├── when there are no terminals supporting the input token
|
|
3
|
-
│ └── it will return the zero address
|
|
4
|
-
└── when there is at least one supporting terminal
|
|
5
|
-
├── given there are multiple terminals with proper accountingContextForTokenOf
|
|
6
|
-
│ └── it will check each terminals accountingContextForTokenOf and return the first
|
|
7
|
-
└── given there are multiple terminals but none with the proper accountingContextForTokenOf
|
|
8
|
-
└── it will return the zero address
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
TestSetControllerOf_Local
|
|
2
|
-
├── when caller does not have any permission
|
|
3
|
-
│ └── it should revert
|
|
4
|
-
└── when caller isAllowedToSetFirstController or has permission
|
|
5
|
-
├── given that a project doesn't exist
|
|
6
|
-
│ └── it should revert
|
|
7
|
-
└── given that the project exists
|
|
8
|
-
├── given that the current controller is not setControllerAllowed
|
|
9
|
-
│ └── it should revert
|
|
10
|
-
└── given that the current controller is setControllerAllowed
|
|
11
|
-
└── it should set controllerOf and emit SetController
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
TestSetPrimaryTerminalOf_Local
|
|
2
|
-
├── when caller has no permission
|
|
3
|
-
│ └── it should revert with UNAUTHORIZED()
|
|
4
|
-
└── when caller has permission
|
|
5
|
-
├── given that there is no accountingContextForTokenOf
|
|
6
|
-
│ └── it should revert with TOKEN_NOT_ACCEPTED
|
|
7
|
-
└── given that there is an accountingContextForTokenOf
|
|
8
|
-
├── given that the terminal has already been added
|
|
9
|
-
│ └── it should not add the terminal
|
|
10
|
-
└── given that the terminal has not been added
|
|
11
|
-
├── given that the project is not allowed to set terminals
|
|
12
|
-
│ └── it should revert with SET_TERMINALS_NOT_ALLOWED
|
|
13
|
-
└── given that the project is allowed to set terminals
|
|
14
|
-
├── it should set the terminal and emit AddTerminal
|
|
15
|
-
└── it should set the terminal as primary and emit SetPrimaryTerminal
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
TestSetTerminalsOf_Local
|
|
2
|
-
├── when caller has no permission
|
|
3
|
-
│ └── it should revert with UNAUTHORIZED()
|
|
4
|
-
└── when caller has permission
|
|
5
|
-
├── given that not setTerminalsAllowed
|
|
6
|
-
│ └── it should revert with revert SET_TERMINALS_NOT_ALLOWED()
|
|
7
|
-
└── given that setTerminalsAllowed
|
|
8
|
-
├── given that duplicate terminals were added
|
|
9
|
-
│ └── it should revert with DUPLICATE_TERMINALS()
|
|
10
|
-
└── given that duplicate terminals were not added
|
|
11
|
-
└── it should set terminals and emit SetTerminals
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
TestPayoutLimitsOf_Local
|
|
2
|
-
└── when a project has payout limits
|
|
3
|
-
├── given they are configured for a specific token
|
|
4
|
-
│ └── it will return them
|
|
5
|
-
├── given they are configured for a specific terminal
|
|
6
|
-
│ └── it will return them
|
|
7
|
-
└── given they are configured for a specific rulesetId
|
|
8
|
-
└── it will return them
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
TestSetFundAccessLimitsFor_Local
|
|
2
|
-
├── when caller is not controller
|
|
3
|
-
│ └── it will revert
|
|
4
|
-
└── when caller is controller of project
|
|
5
|
-
├── given payoutLimit amount is gt uint224
|
|
6
|
-
│ └── it will revert INVALID_PAYOUT_LIMIT
|
|
7
|
-
├── given payoutLimit currency is gt uint32
|
|
8
|
-
│ └── it will revert INVALID_PAYOUT_LIMIT_CURRENCY
|
|
9
|
-
├── given payoutLimit currency is not given in ascending order
|
|
10
|
-
│ └── it will revert INVALID_PAYOUT_LIMIT_CURRENCY_ORDERING
|
|
11
|
-
├── given surplusAllowance amount gt uint224
|
|
12
|
-
│ └── it will revert INVALID_SURPLUS_ALLOWANCE
|
|
13
|
-
├── given surplusAllowance currency gt uint32
|
|
14
|
-
│ └── it will revert INVALID_PAYOUT_LIMIT_CURRENCY
|
|
15
|
-
├── given surplus allowance currencies are not ascending order
|
|
16
|
-
│ └── it will revert INVALID_SURPLUS_ALLOWANCE_CURRENCY_ORDERING
|
|
17
|
-
└── given valid config
|
|
18
|
-
└── it will set packed properties and emit SetFundAccessLimits
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
TestSurplusAllowancesOf_Local
|
|
2
|
-
└── when a project has specified surplus allowances
|
|
3
|
-
├── given they are specified for a specific ruleset
|
|
4
|
-
│ └── it will return them
|
|
5
|
-
├── given they are specified for a specific terminal
|
|
6
|
-
│ └── it will return them
|
|
7
|
-
└── given they are specified for a specific token
|
|
8
|
-
└── it will return them
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
TestGetDataFor_Local
|
|
2
|
-
├── when metadata length LTEQ MIN_METADATA_LENGTH
|
|
3
|
-
│ └── it will return false and empty bytes
|
|
4
|
-
└── when metadata length GT MIN_METADATA_LENGTH
|
|
5
|
-
├── given id is found
|
|
6
|
-
│ └── it will return found EQ true and targetData
|
|
7
|
-
└── given id is not found
|
|
8
|
-
└── it will return found EQ false and empty bytes targetData
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
TestAddAccountingContextsFor_Local
|
|
2
|
-
├── when caller is not permissioned
|
|
3
|
-
│ └── it will revert UNAUTHORIZED
|
|
4
|
-
├── when caller is permissioned
|
|
5
|
-
│ ├── given the context is already set
|
|
6
|
-
│ │ └── it will revert ACCOUNTING_CONTEXT_ALREADY_SET
|
|
7
|
-
│ └── given happypath
|
|
8
|
-
│ └── it will set the context and emit SetAccountingContext
|
|
9
|
-
└── when caller is controller
|
|
10
|
-
└── it will alsoGrantAccess
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
TestAddToBalanceOf_Local
|
|
2
|
-
├── when shouldReturnHeldFees eq true
|
|
3
|
-
│ ├── given return amount is zero
|
|
4
|
-
│ │ └── it will set heldFeesOf project to zero
|
|
5
|
-
│ ├── given return amount is non-zero and leftoverAmount GTEQ amountFromFee
|
|
6
|
-
│ │ └── it will return feeAmountResultingIn
|
|
7
|
-
│ └── given return amount is non-zero and leftoverAmount LT amountFromFee
|
|
8
|
-
│ └── it will set heldFeesOf return feeAmountFrom and set leftoverAmount to zero
|
|
9
|
-
├── when shouldReturnHeldFees eq false
|
|
10
|
-
│ └── it will call terminalstore recordAddedBalanceFor and emit AddToBalance
|
|
11
|
-
├── when the project DNH accounting context for the token
|
|
12
|
-
│ └── it will revert TOKEN_NOT_ACCEPTED
|
|
13
|
-
├── when the terminals token eq native token
|
|
14
|
-
│ └── it will use msg.value
|
|
15
|
-
├── when the terminals token eq native token and msgvalue eq zero
|
|
16
|
-
│ └── it will revert NO_MSG_VALUE_ALLOWED
|
|
17
|
-
├── when the terminal is calling itself
|
|
18
|
-
│ └── it will not transfer
|
|
19
|
-
└── when pay metadata contains permit data
|
|
20
|
-
├── given the permit allowance lt amount
|
|
21
|
-
│ └── it will revert PERMIT_ALLOWANCE_NOT_ENOUGH
|
|
22
|
-
└── given permit allowance is good
|
|
23
|
-
└── it will set permit allowance to spend tokens for user via permit2
|