@bananapus/core-v6 0.0.37 → 0.0.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/foundry.lock +1 -7
- package/foundry.toml +1 -1
- package/package.json +19 -7
- package/src/JBController.sol +19 -1
- package/src/JBMultiTerminal.sol +68 -34
- package/src/JBTerminalStore.sol +6 -6
- package/src/interfaces/IJBController.sol +4 -1
- package/src/libraries/JBFees.sol +47 -9
- package/src/libraries/JBPayoutSplitGroupLib.sol +2 -2
- package/src/periphery/JBMatchingPriceFeed.sol +1 -1
- package/test/mock/MockMaliciousBeneficiary.sol +15 -15
- package/ADMINISTRATION.md +0 -103
- package/ARCHITECTURE.md +0 -133
- package/AUDIT_INSTRUCTIONS.md +0 -139
- package/RISKS.md +0 -215
- package/SKILLS.md +0 -55
- package/STYLE_GUIDE.md +0 -610
- package/USER_JOURNEYS.md +0 -215
- package/script/Deploy.s.sol +0 -124
- package/script/DeployPeriphery.s.sol +0 -354
- package/slither-ci.config.json +0 -10
- package/test/AuditFixes.t.sol +0 -808
- package/test/ComprehensiveInvariant.t.sol +0 -306
- package/test/CoreExploitTests.t.sol +0 -2741
- package/test/EconomicSimulation.t.sol +0 -348
- package/test/EntryPointPermutations.t.sol +0 -684
- package/test/FlashLoanAttacks.t.sol +0 -797
- package/test/PermissionEscalation.t.sol +0 -711
- package/test/PermissionsInvariant.t.sol +0 -403
- package/test/RulesetTransitions.t.sol +0 -713
- package/test/SplitLoopTests.t.sol +0 -752
- package/test/TestAccessToFunds.sol +0 -2683
- package/test/TestAuditResponseDesignProofs.sol +0 -434
- package/test/TestCashOut.sol +0 -198
- package/test/TestCashOutCountFor.sol +0 -271
- package/test/TestCashOutHooks.sol +0 -351
- package/test/TestCashOutTimingEdge.sol +0 -241
- package/test/TestDataHookFuzzing.sol +0 -524
- package/test/TestDurationUnderflow.sol +0 -233
- package/test/TestFeeFreeCashOutBypass.sol +0 -949
- package/test/TestFeeProcessingFailure.sol +0 -218
- package/test/TestFees.sol +0 -619
- package/test/TestForwardedTokenConsumption.sol +0 -425
- package/test/TestInterfaceSupport.sol +0 -81
- package/test/TestJBERC20Inheritance.sol +0 -103
- package/test/TestL2SequencerPriceFeed.sol +0 -292
- package/test/TestLaunchProject.sol +0 -188
- package/test/TestMetaTx.sol +0 -217
- package/test/TestMetadataOffsetOverflow.sol +0 -179
- package/test/TestMetadataParserLib.sol +0 -471
- package/test/TestMigrationHeldFees.sol +0 -255
- package/test/TestMintTokensOf.sol +0 -185
- package/test/TestMultiTerminalSurplus.sol +0 -348
- package/test/TestMultiTokenSurplus.sol +0 -202
- package/test/TestMultipleAccessLimits.sol +0 -664
- package/test/TestPayBurnRedeemFlow.sol +0 -195
- package/test/TestPayHooks.sol +0 -209
- package/test/TestPermissions.sol +0 -324
- package/test/TestPermissionsEdge.sol +0 -290
- package/test/TestPermit2DataHook.t.sol +0 -360
- package/test/TestPermit2Terminal.sol +0 -372
- package/test/TestRulesetQueueing.sol +0 -1025
- package/test/TestRulesetQueuingStress.sol +0 -806
- package/test/TestRulesetWeightCaching.sol +0 -178
- package/test/TestSplits.sol +0 -391
- package/test/TestTerminalMigration.sol +0 -274
- package/test/TestTerminalPreviewParity.sol +0 -208
- package/test/TestTokenFlow.sol +0 -191
- package/test/TestWeightCacheStaleAfterRejection.sol +0 -303
- package/test/WeirdTokenTests.t.sol +0 -817
- package/test/audit/CashOutReenterPay.t.sol +0 -501
- package/test/audit/CodexHeldFeeRounding.t.sol +0 -159
- package/test/audit/CodexMigrationFeeFailure.t.sol +0 -163
- package/test/audit/CrossTerminalSurplusSpoof.t.sol +0 -140
- package/test/audit/CycledSurplusAllowanceReset.t.sol +0 -184
- package/test/audit/FeeFreeSurplusLifecycle.t.sol +0 -399
- package/test/audit/FeeFreeSurplusStale.t.sol +0 -248
- package/test/audit/USDTVoidReturnCompat.t.sol +0 -525
- package/test/fork/TestChainlinkPriceFeedFork.sol +0 -254
- package/test/fork/TestSequencerPriceFeedFork.sol +0 -168
- package/test/fork/TestTerminalPreviewParityFork.sol +0 -108
- package/test/formal/BondingCurveProperties.t.sol +0 -420
- package/test/formal/FeeProperties.t.sol +0 -252
- package/test/invariants/Phase3DeepInvariant.t.sol +0 -412
- package/test/invariants/RulesetsInvariant.t.sol +0 -125
- package/test/invariants/TerminalStoreInvariant.t.sol +0 -227
- package/test/invariants/TokensInvariant.t.sol +0 -195
- package/test/invariants/handlers/ComprehensiveHandler.sol +0 -303
- package/test/invariants/handlers/EconomicHandler.sol +0 -377
- package/test/invariants/handlers/Phase3Handler.sol +0 -443
- package/test/invariants/handlers/RulesetsHandler.sol +0 -115
- package/test/invariants/handlers/TerminalStoreHandler.sol +0 -151
- package/test/invariants/handlers/TokensHandler.sol +0 -126
- package/test/regression/HoldFeesCashOutReserved.t.sol +0 -415
- package/test/regression/WeightCacheBoundary.t.sol +0 -291
- package/test/trees/JBController/burnTokensOf.tree +0 -9
- package/test/trees/JBController/claimTokensFor.tree +0 -5
- package/test/trees/JBController/deployERC20For.tree +0 -5
- package/test/trees/JBController/getRulesetOf.tree +0 -5
- package/test/trees/JBController/launchProjectFor.tree +0 -12
- package/test/trees/JBController/launchRulesetsFor.tree +0 -8
- package/test/trees/JBController/migrateController.tree +0 -12
- package/test/trees/JBController/mintTokensOf.tree +0 -12
- package/test/trees/JBController/payReservedTokenToTerminal.tree +0 -8
- package/test/trees/JBController/receiveMigrationFrom.tree +0 -4
- package/test/trees/JBController/sendReservedTokensToSplitsOf.tree +0 -12
- package/test/trees/JBController/setMetadataOf.tree +0 -5
- package/test/trees/JBController/setSplitGroupsOf.tree +0 -5
- package/test/trees/JBController/setTokenFor.tree +0 -5
- package/test/trees/JBController/transferCreditsFrom.tree +0 -8
- package/test/trees/JBDirectory/primaryTerminalOf.tree +0 -8
- package/test/trees/JBDirectory/setControllerOf.tree +0 -11
- package/test/trees/JBDirectory/setPrimaryTerminalOf.tree +0 -15
- package/test/trees/JBDirectory/setTerminalsOf.tree +0 -11
- package/test/trees/JBERC20/initialize.tree +0 -7
- package/test/trees/JBERC20/name.tree +0 -5
- package/test/trees/JBERC20/nonces.tree +0 -5
- package/test/trees/JBERC20/symbol.tree +0 -5
- package/test/trees/JBFeelessAddresses/setFeelessAddress.tree +0 -5
- package/test/trees/JBFeelessAddresses/supportsInterface.tree +0 -5
- package/test/trees/JBFundAccessLimits/payoutLimitOf.tree +0 -5
- package/test/trees/JBFundAccessLimits/payoutLimitsOf.tree +0 -8
- package/test/trees/JBFundAccessLimits/setFundAccessLimitsFor.tree +0 -18
- package/test/trees/JBFundAccessLimits/surplusAllowanceOf.tree +0 -5
- package/test/trees/JBFundAccessLimits/surplusAllowancesOf.tree +0 -8
- package/test/trees/JBMetadataResolver/getDataFor.tree +0 -8
- package/test/trees/JBMultiTerminal/accountingContextsOf.tree +0 -5
- package/test/trees/JBMultiTerminal/addAccountingContextsFor.tree +0 -10
- package/test/trees/JBMultiTerminal/addToBalanceOf.tree +0 -23
- package/test/trees/JBMultiTerminal/cashOutTokensOf.tree +0 -23
- package/test/trees/JBMultiTerminal/executePayout.tree +0 -32
- package/test/trees/JBMultiTerminal/executeProcessFee.tree +0 -14
- package/test/trees/JBMultiTerminal/migrateBalanceOf.tree +0 -12
- package/test/trees/JBMultiTerminal/pay.tree +0 -23
- package/test/trees/JBMultiTerminal/processHeldFeesOf.tree +0 -8
- package/test/trees/JBMultiTerminal/sendPayoutsOf.tree +0 -34
- package/test/trees/JBMultiTerminal/useAllowanceOf.tree +0 -16
- package/test/trees/JBPermissions/hasPermission.tree +0 -8
- package/test/trees/JBPermissions/hasPermissions.tree +0 -8
- package/test/trees/JBPermissions/setPermissionsFor.tree +0 -5
- package/test/trees/JBPrices/addPriceFeedFor.tree +0 -14
- package/test/trees/JBPrices/pricePerUnitOf.tree +0 -11
- package/test/trees/JBProjects/createFor.tree +0 -11
- package/test/trees/JBProjects/setTokenUriResolver.tree +0 -5
- package/test/trees/JBProjects/supportsInterface.tree +0 -9
- package/test/trees/JBProjects/tokenURI.tree +0 -5
- package/test/trees/JBRulesets/currentApprovalStatusForLatestRulesetOf.tree +0 -8
- package/test/trees/JBRulesets/currentOf.tree +0 -12
- package/test/trees/JBRulesets/getRulesetOf.tree +0 -5
- package/test/trees/JBRulesets/latestQueuedRulesetOf.tree +0 -10
- package/test/trees/JBRulesets/rulesetsOf.tree +0 -11
- package/test/trees/JBRulesets/upcomingRulesetOf.tree +0 -20
- package/test/trees/JBRulesets/updateRulesetWeightCache.tree +0 -5
- package/test/trees/JBSplits/setSplitGroupsOf.tree +0 -17
- package/test/trees/JBSplits/splitsOf.tree +0 -5
- package/test/trees/JBTerminalStore/currentReclaimableSurplusOf.tree +0 -16
- package/test/trees/JBTerminalStore/currentSurplusOf.tree +0 -25
- package/test/trees/JBTerminalStore/currentTotalSurplusOf.tree +0 -5
- package/test/trees/JBTerminalStore/recordCashOutsFor.tree +0 -16
- package/test/trees/JBTerminalStore/recordPaymentFrom.tree +0 -14
- package/test/trees/JBTerminalStore/recordPayoutFor.tree +0 -10
- package/test/trees/JBTerminalStore/recordTerminalMigration.tree +0 -5
- package/test/trees/JBTerminalStore/recordUsedAllowanceOf.tree +0 -10
- package/test/trees/JBTokens/burnFrom.tree +0 -10
- package/test/trees/JBTokens/claimTokensFor.tree +0 -10
- package/test/trees/JBTokens/deployERC20For.tree +0 -12
- package/test/trees/JBTokens/mintFor.tree +0 -10
- package/test/trees/JBTokens/setTokenFor.tree +0 -11
- package/test/trees/JBTokens/totalBalanceOf.tree +0 -5
- package/test/trees/JBTokens/totalSupplyOf.tree +0 -5
- package/test/trees/JBTokens/transferCreditsFrom.tree +0 -8
- package/test/trees/mintTokensOf.tree +0 -12
- package/test/units/static/JBChainlinkV3PriceFeed/TestPriceFeed.sol +0 -223
- package/test/units/static/JBController/JBControllerSetup.sol +0 -50
- package/test/units/static/JBController/TestBurnTokensOf.sol +0 -114
- package/test/units/static/JBController/TestClaimTokensFor.sol +0 -63
- package/test/units/static/JBController/TestDeployErc20For.sol +0 -86
- package/test/units/static/JBController/TestLaunchProjectFor.sol +0 -302
- package/test/units/static/JBController/TestLaunchRulesetsFor.sol +0 -342
- package/test/units/static/JBController/TestMigrateController.sol +0 -157
- package/test/units/static/JBController/TestMintTokensOfUnits.sol +0 -111
- package/test/units/static/JBController/TestOmnichainRulesetOperator.sol +0 -324
- package/test/units/static/JBController/TestPayReservedTokenToTerminal.sol +0 -74
- package/test/units/static/JBController/TestPreviewMintOf.sol +0 -117
- package/test/units/static/JBController/TestReceiveMigrationFrom.sol +0 -99
- package/test/units/static/JBController/TestRulesetViews.sol +0 -225
- package/test/units/static/JBController/TestSendReservedTokensToSplitsOf.sol +0 -615
- package/test/units/static/JBController/TestSetSplitGroupsOf.sol +0 -68
- package/test/units/static/JBController/TestSetTokenFor.sol +0 -239
- package/test/units/static/JBController/TestSetUriOf.sol +0 -57
- package/test/units/static/JBController/TestTransferCreditsFrom.sol +0 -169
- package/test/units/static/JBDeadline/TestDeadlineFuzz.sol +0 -211
- package/test/units/static/JBDirectory/JBDirectorySetup.sol +0 -26
- package/test/units/static/JBDirectory/TestPrimaryTerminalOf.sol +0 -126
- package/test/units/static/JBDirectory/TestSetControllerOf.sol +0 -183
- package/test/units/static/JBDirectory/TestSetControllerOfMigrationOrder.sol +0 -104
- package/test/units/static/JBDirectory/TestSetPrimaryTerminalOf.sol +0 -179
- package/test/units/static/JBDirectory/TestSetTerminalsOf.sol +0 -137
- package/test/units/static/JBERC20/JBERC20Setup.sol +0 -34
- package/test/units/static/JBERC20/SigUtils.sol +0 -36
- package/test/units/static/JBERC20/TestInitialize.sol +0 -60
- package/test/units/static/JBERC20/TestName.sol +0 -30
- package/test/units/static/JBERC20/TestNonces.sol +0 -62
- package/test/units/static/JBERC20/TestSymbol.sol +0 -31
- package/test/units/static/JBFeelessAdresses/JBFeelessSetup.sol +0 -22
- package/test/units/static/JBFeelessAdresses/TestInterfaces.sol +0 -30
- package/test/units/static/JBFeelessAdresses/TestSetFeelessAddress.sol +0 -35
- package/test/units/static/JBFees/TestFeesFuzz.sol +0 -79
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimals.sol +0 -16
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimalsFuzz.sol +0 -71
- package/test/units/static/JBFundAccessLimits/JBFundAccessSetup.sol +0 -24
- package/test/units/static/JBFundAccessLimits/TestFundAccessLimitsEdge.sol +0 -163
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitOf.sol +0 -59
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitsOf.sol +0 -101
- package/test/units/static/JBFundAccessLimits/TestSetFundAccessLimitsFor.sol +0 -189
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowanceOf.sol +0 -64
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowancesOf.sol +0 -102
- package/test/units/static/JBMetadataResolver/TestGetDataFor.sol +0 -90
- package/test/units/static/JBMetadataResolver/TestMetadataResolverEdgeCases.sol +0 -247
- package/test/units/static/JBMetadataResolver/TestMetadataResolverFuzz.sol +0 -229
- package/test/units/static/JBMultiTerminal/JBMultiTerminalSetup.sol +0 -50
- package/test/units/static/JBMultiTerminal/TestAccountingContextsOf.sol +0 -72
- package/test/units/static/JBMultiTerminal/TestAddAccountingContextsFor.sol +0 -289
- package/test/units/static/JBMultiTerminal/TestAddToBalanceOf.sol +0 -474
- package/test/units/static/JBMultiTerminal/TestCashOutTokensOf.sol +0 -624
- package/test/units/static/JBMultiTerminal/TestExecutePayout.sol +0 -578
- package/test/units/static/JBMultiTerminal/TestExecuteProcessFee.sol +0 -202
- package/test/units/static/JBMultiTerminal/TestMigrateBalanceOf.sol +0 -222
- package/test/units/static/JBMultiTerminal/TestPay.sol +0 -604
- package/test/units/static/JBMultiTerminal/TestPreviewCashOutFrom.sol +0 -117
- package/test/units/static/JBMultiTerminal/TestPreviewPayFor.sol +0 -114
- package/test/units/static/JBMultiTerminal/TestProcessHeldFeesOf.sol +0 -228
- package/test/units/static/JBMultiTerminal/TestSelfPayRevert.sol +0 -55
- package/test/units/static/JBMultiTerminal/TestSendPayoutsOf.sol +0 -257
- package/test/units/static/JBMultiTerminal/TestUseAllowanceOf.sol +0 -611
- package/test/units/static/JBPermissions/JBPermissionsSetup.sol +0 -20
- package/test/units/static/JBPermissions/TestHasPermission.sol +0 -50
- package/test/units/static/JBPermissions/TestHasPermissions.sol +0 -93
- package/test/units/static/JBPermissions/TestSetPermissionsFor.sol +0 -64
- package/test/units/static/JBPrices/JBPricesSetup.sol +0 -32
- package/test/units/static/JBPrices/TestAddPriceFeedFor.sol +0 -107
- package/test/units/static/JBPrices/TestPricePerUnitOf.sol +0 -132
- package/test/units/static/JBPrices/TestPrices.sol +0 -265
- package/test/units/static/JBProjects/JBProjectsSetup.sol +0 -22
- package/test/units/static/JBProjects/TestCreateFor.sol +0 -71
- package/test/units/static/JBProjects/TestInitialProject.sol +0 -21
- package/test/units/static/JBProjects/TestInterfaces.sol +0 -26
- package/test/units/static/JBProjects/TestSetResolver.sol +0 -37
- package/test/units/static/JBProjects/TestTokenUri.sol +0 -40
- package/test/units/static/JBRulesetMetadataResolver/TestSetCashOutTaxRateTo.sol +0 -108
- package/test/units/static/JBRulesets/JBRulesetsSetup.sol +0 -24
- package/test/units/static/JBRulesets/TestCurrentApprovalStatusForLatestRulesetOf.sol +0 -265
- package/test/units/static/JBRulesets/TestCurrentOf.sol +0 -242
- package/test/units/static/JBRulesets/TestGetRulesetOf.sol +0 -100
- package/test/units/static/JBRulesets/TestLatestQueuedRulesetOf.sol +0 -260
- package/test/units/static/JBRulesets/TestRulesets.sol +0 -632
- package/test/units/static/JBRulesets/TestRulesetsOf.sol +0 -37
- package/test/units/static/JBRulesets/TestUpcomingRulesetOf.sol +0 -522
- package/test/units/static/JBRulesets/TestUpdateRulesetWeightCache.sol +0 -96
- package/test/units/static/JBSplits/JBSplitsSetup.sol +0 -26
- package/test/units/static/JBSplits/TestSelfManagedSplitGroups.sol +0 -552
- package/test/units/static/JBSplits/TestSetSplitGroupsOf.sol +0 -377
- package/test/units/static/JBSplits/TestSplitsLockedEdge.sol +0 -267
- package/test/units/static/JBSplits/TestSplitsOf.sol +0 -24
- package/test/units/static/JBSplits/TestSplitsPacking.sol +0 -36
- package/test/units/static/JBSurplus/TestSurplusFuzz.sol +0 -160
- package/test/units/static/JBTerminalStore/JBTerminalStoreSetup.sol +0 -45
- package/test/units/static/JBTerminalStore/TestCurrentReclaimableSurplusOf.sol +0 -536
- package/test/units/static/JBTerminalStore/TestCurrentSurplusOf.sol +0 -463
- package/test/units/static/JBTerminalStore/TestCurrentTotalSurplusOf.sol +0 -135
- package/test/units/static/JBTerminalStore/TestPreviewCashOutFrom.sol +0 -476
- package/test/units/static/JBTerminalStore/TestPreviewPayFrom.sol +0 -494
- package/test/units/static/JBTerminalStore/TestRecordCashOutsFor.sol +0 -652
- package/test/units/static/JBTerminalStore/TestRecordPaymentFrom.sol +0 -744
- package/test/units/static/JBTerminalStore/TestRecordPayoutFor.sol +0 -289
- package/test/units/static/JBTerminalStore/TestRecordTerminalMigration.sol +0 -138
- package/test/units/static/JBTerminalStore/TestRecordUsedAllowanceOf.sol +0 -415
- package/test/units/static/JBTerminalStore/TestUint224Overflow.sol +0 -219
- package/test/units/static/JBTokens/JBTokensSetup.sol +0 -32
- package/test/units/static/JBTokens/TestBurnFrom.sol +0 -107
- package/test/units/static/JBTokens/TestClaimTokensFor.sol +0 -110
- package/test/units/static/JBTokens/TestDeployERC20ForUnits.sol +0 -92
- package/test/units/static/JBTokens/TestMintFor.sol +0 -100
- package/test/units/static/JBTokens/TestSetTokenFor.sol +0 -98
- package/test/units/static/JBTokens/TestTotalBalanceOf.sol +0 -65
- package/test/units/static/JBTokens/TestTotalSupplyOf.sol +0 -56
- package/test/units/static/JBTokens/TestTransferCreditsFrom.sol +0 -56
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {MetadataResolverHelper} from "../../../helpers/MetadataResolverHelper.sol";
|
|
5
|
-
import {JBMultiTerminal} from "../../../../src/JBMultiTerminal.sol";
|
|
6
|
-
import {IJBDirectory} from "../../../../src/interfaces/IJBDirectory.sol";
|
|
7
|
-
import {IJBFeelessAddresses} from "../../../../src/interfaces/IJBFeelessAddresses.sol";
|
|
8
|
-
import {IJBMultiTerminal} from "../../../../src/interfaces/IJBMultiTerminal.sol";
|
|
9
|
-
import {IJBPermissions} from "../../../../src/interfaces/IJBPermissions.sol";
|
|
10
|
-
import {IJBProjects} from "../../../../src/interfaces/IJBProjects.sol";
|
|
11
|
-
import {IJBRulesets} from "../../../../src/interfaces/IJBRulesets.sol";
|
|
12
|
-
import {IJBSplits} from "../../../../src/interfaces/IJBSplits.sol";
|
|
13
|
-
import {IJBTerminalStore} from "../../../../src/interfaces/IJBTerminalStore.sol";
|
|
14
|
-
import {IJBTokens} from "../../../../src/interfaces/IJBTokens.sol";
|
|
15
|
-
import {IPermit2} from "@uniswap/permit2/src/interfaces/IPermit2.sol";
|
|
16
|
-
import {JBTest} from "../../../helpers/JBTest.sol";
|
|
17
|
-
|
|
18
|
-
/*
|
|
19
|
-
Contract that deploys a target contract with other mock contracts to satisfy the constructor.
|
|
20
|
-
Tests relative to this contract will be dependent on mock calls/emits and stdStorage.
|
|
21
|
-
*/
|
|
22
|
-
contract JBMultiTerminalSetup is JBTest {
|
|
23
|
-
// Target Contract
|
|
24
|
-
IJBMultiTerminal public _terminal;
|
|
25
|
-
MetadataResolverHelper public _metadataHelper;
|
|
26
|
-
|
|
27
|
-
// Mocks
|
|
28
|
-
IJBPermissions public permissions = IJBPermissions(makeAddr("permissions"));
|
|
29
|
-
IJBProjects public projects = IJBProjects(makeAddr("projects"));
|
|
30
|
-
IJBDirectory public directory = IJBDirectory(makeAddr("directory"));
|
|
31
|
-
IJBRulesets public rulesets = IJBRulesets(makeAddr("rulesets"));
|
|
32
|
-
IJBTokens public tokens = IJBTokens(makeAddr("tokens"));
|
|
33
|
-
IJBSplits public splits = IJBSplits(makeAddr("splits"));
|
|
34
|
-
IJBTerminalStore public store = IJBTerminalStore(makeAddr("store"));
|
|
35
|
-
IJBFeelessAddresses public feelessAddresses = IJBFeelessAddresses(makeAddr("feeless"));
|
|
36
|
-
IPermit2 public permit2 = IPermit2(makeAddr("permit2"));
|
|
37
|
-
address trustedForwarder = makeAddr("forwarder");
|
|
38
|
-
|
|
39
|
-
function multiTerminalSetup() public virtual {
|
|
40
|
-
// Constructor will call to find directory from the terminal store
|
|
41
|
-
mockExpect(address(store), abi.encodeCall(IJBTerminalStore.DIRECTORY, ()), abi.encode(address(directory)));
|
|
42
|
-
|
|
43
|
-
// Instantiate the contract being tested
|
|
44
|
-
_terminal = new JBMultiTerminal(
|
|
45
|
-
feelessAddresses, permissions, projects, splits, store, tokens, permit2, trustedForwarder
|
|
46
|
-
);
|
|
47
|
-
|
|
48
|
-
_metadataHelper = new MetadataResolverHelper();
|
|
49
|
-
}
|
|
50
|
-
}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {IJBDirectory} from "../../../../src/interfaces/IJBDirectory.sol";
|
|
5
|
-
import {IJBTerminalStore} from "../../../../src/interfaces/IJBTerminalStore.sol";
|
|
6
|
-
import {JBAccountingContext} from "../../../../src/structs/JBAccountingContext.sol";
|
|
7
|
-
import {IERC721} from "@openzeppelin/contracts/token/ERC721/IERC721.sol";
|
|
8
|
-
import {JBMultiTerminalSetup} from "./JBMultiTerminalSetup.sol";
|
|
9
|
-
|
|
10
|
-
contract TestAccountingContextsOf_Local is JBMultiTerminalSetup {
|
|
11
|
-
uint256 _projectId = 1;
|
|
12
|
-
address _usdc = makeAddr("USDC");
|
|
13
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
14
|
-
uint256 _usdcCurrency = uint32(uint160(_usdc));
|
|
15
|
-
|
|
16
|
-
function setUp() public {
|
|
17
|
-
super.multiTerminalSetup();
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
function test_WhenAccountingContextsAreSet() external {
|
|
21
|
-
// it will return contexts
|
|
22
|
-
|
|
23
|
-
// mock call to JBProjects ownerOf(_projectId)
|
|
24
|
-
bytes memory _projectsCall = abi.encodeCall(IERC721.ownerOf, (_projectId));
|
|
25
|
-
bytes memory _projectsCallReturn = abi.encode(address(this));
|
|
26
|
-
mockExpect(address(projects), _projectsCall, _projectsCallReturn);
|
|
27
|
-
|
|
28
|
-
// mock call to JBDirectory controllerOf(_projectId)
|
|
29
|
-
mockExpect(
|
|
30
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
31
|
-
);
|
|
32
|
-
|
|
33
|
-
// call params
|
|
34
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
35
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
36
|
-
_tokens[0] = JBAccountingContext({token: _usdc, decimals: 6, currency: uint32(uint160(_usdc))});
|
|
37
|
-
|
|
38
|
-
// Mock recordAccountingContextOf in the store (validation now happens there)
|
|
39
|
-
mockExpect(
|
|
40
|
-
address(store), abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)), ""
|
|
41
|
-
);
|
|
42
|
-
|
|
43
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
44
|
-
|
|
45
|
-
// Mock the store to return all contexts when queried
|
|
46
|
-
mockExpect(
|
|
47
|
-
address(store),
|
|
48
|
-
abi.encodeCall(IJBTerminalStore.accountingContextsOf, (address(_terminal), _projectId)),
|
|
49
|
-
abi.encode(_tokens)
|
|
50
|
-
);
|
|
51
|
-
|
|
52
|
-
JBAccountingContext[] memory _storedContexts = _terminal.accountingContextsOf(_projectId);
|
|
53
|
-
assertEq(_storedContexts[0].currency, _usdcCurrency);
|
|
54
|
-
assertEq(_storedContexts[0].token, _usdc);
|
|
55
|
-
assertEq(_storedContexts[0].decimals, 6);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
function test_WhenAccountingContextsAreNotSet() external {
|
|
59
|
-
// it will return an empty array
|
|
60
|
-
|
|
61
|
-
// Mock the store to return empty array
|
|
62
|
-
JBAccountingContext[] memory _empty = new JBAccountingContext[](0);
|
|
63
|
-
mockExpect(
|
|
64
|
-
address(store),
|
|
65
|
-
abi.encodeCall(IJBTerminalStore.accountingContextsOf, (address(_terminal), _projectId)),
|
|
66
|
-
abi.encode(_empty)
|
|
67
|
-
);
|
|
68
|
-
|
|
69
|
-
JBAccountingContext[] memory _storedContexts = _terminal.accountingContextsOf(_projectId);
|
|
70
|
-
assertEq(_storedContexts.length, 0);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
@@ -1,289 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {JBTerminalStore} from "../../../../src/JBTerminalStore.sol";
|
|
5
|
-
import {IJBDirectory} from "../../../../src/interfaces/IJBDirectory.sol";
|
|
6
|
-
import {IJBTerminalStore} from "../../../../src/interfaces/IJBTerminalStore.sol";
|
|
7
|
-
import {JBConstants} from "../../../../src/libraries/JBConstants.sol";
|
|
8
|
-
import {JBAccountingContext} from "../../../../src/structs/JBAccountingContext.sol";
|
|
9
|
-
import {IERC721} from "@openzeppelin/contracts/token/ERC721/IERC721.sol";
|
|
10
|
-
import {JBMultiTerminalSetup} from "./JBMultiTerminalSetup.sol";
|
|
11
|
-
|
|
12
|
-
contract TestAddAccountingContextsFor_Local is JBMultiTerminalSetup {
|
|
13
|
-
uint256 _projectId = 1;
|
|
14
|
-
address _usdc = makeAddr("USDC");
|
|
15
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
16
|
-
uint256 _usdcCurrency = uint32(uint160(_usdc));
|
|
17
|
-
|
|
18
|
-
function setUp() public {
|
|
19
|
-
super.multiTerminalSetup();
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
function test_WhenCallerIsNotPermissioned() external {
|
|
23
|
-
// it will revert UNAUTHORIZED
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
modifier whenCallerIsPermissioned() {
|
|
27
|
-
// mock call to JBProjects ownerOf(_projectId)
|
|
28
|
-
bytes memory _projectsCall = abi.encodeCall(IERC721.ownerOf, (_projectId));
|
|
29
|
-
bytes memory _projectsCallReturn = abi.encode(address(this));
|
|
30
|
-
mockExpect(address(projects), _projectsCall, _projectsCallReturn);
|
|
31
|
-
|
|
32
|
-
// mock call to JBDirectory controllerOf(_projectId)
|
|
33
|
-
mockExpect(
|
|
34
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
35
|
-
);
|
|
36
|
-
|
|
37
|
-
_;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
function test_GivenTheContextIsAlreadySet() external whenCallerIsPermissioned {
|
|
41
|
-
// it will revert ACCOUNTING_CONTEXT_ALREADY_SET
|
|
42
|
-
|
|
43
|
-
// call params
|
|
44
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
45
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
46
|
-
_tokens[0] = JBAccountingContext({token: _usdc, decimals: 6, currency: uint32(uint160(_usdc))});
|
|
47
|
-
|
|
48
|
-
// Mock recordAccountingContextOf to revert with AccountingContextAlreadySet
|
|
49
|
-
vm.mockCallRevert(
|
|
50
|
-
address(store),
|
|
51
|
-
abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)),
|
|
52
|
-
abi.encodeWithSelector(JBTerminalStore.JBTerminalStore_AccountingContextAlreadySet.selector, _usdc)
|
|
53
|
-
);
|
|
54
|
-
|
|
55
|
-
vm.expectRevert(
|
|
56
|
-
abi.encodeWithSelector(JBTerminalStore.JBTerminalStore_AccountingContextAlreadySet.selector, _usdc)
|
|
57
|
-
);
|
|
58
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
function test_GivenHappyPathERC20() external whenCallerIsPermissioned {
|
|
62
|
-
// it will set the context and emit SetAccountingContext
|
|
63
|
-
|
|
64
|
-
// call params
|
|
65
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
66
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
67
|
-
_tokens[0] = JBAccountingContext({token: _usdc, decimals: 6, currency: uint32(uint160(_usdc))});
|
|
68
|
-
|
|
69
|
-
// Mock recordAccountingContextOf in the store (validation now happens there)
|
|
70
|
-
mockExpect(
|
|
71
|
-
address(store), abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)), ""
|
|
72
|
-
);
|
|
73
|
-
|
|
74
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
75
|
-
|
|
76
|
-
// Mock the store to return the context when queried
|
|
77
|
-
mockExpect(
|
|
78
|
-
address(store),
|
|
79
|
-
abi.encodeCall(IJBTerminalStore.accountingContextOf, (address(_terminal), _projectId, _usdc)),
|
|
80
|
-
abi.encode(_tokens[0])
|
|
81
|
-
);
|
|
82
|
-
|
|
83
|
-
JBAccountingContext memory _storedContext = _terminal.accountingContextForTokenOf(_projectId, _usdc);
|
|
84
|
-
assertEq(_storedContext.token, _usdc);
|
|
85
|
-
assertEq(_storedContext.decimals, 6);
|
|
86
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
87
|
-
assertEq(_storedContext.currency, uint32(uint160(_usdc)));
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
function test_GivenHappyPathNative() external whenCallerIsPermissioned {
|
|
91
|
-
// call params
|
|
92
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
93
|
-
_tokens[0] = JBAccountingContext({
|
|
94
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
// Mock recordAccountingContextOf in the store (validation now happens there)
|
|
98
|
-
mockExpect(
|
|
99
|
-
address(store), abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)), ""
|
|
100
|
-
);
|
|
101
|
-
|
|
102
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
103
|
-
|
|
104
|
-
// Mock the store to return the context when queried
|
|
105
|
-
mockExpect(
|
|
106
|
-
address(store),
|
|
107
|
-
abi.encodeCall(
|
|
108
|
-
IJBTerminalStore.accountingContextOf, (address(_terminal), _projectId, JBConstants.NATIVE_TOKEN)
|
|
109
|
-
),
|
|
110
|
-
abi.encode(_tokens[0])
|
|
111
|
-
);
|
|
112
|
-
|
|
113
|
-
JBAccountingContext memory _storedContext =
|
|
114
|
-
_terminal.accountingContextForTokenOf(_projectId, JBConstants.NATIVE_TOKEN);
|
|
115
|
-
assertEq(_storedContext.token, JBConstants.NATIVE_TOKEN);
|
|
116
|
-
assertEq(_storedContext.decimals, 18);
|
|
117
|
-
assertEq(_storedContext.currency, uint32(uint160(JBConstants.NATIVE_TOKEN)));
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
function test_WhenCallerIsController() external {
|
|
121
|
-
// it will alsoGrantAccess
|
|
122
|
-
|
|
123
|
-
// mock call to JBProjects ownerOf(_projectId)
|
|
124
|
-
bytes memory _projectsCall = abi.encodeCall(IERC721.ownerOf, (_projectId));
|
|
125
|
-
bytes memory _projectsCallReturn = abi.encode(address(0));
|
|
126
|
-
mockExpect(address(projects), _projectsCall, _projectsCallReturn);
|
|
127
|
-
|
|
128
|
-
// mock call to JBDirectory controllerOf(_projectId)
|
|
129
|
-
mockExpect(
|
|
130
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
131
|
-
);
|
|
132
|
-
|
|
133
|
-
// call params
|
|
134
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
135
|
-
_tokens[0] = JBAccountingContext({
|
|
136
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
// Mock recordAccountingContextOf in the store (validation now happens there)
|
|
140
|
-
mockExpect(
|
|
141
|
-
address(store), abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)), ""
|
|
142
|
-
);
|
|
143
|
-
|
|
144
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
145
|
-
|
|
146
|
-
// Mock the store to return the context when queried
|
|
147
|
-
mockExpect(
|
|
148
|
-
address(store),
|
|
149
|
-
abi.encodeCall(
|
|
150
|
-
IJBTerminalStore.accountingContextOf, (address(_terminal), _projectId, JBConstants.NATIVE_TOKEN)
|
|
151
|
-
),
|
|
152
|
-
abi.encode(_tokens[0])
|
|
153
|
-
);
|
|
154
|
-
|
|
155
|
-
JBAccountingContext memory _storedContext =
|
|
156
|
-
_terminal.accountingContextForTokenOf(_projectId, JBConstants.NATIVE_TOKEN);
|
|
157
|
-
assertEq(_storedContext.token, JBConstants.NATIVE_TOKEN);
|
|
158
|
-
assertEq(_storedContext.decimals, 18);
|
|
159
|
-
assertEq(_storedContext.currency, uint32(uint160(JBConstants.NATIVE_TOKEN)));
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
function test_WhenCallerIsControllerAndRulesetDoesntAllow() external {
|
|
163
|
-
// it will revert
|
|
164
|
-
|
|
165
|
-
// mock call to JBProjects ownerOf(_projectId)
|
|
166
|
-
bytes memory _projectsCall = abi.encodeCall(IERC721.ownerOf, (_projectId));
|
|
167
|
-
bytes memory _projectsCallReturn = abi.encode(address(0));
|
|
168
|
-
mockExpect(address(projects), _projectsCall, _projectsCallReturn);
|
|
169
|
-
|
|
170
|
-
// mock call to JBDirectory controllerOf(_projectId)
|
|
171
|
-
mockExpect(
|
|
172
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
173
|
-
);
|
|
174
|
-
|
|
175
|
-
// call params
|
|
176
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
177
|
-
_tokens[0] = JBAccountingContext({
|
|
178
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
// Mock recordAccountingContextOf to revert with AddingAccountingContextNotAllowed (validation now in store)
|
|
182
|
-
vm.mockCallRevert(
|
|
183
|
-
address(store),
|
|
184
|
-
abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)),
|
|
185
|
-
abi.encodeWithSelector(JBTerminalStore.JBTerminalStore_AddingAccountingContextNotAllowed.selector)
|
|
186
|
-
);
|
|
187
|
-
|
|
188
|
-
vm.expectRevert(JBTerminalStore.JBTerminalStore_AddingAccountingContextNotAllowed.selector);
|
|
189
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
function test_WhenCurrencyIsNativeButDecimalsDNEQ18() external {
|
|
193
|
-
// it will revert JBTerminalStore_AccountingContextDecimalsMismatch
|
|
194
|
-
|
|
195
|
-
// mock call to JBProjects ownerOf(_projectId)
|
|
196
|
-
bytes memory _projectsCall = abi.encodeCall(IERC721.ownerOf, (_projectId));
|
|
197
|
-
bytes memory _projectsCallReturn = abi.encode(address(0));
|
|
198
|
-
mockExpect(address(projects), _projectsCall, _projectsCallReturn);
|
|
199
|
-
|
|
200
|
-
// mock call to JBDirectory controllerOf(_projectId)
|
|
201
|
-
mockExpect(
|
|
202
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
203
|
-
);
|
|
204
|
-
|
|
205
|
-
// call params
|
|
206
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
207
|
-
_tokens[0] = JBAccountingContext({
|
|
208
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
209
|
-
decimals: 17, //invalid
|
|
210
|
-
currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
// Mock recordAccountingContextOf to revert with DecimalsMismatch (validation now in store)
|
|
214
|
-
vm.mockCallRevert(
|
|
215
|
-
address(store),
|
|
216
|
-
abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)),
|
|
217
|
-
abi.encodeWithSelector(JBTerminalStore.JBTerminalStore_AccountingContextDecimalsMismatch.selector)
|
|
218
|
-
);
|
|
219
|
-
|
|
220
|
-
vm.expectRevert(JBTerminalStore.JBTerminalStore_AccountingContextDecimalsMismatch.selector);
|
|
221
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
function test_WhenTokenDecimalsDoesNotMatchAccountingContext() external {
|
|
225
|
-
// it will revert JBTerminalStore_AccountingContextDecimalsMismatch
|
|
226
|
-
|
|
227
|
-
// mock call to JBProjects ownerOf(_projectId)
|
|
228
|
-
bytes memory _projectsCall = abi.encodeCall(IERC721.ownerOf, (_projectId));
|
|
229
|
-
bytes memory _projectsCallReturn = abi.encode(address(0));
|
|
230
|
-
mockExpect(address(projects), _projectsCall, _projectsCallReturn);
|
|
231
|
-
|
|
232
|
-
// mock call to JBDirectory controllerOf(_projectId)
|
|
233
|
-
mockExpect(
|
|
234
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
235
|
-
);
|
|
236
|
-
|
|
237
|
-
address someToken = makeAddr("someToken");
|
|
238
|
-
|
|
239
|
-
// call params
|
|
240
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
241
|
-
_tokens[0] = JBAccountingContext({
|
|
242
|
-
token: someToken,
|
|
243
|
-
decimals: 17, // invalid- we will mock a return of 18 decimals
|
|
244
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
245
|
-
currency: uint32(uint160(someToken))
|
|
246
|
-
});
|
|
247
|
-
|
|
248
|
-
// Mock recordAccountingContextOf to revert with DecimalsMismatch (validation now in store)
|
|
249
|
-
vm.mockCallRevert(
|
|
250
|
-
address(store),
|
|
251
|
-
abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)),
|
|
252
|
-
abi.encodeWithSelector(JBTerminalStore.JBTerminalStore_AccountingContextDecimalsMismatch.selector)
|
|
253
|
-
);
|
|
254
|
-
|
|
255
|
-
vm.expectRevert(JBTerminalStore.JBTerminalStore_AccountingContextDecimalsMismatch.selector);
|
|
256
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
function test_WhenCurrencyEQZero() external {
|
|
260
|
-
// it will revert JBTerminalStore_ZeroAccountingContextCurrency
|
|
261
|
-
|
|
262
|
-
// mock call to JBProjects ownerOf(_projectId)
|
|
263
|
-
bytes memory _projectsCall = abi.encodeCall(IERC721.ownerOf, (_projectId));
|
|
264
|
-
bytes memory _projectsCallReturn = abi.encode(address(0));
|
|
265
|
-
mockExpect(address(projects), _projectsCall, _projectsCallReturn);
|
|
266
|
-
|
|
267
|
-
// mock call to JBDirectory controllerOf(_projectId)
|
|
268
|
-
mockExpect(
|
|
269
|
-
address(directory), abi.encodeCall(IJBDirectory.controllerOf, (_projectId)), abi.encode(address(this))
|
|
270
|
-
);
|
|
271
|
-
|
|
272
|
-
address someToken = makeAddr("someToken");
|
|
273
|
-
|
|
274
|
-
// call params
|
|
275
|
-
JBAccountingContext[] memory _tokens = new JBAccountingContext[](1);
|
|
276
|
-
// forge-lint: disable-next-line(unsafe-typecast)
|
|
277
|
-
_tokens[0] = JBAccountingContext({token: someToken, decimals: 18, currency: uint32(uint160(0))});
|
|
278
|
-
|
|
279
|
-
// Mock recordAccountingContextOf to revert with ZeroAccountingContextCurrency (validation now in store)
|
|
280
|
-
vm.mockCallRevert(
|
|
281
|
-
address(store),
|
|
282
|
-
abi.encodeCall(IJBTerminalStore.recordAccountingContextOf, (_projectId, _tokens)),
|
|
283
|
-
abi.encodeWithSelector(JBTerminalStore.JBTerminalStore_ZeroAccountingContextCurrency.selector)
|
|
284
|
-
);
|
|
285
|
-
|
|
286
|
-
vm.expectRevert(JBTerminalStore.JBTerminalStore_ZeroAccountingContextCurrency.selector);
|
|
287
|
-
_terminal.addAccountingContextsFor(_projectId, _tokens);
|
|
288
|
-
}
|
|
289
|
-
}
|