@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,255 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.6;
|
|
3
|
-
|
|
4
|
-
import {TestBaseWorkflow} from "./helpers/TestBaseWorkflow.sol";
|
|
5
|
-
import {JBMultiTerminal} from "../src/JBMultiTerminal.sol";
|
|
6
|
-
import {JBTerminalStore} from "../src/JBTerminalStore.sol";
|
|
7
|
-
import {JBTokens} from "../src/JBTokens.sol";
|
|
8
|
-
import {IJBController} from "../src/interfaces/IJBController.sol";
|
|
9
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
10
|
-
import {IJBTerminal} from "../src/interfaces/IJBTerminal.sol";
|
|
11
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
12
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
13
|
-
import {JBCurrencyAmount} from "../src/structs/JBCurrencyAmount.sol";
|
|
14
|
-
import {JBFee} from "../src/structs/JBFee.sol";
|
|
15
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
16
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
17
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
18
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
19
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
20
|
-
|
|
21
|
-
/// @notice Confirms held fees are stranded when a terminal migrates.
|
|
22
|
-
/// The migration calls addToBalanceOf with shouldReturnHeldFees: false,
|
|
23
|
-
/// leaving held fees in the old terminal with no balance to process them.
|
|
24
|
-
contract TestMigrationHeldFees_Local is TestBaseWorkflow {
|
|
25
|
-
IJBController private _controller;
|
|
26
|
-
JBMultiTerminal private _terminal;
|
|
27
|
-
JBMultiTerminal private _terminal2;
|
|
28
|
-
JBTokens private _tokens;
|
|
29
|
-
JBTerminalStore private _store;
|
|
30
|
-
uint256 private _projectId;
|
|
31
|
-
address private _projectOwner;
|
|
32
|
-
|
|
33
|
-
uint112 private constant WEIGHT = 1000 * 10 ** 18;
|
|
34
|
-
uint112 private constant PAY_AMOUNT = 10 ether;
|
|
35
|
-
|
|
36
|
-
function setUp() public override {
|
|
37
|
-
super.setUp();
|
|
38
|
-
|
|
39
|
-
_projectOwner = multisig();
|
|
40
|
-
_controller = jbController();
|
|
41
|
-
_terminal = jbMultiTerminal();
|
|
42
|
-
_terminal2 = jbMultiTerminal2();
|
|
43
|
-
_tokens = jbTokens();
|
|
44
|
-
_store = jbTerminalStore();
|
|
45
|
-
|
|
46
|
-
// Ruleset with holdFees=true and allowTerminalMigration=true.
|
|
47
|
-
JBRulesetMetadata memory metadata = JBRulesetMetadata({
|
|
48
|
-
reservedPercent: 0,
|
|
49
|
-
cashOutTaxRate: 0,
|
|
50
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
51
|
-
pausePay: false,
|
|
52
|
-
pauseCreditTransfers: false,
|
|
53
|
-
allowOwnerMinting: false,
|
|
54
|
-
allowSetCustomToken: false,
|
|
55
|
-
allowTerminalMigration: true,
|
|
56
|
-
allowSetTerminals: true,
|
|
57
|
-
ownerMustSendPayouts: false,
|
|
58
|
-
allowSetController: false,
|
|
59
|
-
allowAddAccountingContext: true,
|
|
60
|
-
allowAddPriceFeed: false,
|
|
61
|
-
holdFees: true, // Fees are held, not processed immediately.
|
|
62
|
-
useTotalSurplusForCashOuts: false,
|
|
63
|
-
useDataHookForPay: false,
|
|
64
|
-
useDataHookForCashOut: false,
|
|
65
|
-
dataHook: address(0),
|
|
66
|
-
metadata: 0
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
JBRulesetConfig[] memory rulesetConfig = new JBRulesetConfig[](1);
|
|
70
|
-
rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
71
|
-
rulesetConfig[0].duration = 0;
|
|
72
|
-
rulesetConfig[0].weight = WEIGHT;
|
|
73
|
-
rulesetConfig[0].weightCutPercent = 0;
|
|
74
|
-
rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
75
|
-
rulesetConfig[0].metadata = metadata;
|
|
76
|
-
rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
77
|
-
|
|
78
|
-
// Set up payout limit so fees are taken on payouts.
|
|
79
|
-
JBCurrencyAmount[] memory payoutLimits = new JBCurrencyAmount[](1);
|
|
80
|
-
payoutLimits[0] =
|
|
81
|
-
JBCurrencyAmount({amount: uint224(PAY_AMOUNT), currency: uint32(uint160(JBConstants.NATIVE_TOKEN))});
|
|
82
|
-
JBFundAccessLimitGroup[] memory limitGroups = new JBFundAccessLimitGroup[](1);
|
|
83
|
-
limitGroups[0] = JBFundAccessLimitGroup({
|
|
84
|
-
terminal: address(_terminal),
|
|
85
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
86
|
-
payoutLimits: payoutLimits,
|
|
87
|
-
surplusAllowances: new JBCurrencyAmount[](0)
|
|
88
|
-
});
|
|
89
|
-
rulesetConfig[0].fundAccessLimitGroups = limitGroups;
|
|
90
|
-
|
|
91
|
-
// Terminal configs — both terminals accept native token.
|
|
92
|
-
JBAccountingContext[] memory tokensToAccept = new JBAccountingContext[](1);
|
|
93
|
-
tokensToAccept[0] = JBAccountingContext({
|
|
94
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
JBTerminalConfig[] memory terminalConfigs = new JBTerminalConfig[](2);
|
|
98
|
-
terminalConfigs[0] =
|
|
99
|
-
JBTerminalConfig({terminal: IJBTerminal(address(_terminal)), accountingContextsToAccept: tokensToAccept});
|
|
100
|
-
terminalConfigs[1] =
|
|
101
|
-
JBTerminalConfig({terminal: IJBTerminal(address(_terminal2)), accountingContextsToAccept: tokensToAccept});
|
|
102
|
-
|
|
103
|
-
// Fee project (#1).
|
|
104
|
-
JBTerminalConfig[] memory feeTerminalConfigs = new JBTerminalConfig[](1);
|
|
105
|
-
feeTerminalConfigs[0] =
|
|
106
|
-
JBTerminalConfig({terminal: IJBTerminal(address(_terminal)), accountingContextsToAccept: tokensToAccept});
|
|
107
|
-
|
|
108
|
-
JBRulesetConfig[] memory feeRulesetConfig = new JBRulesetConfig[](1);
|
|
109
|
-
feeRulesetConfig[0].mustStartAtOrAfter = 0;
|
|
110
|
-
feeRulesetConfig[0].duration = 0;
|
|
111
|
-
feeRulesetConfig[0].weight = WEIGHT;
|
|
112
|
-
feeRulesetConfig[0].metadata = metadata;
|
|
113
|
-
feeRulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
114
|
-
feeRulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
115
|
-
|
|
116
|
-
_controller.launchProjectFor({
|
|
117
|
-
owner: address(420),
|
|
118
|
-
projectUri: "fee",
|
|
119
|
-
rulesetConfigurations: feeRulesetConfig,
|
|
120
|
-
terminalConfigurations: feeTerminalConfigs,
|
|
121
|
-
memo: ""
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
// Test project (#2).
|
|
125
|
-
_projectId = _controller.launchProjectFor({
|
|
126
|
-
owner: _projectOwner,
|
|
127
|
-
projectUri: "test",
|
|
128
|
-
rulesetConfigurations: rulesetConfig,
|
|
129
|
-
terminalConfigurations: terminalConfigs,
|
|
130
|
-
memo: ""
|
|
131
|
-
});
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
/// @notice Pay → distribute payouts (holds fees) → migrate → fees stranded.
|
|
135
|
-
function test_migration_heldFeesStranded() external {
|
|
136
|
-
// Step 1: Pay the project.
|
|
137
|
-
_terminal.pay{value: PAY_AMOUNT}({
|
|
138
|
-
projectId: _projectId,
|
|
139
|
-
amount: PAY_AMOUNT,
|
|
140
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
141
|
-
beneficiary: _projectOwner,
|
|
142
|
-
minReturnedTokens: 0,
|
|
143
|
-
memo: "",
|
|
144
|
-
metadata: new bytes(0)
|
|
145
|
-
});
|
|
146
|
-
|
|
147
|
-
// Step 2: Distribute payouts — fees will be held (holdFees=true).
|
|
148
|
-
vm.prank(_projectOwner);
|
|
149
|
-
_terminal.sendPayoutsOf({
|
|
150
|
-
projectId: _projectId,
|
|
151
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
152
|
-
amount: PAY_AMOUNT,
|
|
153
|
-
currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
154
|
-
minTokensPaidOut: 0
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
// Verify held fees exist.
|
|
158
|
-
JBFee[] memory heldFees = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
|
|
159
|
-
assertGt(heldFees.length, 0, "Should have held fees after payout");
|
|
160
|
-
|
|
161
|
-
// Step 3: Migrate balance to terminal2.
|
|
162
|
-
vm.prank(_projectOwner);
|
|
163
|
-
_terminal.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, IJBTerminal(address(_terminal2)));
|
|
164
|
-
|
|
165
|
-
// Step 4: Verify old terminal has no balance but still has held fees.
|
|
166
|
-
uint256 balanceAfter = _store.balanceOf(address(_terminal), _projectId, JBConstants.NATIVE_TOKEN);
|
|
167
|
-
assertEq(balanceAfter, 0, "Old terminal should have 0 balance after migration");
|
|
168
|
-
|
|
169
|
-
// Held fees still exist in old terminal.
|
|
170
|
-
JBFee[] memory feesAfterMigration = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
|
|
171
|
-
assertEq(feesAfterMigration.length, heldFees.length, "Held fees remain in old terminal");
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
/// @notice Process held fees FIRST, then migrate — correct approach.
|
|
175
|
-
function test_migration_feeProcessingBeforeMigration() external {
|
|
176
|
-
// Pay.
|
|
177
|
-
_terminal.pay{value: PAY_AMOUNT}({
|
|
178
|
-
projectId: _projectId,
|
|
179
|
-
amount: PAY_AMOUNT,
|
|
180
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
181
|
-
beneficiary: _projectOwner,
|
|
182
|
-
minReturnedTokens: 0,
|
|
183
|
-
memo: "",
|
|
184
|
-
metadata: new bytes(0)
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
// Distribute payouts (holds fees).
|
|
188
|
-
vm.prank(_projectOwner);
|
|
189
|
-
_terminal.sendPayoutsOf({
|
|
190
|
-
projectId: _projectId,
|
|
191
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
192
|
-
amount: PAY_AMOUNT,
|
|
193
|
-
currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
194
|
-
minTokensPaidOut: 0
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
// Fast-forward past fee holding period (28 days).
|
|
198
|
-
vm.warp(block.timestamp + 28 days + 1);
|
|
199
|
-
|
|
200
|
-
// Process held fees before migration.
|
|
201
|
-
uint256 feeProjectBalanceBefore = _store.balanceOf(address(_terminal), 1, JBConstants.NATIVE_TOKEN);
|
|
202
|
-
_terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
|
|
203
|
-
uint256 feeProjectBalanceAfter = _store.balanceOf(address(_terminal), 1, JBConstants.NATIVE_TOKEN);
|
|
204
|
-
|
|
205
|
-
// Fee project should have received fees.
|
|
206
|
-
assertGt(feeProjectBalanceAfter, feeProjectBalanceBefore, "Fee project should receive fees");
|
|
207
|
-
|
|
208
|
-
// Now held fees should be cleared.
|
|
209
|
-
JBFee[] memory feesAfter = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
|
|
210
|
-
assertEq(feesAfter.length, 0, "Held fees should be cleared after processing");
|
|
211
|
-
|
|
212
|
-
// Now migrate safely.
|
|
213
|
-
vm.prank(_projectOwner);
|
|
214
|
-
_terminal.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, IJBTerminal(address(_terminal2)));
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
/// @notice After migration, processHeldFeesOf on old terminal processes nothing (no balance).
|
|
218
|
-
function test_migration_heldFeesUnclaimable() external {
|
|
219
|
-
// Pay and distribute.
|
|
220
|
-
_terminal.pay{value: PAY_AMOUNT}({
|
|
221
|
-
projectId: _projectId,
|
|
222
|
-
amount: PAY_AMOUNT,
|
|
223
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
224
|
-
beneficiary: _projectOwner,
|
|
225
|
-
minReturnedTokens: 0,
|
|
226
|
-
memo: "",
|
|
227
|
-
metadata: new bytes(0)
|
|
228
|
-
});
|
|
229
|
-
|
|
230
|
-
vm.prank(_projectOwner);
|
|
231
|
-
_terminal.sendPayoutsOf({
|
|
232
|
-
projectId: _projectId,
|
|
233
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
234
|
-
amount: PAY_AMOUNT,
|
|
235
|
-
currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
236
|
-
minTokensPaidOut: 0
|
|
237
|
-
});
|
|
238
|
-
|
|
239
|
-
// Migrate.
|
|
240
|
-
vm.prank(_projectOwner);
|
|
241
|
-
_terminal.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, IJBTerminal(address(_terminal2)));
|
|
242
|
-
|
|
243
|
-
// Warp past holding period.
|
|
244
|
-
vm.warp(block.timestamp + 28 days + 1);
|
|
245
|
-
|
|
246
|
-
// Try to process held fees — the fees still exist but the old terminal has no ETH.
|
|
247
|
-
// The _processFee try-catch will catch the revert and credit the fee amount back to the project.
|
|
248
|
-
_terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
|
|
249
|
-
|
|
250
|
-
// The fee processing attempted but the terminal has no actual ETH.
|
|
251
|
-
// The _recordAddedBalanceFor in the catch block inflates the store balance
|
|
252
|
-
// without actual funds — this is a phantom balance.
|
|
253
|
-
// This documents the issue: either fees are lost OR phantom balances are created.
|
|
254
|
-
}
|
|
255
|
-
}
|
|
@@ -1,185 +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 {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
7
|
-
import {IJBRulesetDataHook} from "../src/interfaces/IJBRulesetDataHook.sol";
|
|
8
|
-
import {IJBTerminal} from "../src/interfaces/IJBTerminal.sol";
|
|
9
|
-
import {IJBTokens} from "../src/interfaces/IJBTokens.sol";
|
|
10
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
11
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
12
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
13
|
-
import {JBRuleset} from "../src/structs/JBRuleset.sol";
|
|
14
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
15
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
16
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
17
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
18
|
-
|
|
19
|
-
contract TestMintTokensOf_Local is TestBaseWorkflow {
|
|
20
|
-
uint8 private constant _WEIGHT_DECIMALS = 18;
|
|
21
|
-
uint112 private constant _WEIGHT = uint112(1000 * 10 ** _WEIGHT_DECIMALS);
|
|
22
|
-
address private constant _DATA_HOOK = address(bytes20(keccak256("datahook")));
|
|
23
|
-
|
|
24
|
-
IJBController private _controller;
|
|
25
|
-
IJBTerminal private _terminal;
|
|
26
|
-
IJBTokens private _tokens;
|
|
27
|
-
address private _projectOwner;
|
|
28
|
-
|
|
29
|
-
uint256 _projectId;
|
|
30
|
-
|
|
31
|
-
function setUp() public override {
|
|
32
|
-
super.setUp();
|
|
33
|
-
|
|
34
|
-
_controller = jbController();
|
|
35
|
-
_projectOwner = multisig();
|
|
36
|
-
_terminal = jbMultiTerminal();
|
|
37
|
-
_tokens = jbTokens();
|
|
38
|
-
|
|
39
|
-
JBRulesetMetadata memory _metadata = JBRulesetMetadata({
|
|
40
|
-
reservedPercent: 0,
|
|
41
|
-
cashOutTaxRate: 0,
|
|
42
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
43
|
-
pausePay: false,
|
|
44
|
-
pauseCreditTransfers: false,
|
|
45
|
-
allowOwnerMinting: true,
|
|
46
|
-
allowSetCustomToken: true,
|
|
47
|
-
allowTerminalMigration: false,
|
|
48
|
-
allowSetTerminals: false,
|
|
49
|
-
ownerMustSendPayouts: false,
|
|
50
|
-
allowSetController: false,
|
|
51
|
-
allowAddAccountingContext: true,
|
|
52
|
-
allowAddPriceFeed: false,
|
|
53
|
-
holdFees: false,
|
|
54
|
-
useTotalSurplusForCashOuts: false,
|
|
55
|
-
useDataHookForPay: true,
|
|
56
|
-
useDataHookForCashOut: true,
|
|
57
|
-
dataHook: _DATA_HOOK,
|
|
58
|
-
metadata: 0
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
// Package up ruleset configuration.
|
|
62
|
-
JBRulesetConfig[] memory _rulesetConfig = new JBRulesetConfig[](1);
|
|
63
|
-
_rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
64
|
-
_rulesetConfig[0].duration = 0;
|
|
65
|
-
_rulesetConfig[0].weight = _WEIGHT;
|
|
66
|
-
_rulesetConfig[0].weightCutPercent = 0;
|
|
67
|
-
_rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
68
|
-
_rulesetConfig[0].metadata = _metadata;
|
|
69
|
-
_rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
70
|
-
_rulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
71
|
-
|
|
72
|
-
JBTerminalConfig[] memory _terminalConfigurations = new JBTerminalConfig[](1);
|
|
73
|
-
JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
|
|
74
|
-
_tokensToAccept[0] = JBAccountingContext({
|
|
75
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
76
|
-
});
|
|
77
|
-
_terminalConfigurations[0] =
|
|
78
|
-
JBTerminalConfig({terminal: _terminal, accountingContextsToAccept: _tokensToAccept});
|
|
79
|
-
|
|
80
|
-
_projectId = _controller.launchProjectFor({
|
|
81
|
-
owner: _projectOwner,
|
|
82
|
-
projectUri: "myIPFSHash",
|
|
83
|
-
rulesetConfigurations: _rulesetConfig,
|
|
84
|
-
terminalConfigurations: _terminalConfigurations,
|
|
85
|
-
memo: ""
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
function test_GivenNoRulesetIsActive() external {
|
|
90
|
-
// deploy a second project without ruleset
|
|
91
|
-
JBRulesetMetadata memory _metadata = JBRulesetMetadata({
|
|
92
|
-
reservedPercent: 0,
|
|
93
|
-
cashOutTaxRate: 0,
|
|
94
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
95
|
-
pausePay: false,
|
|
96
|
-
pauseCreditTransfers: false,
|
|
97
|
-
allowOwnerMinting: true,
|
|
98
|
-
allowSetCustomToken: true,
|
|
99
|
-
allowTerminalMigration: false,
|
|
100
|
-
allowSetTerminals: false,
|
|
101
|
-
ownerMustSendPayouts: false,
|
|
102
|
-
allowSetController: false,
|
|
103
|
-
allowAddAccountingContext: true,
|
|
104
|
-
allowAddPriceFeed: false,
|
|
105
|
-
holdFees: false,
|
|
106
|
-
useTotalSurplusForCashOuts: false,
|
|
107
|
-
useDataHookForPay: true,
|
|
108
|
-
useDataHookForCashOut: true,
|
|
109
|
-
dataHook: _DATA_HOOK,
|
|
110
|
-
metadata: 0
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
// Package up ruleset configuration that starts in the future.
|
|
114
|
-
JBRulesetConfig[] memory _rulesetConfig = new JBRulesetConfig[](1);
|
|
115
|
-
_rulesetConfig[0].mustStartAtOrAfter = uint48(block.timestamp + 100);
|
|
116
|
-
_rulesetConfig[0].duration = 0;
|
|
117
|
-
_rulesetConfig[0].weight = _WEIGHT;
|
|
118
|
-
_rulesetConfig[0].weightCutPercent = 0;
|
|
119
|
-
_rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
120
|
-
_rulesetConfig[0].metadata = _metadata;
|
|
121
|
-
_rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
122
|
-
_rulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
123
|
-
|
|
124
|
-
JBTerminalConfig[] memory _terminalConfigurations = new JBTerminalConfig[](1);
|
|
125
|
-
|
|
126
|
-
JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
|
|
127
|
-
_tokensToAccept[0] = JBAccountingContext({
|
|
128
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
129
|
-
});
|
|
130
|
-
_terminalConfigurations[0] =
|
|
131
|
-
JBTerminalConfig({terminal: _terminal, accountingContextsToAccept: _tokensToAccept});
|
|
132
|
-
|
|
133
|
-
_projectId = _controller.launchProjectFor({
|
|
134
|
-
owner: _projectOwner,
|
|
135
|
-
projectUri: "myIPFSHash",
|
|
136
|
-
rulesetConfigurations: _rulesetConfig,
|
|
137
|
-
terminalConfigurations: _terminalConfigurations,
|
|
138
|
-
memo: ""
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
// owner should be able to mint
|
|
142
|
-
vm.prank(_projectOwner);
|
|
143
|
-
|
|
144
|
-
// send: mint some tokens
|
|
145
|
-
_controller.mintTokensOf(2, 1, address(this), "", false);
|
|
146
|
-
|
|
147
|
-
// check: tokens were minted
|
|
148
|
-
uint256 balance = _tokens.totalBalanceOf(address(this), 2);
|
|
149
|
-
assertEq(balance, 1);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
function test_GivenThatADataSourceIsConfigured() external {
|
|
153
|
-
// it should be able to mint
|
|
154
|
-
vm.prank(address(_DATA_HOOK));
|
|
155
|
-
|
|
156
|
-
// send: mint some tokens
|
|
157
|
-
_controller.mintTokensOf(1, 1, address(this), "", false);
|
|
158
|
-
|
|
159
|
-
// check: tokens were minted
|
|
160
|
-
uint256 balance = _tokens.totalBalanceOf(address(this), 1);
|
|
161
|
-
assertEq(balance, 1);
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
function test_GivenThatADataSourceHasPermissionedAnotherContractToMint() external {
|
|
165
|
-
// it should be able to mint
|
|
166
|
-
|
|
167
|
-
// Get the current ruleset.
|
|
168
|
-
JBRuleset memory _ruleset = jbRulesets().currentOf(1);
|
|
169
|
-
|
|
170
|
-
// setup: mock the datasource mint permission, allowing this contract to mint
|
|
171
|
-
bytes memory _encodedCall =
|
|
172
|
-
abi.encodeCall(IJBRulesetDataHook.hasMintPermissionFor, (1, _ruleset, address(this)));
|
|
173
|
-
bytes memory _willReturn = abi.encode(true);
|
|
174
|
-
|
|
175
|
-
vm.mockCall(address(_DATA_HOOK), _encodedCall, _willReturn);
|
|
176
|
-
vm.expectCall(address(_DATA_HOOK), _encodedCall);
|
|
177
|
-
|
|
178
|
-
// send: mint some tokens
|
|
179
|
-
_controller.mintTokensOf(1, 1, address(this), "", false);
|
|
180
|
-
|
|
181
|
-
// check: tokens were minted
|
|
182
|
-
uint256 balance = _tokens.totalBalanceOf(address(this), 1);
|
|
183
|
-
assertEq(balance, 1);
|
|
184
|
-
}
|
|
185
|
-
}
|