@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,274 +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 {IJBController} from "../src/interfaces/IJBController.sol";
|
|
7
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
8
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
9
|
-
import {JBFees} from "../src/libraries/JBFees.sol";
|
|
10
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
11
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
12
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
13
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
14
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
15
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
16
|
-
|
|
17
|
-
/// @notice E2E test: Pay into terminal A -> migrate to terminal B -> verify balances, surplus, cash outs.
|
|
18
|
-
contract TestTerminalMigration_Local is TestBaseWorkflow {
|
|
19
|
-
IJBController private _controller;
|
|
20
|
-
JBMultiTerminal private _terminalA;
|
|
21
|
-
JBMultiTerminal private _terminalB;
|
|
22
|
-
uint256 private _projectId;
|
|
23
|
-
address private _projectOwner;
|
|
24
|
-
address private _beneficiary;
|
|
25
|
-
|
|
26
|
-
function setUp() public override {
|
|
27
|
-
super.setUp();
|
|
28
|
-
|
|
29
|
-
_projectOwner = multisig();
|
|
30
|
-
_beneficiary = beneficiary();
|
|
31
|
-
_controller = jbController();
|
|
32
|
-
_terminalA = jbMultiTerminal();
|
|
33
|
-
_terminalB = jbMultiTerminal2();
|
|
34
|
-
|
|
35
|
-
JBRulesetMetadata memory _metadata = JBRulesetMetadata({
|
|
36
|
-
reservedPercent: 0,
|
|
37
|
-
cashOutTaxRate: 0,
|
|
38
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
39
|
-
pausePay: false,
|
|
40
|
-
pauseCreditTransfers: false,
|
|
41
|
-
allowOwnerMinting: false,
|
|
42
|
-
allowSetCustomToken: false,
|
|
43
|
-
allowTerminalMigration: true, // KEY: Enable migration
|
|
44
|
-
allowSetTerminals: true,
|
|
45
|
-
allowSetController: false,
|
|
46
|
-
allowAddAccountingContext: false,
|
|
47
|
-
allowAddPriceFeed: false,
|
|
48
|
-
ownerMustSendPayouts: false,
|
|
49
|
-
holdFees: false,
|
|
50
|
-
useTotalSurplusForCashOuts: false,
|
|
51
|
-
useDataHookForPay: false,
|
|
52
|
-
useDataHookForCashOut: false,
|
|
53
|
-
dataHook: address(0),
|
|
54
|
-
metadata: 0
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
JBRulesetConfig[] memory _rulesetConfig = new JBRulesetConfig[](1);
|
|
58
|
-
_rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
59
|
-
_rulesetConfig[0].duration = 0;
|
|
60
|
-
_rulesetConfig[0].weight = 1000 * 10 ** 18;
|
|
61
|
-
_rulesetConfig[0].weightCutPercent = 0;
|
|
62
|
-
_rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
63
|
-
_rulesetConfig[0].metadata = _metadata;
|
|
64
|
-
_rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
65
|
-
_rulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
66
|
-
|
|
67
|
-
// Launch with terminal A
|
|
68
|
-
JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
|
|
69
|
-
_tokensToAccept[0] = JBAccountingContext({
|
|
70
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
JBTerminalConfig[] memory _terminalConfigs = new JBTerminalConfig[](2);
|
|
74
|
-
_terminalConfigs[0] = JBTerminalConfig({terminal: _terminalA, accountingContextsToAccept: _tokensToAccept});
|
|
75
|
-
_terminalConfigs[1] = JBTerminalConfig({terminal: _terminalB, accountingContextsToAccept: _tokensToAccept});
|
|
76
|
-
|
|
77
|
-
_projectId = _controller.launchProjectFor({
|
|
78
|
-
owner: address(_projectOwner),
|
|
79
|
-
projectUri: "migration-test",
|
|
80
|
-
rulesetConfigurations: _rulesetConfig,
|
|
81
|
-
terminalConfigurations: _terminalConfigs,
|
|
82
|
-
memo: ""
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
/// @notice Full migration E2E: pay A -> migrate to B -> verify balances -> cash out from B.
|
|
87
|
-
function test_migrationE2E() public {
|
|
88
|
-
uint256 payAmount = 10 ether;
|
|
89
|
-
|
|
90
|
-
// Step 1: Pay into terminal A
|
|
91
|
-
vm.deal(_beneficiary, payAmount);
|
|
92
|
-
vm.prank(_beneficiary);
|
|
93
|
-
uint256 tokensReceived =
|
|
94
|
-
_terminalA.pay{value: payAmount}(_projectId, JBConstants.NATIVE_TOKEN, payAmount, _beneficiary, 0, "", "");
|
|
95
|
-
assertGt(tokensReceived, 0, "should receive tokens");
|
|
96
|
-
|
|
97
|
-
// Step 2: Verify terminal A has the balance
|
|
98
|
-
uint256 balanceA = jbTerminalStore().balanceOf(address(_terminalA), _projectId, JBConstants.NATIVE_TOKEN);
|
|
99
|
-
assertEq(balanceA, payAmount, "terminal A should have full balance");
|
|
100
|
-
|
|
101
|
-
uint256 balanceB = jbTerminalStore().balanceOf(address(_terminalB), _projectId, JBConstants.NATIVE_TOKEN);
|
|
102
|
-
assertEq(balanceB, 0, "terminal B should have zero balance");
|
|
103
|
-
|
|
104
|
-
// Step 3: Migrate from A to B
|
|
105
|
-
vm.prank(_projectOwner);
|
|
106
|
-
uint256 migratedBalance = _terminalA.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, _terminalB);
|
|
107
|
-
assertEq(migratedBalance, payAmount, "full balance should be migrated");
|
|
108
|
-
|
|
109
|
-
// Step 4: Verify balances after migration (fee project is exempt from migration fee)
|
|
110
|
-
uint256 balanceAAfter = jbTerminalStore().balanceOf(address(_terminalA), _projectId, JBConstants.NATIVE_TOKEN);
|
|
111
|
-
assertEq(balanceAAfter, 0, "terminal A should have zero after migration");
|
|
112
|
-
|
|
113
|
-
uint256 balanceBAfter = jbTerminalStore().balanceOf(address(_terminalB), _projectId, JBConstants.NATIVE_TOKEN);
|
|
114
|
-
assertEq(balanceBAfter, payAmount, "terminal B should have full balance");
|
|
115
|
-
|
|
116
|
-
// Step 5: Terminal B's ETH balance should match
|
|
117
|
-
assertEq(address(_terminalB).balance, payAmount, "terminal B ETH balance should match");
|
|
118
|
-
|
|
119
|
-
// Step 6: Cash out from terminal B (0% tax means full reclaim)
|
|
120
|
-
uint256 beneficiaryBalanceBefore = _beneficiary.balance;
|
|
121
|
-
vm.prank(_beneficiary);
|
|
122
|
-
uint256 reclaimedAmount = _terminalB.cashOutTokensOf({
|
|
123
|
-
holder: _beneficiary,
|
|
124
|
-
projectId: _projectId,
|
|
125
|
-
cashOutCount: tokensReceived,
|
|
126
|
-
tokenToReclaim: JBConstants.NATIVE_TOKEN,
|
|
127
|
-
minTokensReclaimed: 0,
|
|
128
|
-
beneficiary: payable(_beneficiary),
|
|
129
|
-
metadata: ""
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
assertGt(reclaimedAmount, 0, "should reclaim tokens");
|
|
133
|
-
assertEq(
|
|
134
|
-
_beneficiary.balance, beneficiaryBalanceBefore + reclaimedAmount, "beneficiary should receive reclaimed ETH"
|
|
135
|
-
);
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
/// @notice Migration preserves surplus calculations.
|
|
139
|
-
function test_migration_preservesSurplus() public {
|
|
140
|
-
uint256 payAmount = 5 ether;
|
|
141
|
-
|
|
142
|
-
// Pay into terminal A
|
|
143
|
-
vm.deal(_beneficiary, payAmount);
|
|
144
|
-
vm.prank(_beneficiary);
|
|
145
|
-
_terminalA.pay{value: payAmount}(_projectId, JBConstants.NATIVE_TOKEN, payAmount, _beneficiary, 0, "", "");
|
|
146
|
-
|
|
147
|
-
// Record surplus before migration
|
|
148
|
-
uint256 surplusBefore =
|
|
149
|
-
_terminalA.currentSurplusOf(_projectId, new address[](0), 18, uint32(uint160(JBConstants.NATIVE_TOKEN)));
|
|
150
|
-
assertGt(surplusBefore, 0, "should have surplus before migration");
|
|
151
|
-
|
|
152
|
-
// Migrate
|
|
153
|
-
vm.prank(_projectOwner);
|
|
154
|
-
_terminalA.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, _terminalB);
|
|
155
|
-
|
|
156
|
-
// Check surplus from terminal B (fee project exempt from migration fee)
|
|
157
|
-
uint256 surplusAfter =
|
|
158
|
-
_terminalB.currentSurplusOf(_projectId, new address[](0), 18, uint32(uint160(JBConstants.NATIVE_TOKEN)));
|
|
159
|
-
assertEq(surplusAfter, surplusBefore, "surplus should be preserved after migration");
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
/// @notice Migration without permission reverts.
|
|
163
|
-
function test_migration_unauthorizedReverts() public {
|
|
164
|
-
vm.deal(_beneficiary, 1 ether);
|
|
165
|
-
vm.prank(_beneficiary);
|
|
166
|
-
_terminalA.pay{value: 1 ether}(_projectId, JBConstants.NATIVE_TOKEN, 1 ether, _beneficiary, 0, "", "");
|
|
167
|
-
|
|
168
|
-
// Try to migrate as non-owner
|
|
169
|
-
vm.prank(_beneficiary);
|
|
170
|
-
vm.expectRevert();
|
|
171
|
-
_terminalA.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, _terminalB);
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
/// @notice Non-fee project migration charges the 2.5% fee; fee project balance increases.
|
|
175
|
-
function test_migration_nonFeeProject_chargesFee() public {
|
|
176
|
-
// Launch a second project (project 2) — this is NOT the fee project.
|
|
177
|
-
JBRulesetMetadata memory _metadata2 = JBRulesetMetadata({
|
|
178
|
-
reservedPercent: 0,
|
|
179
|
-
cashOutTaxRate: 0,
|
|
180
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
181
|
-
pausePay: false,
|
|
182
|
-
pauseCreditTransfers: false,
|
|
183
|
-
allowOwnerMinting: false,
|
|
184
|
-
allowSetCustomToken: false,
|
|
185
|
-
allowTerminalMigration: true,
|
|
186
|
-
allowSetTerminals: true,
|
|
187
|
-
allowSetController: false,
|
|
188
|
-
allowAddAccountingContext: false,
|
|
189
|
-
allowAddPriceFeed: false,
|
|
190
|
-
ownerMustSendPayouts: false,
|
|
191
|
-
holdFees: false,
|
|
192
|
-
useTotalSurplusForCashOuts: false,
|
|
193
|
-
useDataHookForPay: false,
|
|
194
|
-
useDataHookForCashOut: false,
|
|
195
|
-
dataHook: address(0),
|
|
196
|
-
metadata: 0
|
|
197
|
-
});
|
|
198
|
-
|
|
199
|
-
JBRulesetConfig[] memory _rulesetConfig2 = new JBRulesetConfig[](1);
|
|
200
|
-
_rulesetConfig2[0].mustStartAtOrAfter = 0;
|
|
201
|
-
_rulesetConfig2[0].duration = 0;
|
|
202
|
-
_rulesetConfig2[0].weight = 1000 * 10 ** 18;
|
|
203
|
-
_rulesetConfig2[0].weightCutPercent = 0;
|
|
204
|
-
_rulesetConfig2[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
205
|
-
_rulesetConfig2[0].metadata = _metadata2;
|
|
206
|
-
_rulesetConfig2[0].splitGroups = new JBSplitGroup[](0);
|
|
207
|
-
_rulesetConfig2[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
208
|
-
|
|
209
|
-
JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
|
|
210
|
-
_tokensToAccept[0] = JBAccountingContext({
|
|
211
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
JBTerminalConfig[] memory _terminalConfigs2 = new JBTerminalConfig[](2);
|
|
215
|
-
_terminalConfigs2[0] = JBTerminalConfig({terminal: _terminalA, accountingContextsToAccept: _tokensToAccept});
|
|
216
|
-
_terminalConfigs2[1] = JBTerminalConfig({terminal: _terminalB, accountingContextsToAccept: _tokensToAccept});
|
|
217
|
-
|
|
218
|
-
uint256 project2 = _controller.launchProjectFor({
|
|
219
|
-
owner: _projectOwner,
|
|
220
|
-
projectUri: "non-fee-project",
|
|
221
|
-
rulesetConfigurations: _rulesetConfig2,
|
|
222
|
-
terminalConfigurations: _terminalConfigs2,
|
|
223
|
-
memo: ""
|
|
224
|
-
});
|
|
225
|
-
|
|
226
|
-
// Confirm project 2 is NOT the fee project.
|
|
227
|
-
assertGt(project2, 1, "project2 should not be the fee project");
|
|
228
|
-
|
|
229
|
-
uint256 payAmount = 10 ether;
|
|
230
|
-
|
|
231
|
-
// Pay into terminal A for project 2.
|
|
232
|
-
vm.deal(_beneficiary, payAmount);
|
|
233
|
-
vm.prank(_beneficiary);
|
|
234
|
-
_terminalA.pay{value: payAmount}(project2, JBConstants.NATIVE_TOKEN, payAmount, _beneficiary, 0, "", "");
|
|
235
|
-
|
|
236
|
-
// Snapshot fee project balance before migration.
|
|
237
|
-
uint256 feeBalanceBefore = jbTerminalStore().balanceOf(address(_terminalA), 1, JBConstants.NATIVE_TOKEN);
|
|
238
|
-
|
|
239
|
-
// Migrate project 2 from terminal A to terminal B.
|
|
240
|
-
vm.prank(_projectOwner);
|
|
241
|
-
_terminalA.migrateBalanceOf(project2, JBConstants.NATIVE_TOKEN, _terminalB);
|
|
242
|
-
|
|
243
|
-
// Fee project balance should have increased (fee was charged).
|
|
244
|
-
uint256 feeBalanceAfter = jbTerminalStore().balanceOf(address(_terminalA), 1, JBConstants.NATIVE_TOKEN);
|
|
245
|
-
assertGt(feeBalanceAfter, feeBalanceBefore, "fee project should receive migration fee");
|
|
246
|
-
|
|
247
|
-
// Terminal B should have received payAmount minus the 2.5% fee.
|
|
248
|
-
uint256 expectedFee = JBFees.feeAmountFrom({amountBeforeFee: payAmount, feePercent: 25});
|
|
249
|
-
uint256 balanceBAfter = jbTerminalStore().balanceOf(address(_terminalB), project2, JBConstants.NATIVE_TOKEN);
|
|
250
|
-
assertEq(balanceBAfter, payAmount - expectedFee, "terminal B balance should reflect fee deduction");
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
/// @notice Fee project (project 1) migration is exempt from fees.
|
|
254
|
-
function test_migration_feeProject_noFeeCharged() public {
|
|
255
|
-
// _projectId is project 1, which IS the fee project.
|
|
256
|
-
assertEq(_projectId, 1, "project under test should be the fee project");
|
|
257
|
-
|
|
258
|
-
uint256 payAmount = 10 ether;
|
|
259
|
-
|
|
260
|
-
// Pay into terminal A for the fee project.
|
|
261
|
-
vm.deal(_beneficiary, payAmount);
|
|
262
|
-
vm.prank(_beneficiary);
|
|
263
|
-
_terminalA.pay{value: payAmount}(_projectId, JBConstants.NATIVE_TOKEN, payAmount, _beneficiary, 0, "", "");
|
|
264
|
-
|
|
265
|
-
// Migrate fee project from terminal A to terminal B.
|
|
266
|
-
vm.prank(_projectOwner);
|
|
267
|
-
uint256 migratedBalance = _terminalA.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, _terminalB);
|
|
268
|
-
assertEq(migratedBalance, payAmount, "full balance should be migrated without fee");
|
|
269
|
-
|
|
270
|
-
// Terminal B should have the full amount (no fee deducted).
|
|
271
|
-
uint256 balanceBAfter = jbTerminalStore().balanceOf(address(_terminalB), _projectId, JBConstants.NATIVE_TOKEN);
|
|
272
|
-
assertEq(balanceBAfter, payAmount, "fee project should not be charged migration fee");
|
|
273
|
-
}
|
|
274
|
-
}
|
|
@@ -1,208 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity 0.8.28;
|
|
3
|
-
|
|
4
|
-
import {TestBaseWorkflow} from "./helpers/TestBaseWorkflow.sol";
|
|
5
|
-
import {IJBController} from "../src/interfaces/IJBController.sol";
|
|
6
|
-
import {IJBMultiTerminal} from "../src/interfaces/IJBMultiTerminal.sol";
|
|
7
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
8
|
-
import {IJBTerminal} from "../src/interfaces/IJBTerminal.sol";
|
|
9
|
-
import {IJBCashOutTerminal} from "../src/interfaces/IJBCashOutTerminal.sol";
|
|
10
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
11
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
12
|
-
import {JBCashOutHookSpecification} from "../src/structs/JBCashOutHookSpecification.sol";
|
|
13
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
14
|
-
import {JBPayHookSpecification} from "../src/structs/JBPayHookSpecification.sol";
|
|
15
|
-
import {JBRuleset} from "../src/structs/JBRuleset.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
|
-
contract TestTerminalPreviewParity_Local is TestBaseWorkflow {
|
|
22
|
-
IJBController internal _controller;
|
|
23
|
-
IJBMultiTerminal internal _terminal;
|
|
24
|
-
address internal _projectOwner;
|
|
25
|
-
address internal _beneficiary;
|
|
26
|
-
|
|
27
|
-
function setUp() public virtual override {
|
|
28
|
-
super.setUp();
|
|
29
|
-
|
|
30
|
-
_controller = jbController();
|
|
31
|
-
_terminal = jbMultiTerminal();
|
|
32
|
-
_projectOwner = multisig();
|
|
33
|
-
_beneficiary = beneficiary();
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function _launchProject(uint16 reservedPercent, uint16 cashOutTaxRate) internal returns (uint256 projectId) {
|
|
37
|
-
JBRulesetConfig[] memory rulesetConfigurations = new JBRulesetConfig[](1);
|
|
38
|
-
rulesetConfigurations[0].mustStartAtOrAfter = 0;
|
|
39
|
-
rulesetConfigurations[0].duration = 0;
|
|
40
|
-
rulesetConfigurations[0].weight = 1000 * 10 ** 18;
|
|
41
|
-
rulesetConfigurations[0].weightCutPercent = 0;
|
|
42
|
-
rulesetConfigurations[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
43
|
-
rulesetConfigurations[0].metadata = JBRulesetMetadata({
|
|
44
|
-
reservedPercent: reservedPercent,
|
|
45
|
-
cashOutTaxRate: cashOutTaxRate,
|
|
46
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
47
|
-
pausePay: false,
|
|
48
|
-
pauseCreditTransfers: false,
|
|
49
|
-
allowOwnerMinting: false,
|
|
50
|
-
allowSetCustomToken: false,
|
|
51
|
-
allowTerminalMigration: false,
|
|
52
|
-
allowSetTerminals: false,
|
|
53
|
-
ownerMustSendPayouts: false,
|
|
54
|
-
allowSetController: false,
|
|
55
|
-
allowAddAccountingContext: true,
|
|
56
|
-
allowAddPriceFeed: false,
|
|
57
|
-
holdFees: false,
|
|
58
|
-
useTotalSurplusForCashOuts: false,
|
|
59
|
-
useDataHookForPay: false,
|
|
60
|
-
useDataHookForCashOut: false,
|
|
61
|
-
dataHook: address(0),
|
|
62
|
-
metadata: 0
|
|
63
|
-
});
|
|
64
|
-
rulesetConfigurations[0].splitGroups = new JBSplitGroup[](0);
|
|
65
|
-
rulesetConfigurations[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
66
|
-
|
|
67
|
-
JBAccountingContext[] memory contexts = new JBAccountingContext[](1);
|
|
68
|
-
contexts[0] = JBAccountingContext({
|
|
69
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
JBTerminalConfig[] memory terminalConfigurations = new JBTerminalConfig[](1);
|
|
73
|
-
terminalConfigurations[0] = JBTerminalConfig({terminal: _terminal, accountingContextsToAccept: contexts});
|
|
74
|
-
|
|
75
|
-
return _controller.launchProjectFor({
|
|
76
|
-
owner: _projectOwner,
|
|
77
|
-
projectUri: "ipfs://preview-parity",
|
|
78
|
-
rulesetConfigurations: rulesetConfigurations,
|
|
79
|
-
terminalConfigurations: terminalConfigurations,
|
|
80
|
-
memo: ""
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
function _launchFeeProject() internal {
|
|
85
|
-
_launchProject(0, JBConstants.MAX_CASH_OUT_TAX_RATE);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
function testFuzzPreviewPayForMatchesPay(uint96 amount, uint16 reservedPercent) external {
|
|
89
|
-
amount = uint96(bound(amount, 1, 100 ether));
|
|
90
|
-
reservedPercent = uint16(bound(reservedPercent, 0, JBConstants.MAX_RESERVED_PERCENT));
|
|
91
|
-
|
|
92
|
-
_launchFeeProject();
|
|
93
|
-
uint256 projectId = _launchProject(reservedPercent, JBConstants.MAX_CASH_OUT_TAX_RATE);
|
|
94
|
-
|
|
95
|
-
(
|
|
96
|
-
JBRuleset memory ruleset,
|
|
97
|
-
uint256 previewBeneficiaryTokenCount,
|
|
98
|
-
uint256 previewReservedTokenCount,
|
|
99
|
-
JBPayHookSpecification[] memory hookSpecifications
|
|
100
|
-
) = _terminal.previewPayFor(projectId, JBConstants.NATIVE_TOKEN, amount, _beneficiary, "");
|
|
101
|
-
|
|
102
|
-
assertEq(hookSpecifications.length, 0);
|
|
103
|
-
|
|
104
|
-
uint256 balanceBefore = jbTokens().totalBalanceOf(_beneficiary, projectId);
|
|
105
|
-
uint256 reservedBefore = _controller.pendingReservedTokenBalanceOf(projectId);
|
|
106
|
-
|
|
107
|
-
address payer = makeAddr("payer");
|
|
108
|
-
vm.deal(payer, amount);
|
|
109
|
-
|
|
110
|
-
vm.expectEmit();
|
|
111
|
-
emit IJBTerminal.Pay(
|
|
112
|
-
ruleset.id,
|
|
113
|
-
ruleset.cycleNumber,
|
|
114
|
-
projectId,
|
|
115
|
-
payer,
|
|
116
|
-
_beneficiary,
|
|
117
|
-
amount,
|
|
118
|
-
previewBeneficiaryTokenCount,
|
|
119
|
-
"",
|
|
120
|
-
"",
|
|
121
|
-
payer
|
|
122
|
-
);
|
|
123
|
-
|
|
124
|
-
vm.prank(payer);
|
|
125
|
-
uint256 beneficiaryTokenCount = _terminal.pay{value: amount}({
|
|
126
|
-
projectId: projectId,
|
|
127
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
128
|
-
amount: amount,
|
|
129
|
-
beneficiary: _beneficiary,
|
|
130
|
-
minReturnedTokens: 0,
|
|
131
|
-
memo: "",
|
|
132
|
-
metadata: ""
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
assertEq(beneficiaryTokenCount, previewBeneficiaryTokenCount);
|
|
136
|
-
assertEq(jbTokens().totalBalanceOf(_beneficiary, projectId) - balanceBefore, previewBeneficiaryTokenCount);
|
|
137
|
-
assertEq(_controller.pendingReservedTokenBalanceOf(projectId) - reservedBefore, previewReservedTokenCount);
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
function testFuzzPreviewCashOutMatchesCashOut(
|
|
141
|
-
uint96 payAmount,
|
|
142
|
-
uint16 cashOutTaxRate,
|
|
143
|
-
uint256 cashOutCountSeed
|
|
144
|
-
)
|
|
145
|
-
external
|
|
146
|
-
{
|
|
147
|
-
payAmount = uint96(bound(payAmount, 1, 100 ether));
|
|
148
|
-
cashOutTaxRate = uint16(bound(cashOutTaxRate, 0, JBConstants.MAX_CASH_OUT_TAX_RATE));
|
|
149
|
-
|
|
150
|
-
_launchFeeProject();
|
|
151
|
-
uint256 projectId = _launchProject(0, cashOutTaxRate);
|
|
152
|
-
|
|
153
|
-
vm.prank(_projectOwner);
|
|
154
|
-
jbFeelessAddresses().setFeelessAddress(_beneficiary, true);
|
|
155
|
-
|
|
156
|
-
vm.deal(_beneficiary, payAmount);
|
|
157
|
-
vm.prank(_beneficiary);
|
|
158
|
-
uint256 minted = _terminal.pay{value: payAmount}({
|
|
159
|
-
projectId: projectId,
|
|
160
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
161
|
-
amount: payAmount,
|
|
162
|
-
beneficiary: _beneficiary,
|
|
163
|
-
minReturnedTokens: 0,
|
|
164
|
-
memo: "",
|
|
165
|
-
metadata: ""
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
uint256 cashOutCount = bound(cashOutCountSeed, 1, minted);
|
|
169
|
-
|
|
170
|
-
(
|
|
171
|
-
JBRuleset memory ruleset,
|
|
172
|
-
uint256 previewReclaimAmount,
|
|
173
|
-
uint256 previewCashOutTaxRate,
|
|
174
|
-
JBCashOutHookSpecification[] memory hookSpecifications
|
|
175
|
-
) = _terminal.previewCashOutFrom(
|
|
176
|
-
_beneficiary, projectId, cashOutCount, JBConstants.NATIVE_TOKEN, payable(_beneficiary), ""
|
|
177
|
-
);
|
|
178
|
-
|
|
179
|
-
assertEq(hookSpecifications.length, 0);
|
|
180
|
-
|
|
181
|
-
vm.expectEmit();
|
|
182
|
-
emit IJBCashOutTerminal.CashOutTokens(
|
|
183
|
-
ruleset.id,
|
|
184
|
-
ruleset.cycleNumber,
|
|
185
|
-
projectId,
|
|
186
|
-
_beneficiary,
|
|
187
|
-
_beneficiary,
|
|
188
|
-
cashOutCount,
|
|
189
|
-
previewCashOutTaxRate,
|
|
190
|
-
previewReclaimAmount,
|
|
191
|
-
"",
|
|
192
|
-
_beneficiary
|
|
193
|
-
);
|
|
194
|
-
|
|
195
|
-
vm.prank(_beneficiary);
|
|
196
|
-
uint256 reclaimAmount = _terminal.cashOutTokensOf({
|
|
197
|
-
holder: _beneficiary,
|
|
198
|
-
projectId: projectId,
|
|
199
|
-
cashOutCount: cashOutCount,
|
|
200
|
-
tokenToReclaim: JBConstants.NATIVE_TOKEN,
|
|
201
|
-
minTokensReclaimed: 0,
|
|
202
|
-
beneficiary: payable(_beneficiary),
|
|
203
|
-
metadata: ""
|
|
204
|
-
});
|
|
205
|
-
|
|
206
|
-
assertEq(reclaimAmount, previewReclaimAmount);
|
|
207
|
-
}
|
|
208
|
-
}
|
package/test/TestTokenFlow.sol
DELETED
|
@@ -1,191 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: MIT
|
|
2
|
-
pragma solidity ^0.8.6;
|
|
3
|
-
|
|
4
|
-
import {TestBaseWorkflow} from "./helpers/TestBaseWorkflow.sol";
|
|
5
|
-
import {JBController} from "../src/JBController.sol";
|
|
6
|
-
import {JBERC20} from "../src/JBERC20.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 {IJBToken} from "../src/interfaces/IJBToken.sol";
|
|
12
|
-
import {IJBTokens} from "../src/interfaces/IJBTokens.sol";
|
|
13
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
14
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.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
|
-
import {Clones} from "@openzeppelin/contracts/proxy/Clones.sol";
|
|
21
|
-
import {mulDiv} from "@prb/math/src/Common.sol";
|
|
22
|
-
|
|
23
|
-
// Launch project, issue token or set the token, mint token, burn token.
|
|
24
|
-
contract TestTokenFlow_Local is TestBaseWorkflow {
|
|
25
|
-
IJBController private _controller;
|
|
26
|
-
IJBTokens private _tokens;
|
|
27
|
-
JBRulesetMetadata _metadata;
|
|
28
|
-
IJBTerminal private _terminal;
|
|
29
|
-
uint256 private _projectId;
|
|
30
|
-
address private _projectOwner;
|
|
31
|
-
address private _beneficiary;
|
|
32
|
-
|
|
33
|
-
function setUp() public override {
|
|
34
|
-
super.setUp();
|
|
35
|
-
|
|
36
|
-
_projectOwner = multisig();
|
|
37
|
-
_beneficiary = beneficiary();
|
|
38
|
-
_controller = jbController();
|
|
39
|
-
_tokens = jbTokens();
|
|
40
|
-
_terminal = jbMultiTerminal();
|
|
41
|
-
_metadata = JBRulesetMetadata({
|
|
42
|
-
reservedPercent: JBConstants.MAX_RESERVED_PERCENT / 2,
|
|
43
|
-
cashOutTaxRate: 0,
|
|
44
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
45
|
-
pausePay: false,
|
|
46
|
-
pauseCreditTransfers: false,
|
|
47
|
-
allowOwnerMinting: true,
|
|
48
|
-
allowSetCustomToken: true,
|
|
49
|
-
allowTerminalMigration: false,
|
|
50
|
-
allowSetTerminals: false,
|
|
51
|
-
ownerMustSendPayouts: false,
|
|
52
|
-
allowSetController: false,
|
|
53
|
-
allowAddAccountingContext: true,
|
|
54
|
-
allowAddPriceFeed: false,
|
|
55
|
-
holdFees: false,
|
|
56
|
-
useTotalSurplusForCashOuts: false,
|
|
57
|
-
useDataHookForPay: false,
|
|
58
|
-
useDataHookForCashOut: false,
|
|
59
|
-
dataHook: address(0),
|
|
60
|
-
metadata: 0
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
// Package up ruleset configuration.
|
|
64
|
-
JBRulesetConfig[] memory _rulesetConfig = new JBRulesetConfig[](1);
|
|
65
|
-
_rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
66
|
-
_rulesetConfig[0].duration = 0;
|
|
67
|
-
_rulesetConfig[0].weight = 1000 * 10 ** 18;
|
|
68
|
-
_rulesetConfig[0].weightCutPercent = 0;
|
|
69
|
-
_rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
70
|
-
_rulesetConfig[0].metadata = _metadata;
|
|
71
|
-
_rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
72
|
-
_rulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
73
|
-
|
|
74
|
-
// Package up terminal configuration.
|
|
75
|
-
JBTerminalConfig[] memory _terminalConfigurations = new JBTerminalConfig[](1);
|
|
76
|
-
JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
|
|
77
|
-
_tokensToAccept[0] = JBAccountingContext({
|
|
78
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
79
|
-
});
|
|
80
|
-
_terminalConfigurations[0] =
|
|
81
|
-
JBTerminalConfig({terminal: _terminal, accountingContextsToAccept: _tokensToAccept});
|
|
82
|
-
|
|
83
|
-
_projectId = _controller.launchProjectFor({
|
|
84
|
-
owner: address(_projectOwner),
|
|
85
|
-
projectUri: "myIPFSHash",
|
|
86
|
-
rulesetConfigurations: _rulesetConfig,
|
|
87
|
-
terminalConfigurations: _terminalConfigurations,
|
|
88
|
-
memo: ""
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
function testFuzzTokenFlow(uint208 _mintAmount, uint256 _burnAmount, bool _issueToken) public {
|
|
93
|
-
vm.startPrank(_projectOwner);
|
|
94
|
-
|
|
95
|
-
if (_issueToken) {
|
|
96
|
-
// Issue an ERC-20 token for project.
|
|
97
|
-
_controller.deployERC20For({
|
|
98
|
-
projectId: _projectId, name: "TestName", symbol: "TestSymbol", salt: bytes32(0)
|
|
99
|
-
});
|
|
100
|
-
} else {
|
|
101
|
-
// Create a new `IJBToken` and change it's owner to the `JBTokens` contract.
|
|
102
|
-
IJBToken _newToken = IJBToken(Clones.clone(address(new JBERC20(jbPermissions(), jbProjects()))));
|
|
103
|
-
_newToken.initialize({name: "NewTestName", symbol: "NewTestSymbol", tokens: address(_tokens)});
|
|
104
|
-
|
|
105
|
-
// Mock the token can be added to the project.
|
|
106
|
-
vm.mockCall(
|
|
107
|
-
address(_newToken), abi.encodeWithSelector(IJBToken.canBeAddedTo.selector, _projectId), abi.encode(true)
|
|
108
|
-
);
|
|
109
|
-
|
|
110
|
-
// Set the projects token to `_newToken`.
|
|
111
|
-
_controller.setTokenFor(_projectId, _newToken);
|
|
112
|
-
|
|
113
|
-
// Make sure the project's new `JBToken` is set.
|
|
114
|
-
assertEq(address(_tokens.tokenOf(_projectId)), address(_newToken));
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
// Expect revert if there are no tokens being minted.
|
|
118
|
-
if (_mintAmount == 0) vm.expectRevert(JBController.JBController_ZeroTokensToMint.selector);
|
|
119
|
-
|
|
120
|
-
// Mint tokens to beneficiary.
|
|
121
|
-
_controller.mintTokensOf({
|
|
122
|
-
projectId: _projectId,
|
|
123
|
-
tokenCount: _mintAmount,
|
|
124
|
-
beneficiary: _beneficiary,
|
|
125
|
-
memo: "Mint memo",
|
|
126
|
-
useReservedPercent: true
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
uint256 _expectedTokenBalance = mulDiv(_mintAmount, _metadata.reservedPercent, JBConstants.MAX_RESERVED_PERCENT);
|
|
130
|
-
|
|
131
|
-
// Make sure the beneficiary has the correct amount of tokens.
|
|
132
|
-
assertEq(_tokens.totalBalanceOf(_beneficiary, _projectId), _expectedTokenBalance);
|
|
133
|
-
|
|
134
|
-
if (_burnAmount == 0) {
|
|
135
|
-
vm.expectRevert(JBController.JBController_ZeroTokensToBurn.selector);
|
|
136
|
-
} else if (_burnAmount > _expectedTokenBalance) {
|
|
137
|
-
vm.expectRevert(
|
|
138
|
-
abi.encodeWithSelector(
|
|
139
|
-
JBTokens.JBTokens_InsufficientTokensToBurn.selector, _burnAmount, _expectedTokenBalance
|
|
140
|
-
)
|
|
141
|
-
);
|
|
142
|
-
} else {
|
|
143
|
-
_expectedTokenBalance -= _burnAmount;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
// Burn tokens from beneficiary.
|
|
147
|
-
vm.stopPrank();
|
|
148
|
-
vm.prank(_beneficiary);
|
|
149
|
-
_controller.burnTokensOf({
|
|
150
|
-
holder: _beneficiary, projectId: _projectId, tokenCount: _burnAmount, memo: "Burn memo"
|
|
151
|
-
});
|
|
152
|
-
|
|
153
|
-
// Make sure the total balance of tokens is updated.
|
|
154
|
-
assertEq(_tokens.totalBalanceOf(_beneficiary, _projectId), _expectedTokenBalance);
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
function testMintCreditsAtLimit() public {
|
|
158
|
-
// Pay the project such that the `_beneficiary` receives 1000 project token credits.
|
|
159
|
-
vm.deal(_beneficiary, 1 ether);
|
|
160
|
-
uint256 beneficiaryTokenCount = _terminal.pay{value: 1 ether}({
|
|
161
|
-
projectId: _projectId,
|
|
162
|
-
amount: 1 ether,
|
|
163
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
164
|
-
beneficiary: _beneficiary,
|
|
165
|
-
minReturnedTokens: 0,
|
|
166
|
-
memo: "",
|
|
167
|
-
metadata: new bytes(0)
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
// Calls will originate from project.
|
|
171
|
-
vm.startPrank(_projectOwner);
|
|
172
|
-
|
|
173
|
-
// Issue an ERC-20 token for project.
|
|
174
|
-
_controller.deployERC20For({projectId: _projectId, name: "TestName", symbol: "TestSymbol", salt: bytes32(0)});
|
|
175
|
-
|
|
176
|
-
// Mint claimed tokens to beneficiary: since this is 1,000 over `uint(208)` it will revert.
|
|
177
|
-
vm.expectRevert(
|
|
178
|
-
abi.encodeWithSelector(
|
|
179
|
-
JBTokens.JBTokens_OverflowAlert.selector, type(uint208).max + beneficiaryTokenCount, type(uint208).max
|
|
180
|
-
)
|
|
181
|
-
);
|
|
182
|
-
|
|
183
|
-
_controller.mintTokensOf({
|
|
184
|
-
projectId: _projectId,
|
|
185
|
-
tokenCount: type(uint208).max,
|
|
186
|
-
beneficiary: _beneficiary,
|
|
187
|
-
memo: "Mint memo",
|
|
188
|
-
useReservedPercent: false
|
|
189
|
-
});
|
|
190
|
-
}
|
|
191
|
-
}
|