@bananapus/core-v6 0.0.36 → 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 +26 -5
- package/src/JBMultiTerminal.sol +85 -47
- 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/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,195 +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 {JBTerminalStore} from "../src/JBTerminalStore.sol";
|
|
7
|
-
import {JBTokens} from "../src/JBTokens.sol";
|
|
8
|
-
import {IJBController} from "../src/interfaces/IJBController.sol";
|
|
9
|
-
import {IJBMultiTerminal} from "../src/interfaces/IJBMultiTerminal.sol";
|
|
10
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
11
|
-
import {IJBTerminal} from "../src/interfaces/IJBTerminal.sol";
|
|
12
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
13
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
14
|
-
import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.sol";
|
|
15
|
-
import {JBRulesetConfig} from "../src/structs/JBRulesetConfig.sol";
|
|
16
|
-
import {JBRulesetMetadata} from "../src/structs/JBRulesetMetadata.sol";
|
|
17
|
-
import {JBSplitGroup} from "../src/structs/JBSplitGroup.sol";
|
|
18
|
-
import {JBTerminalConfig} from "../src/structs/JBTerminalConfig.sol";
|
|
19
|
-
import {mul as UD60x18mul, unwrap as UD60x18unwrap, wrap as UD60x18wrap} from "@prb/math/src/UD60x18.sol";
|
|
20
|
-
|
|
21
|
-
// Project can issue token, receive payments in exchange for tokens, burn some of the claimed tokens, and allow holders
|
|
22
|
-
// to cash out the rest of tokens.
|
|
23
|
-
contract TestPayBurnCashOutFlow_Local is TestBaseWorkflow {
|
|
24
|
-
IJBController private _controller;
|
|
25
|
-
IJBMultiTerminal private _terminal;
|
|
26
|
-
JBTokens private _tokens;
|
|
27
|
-
uint112 private _weight;
|
|
28
|
-
JBRulesetMetadata _metadata;
|
|
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
|
-
_terminal = jbMultiTerminal();
|
|
40
|
-
_tokens = jbTokens();
|
|
41
|
-
_weight = 1000 * 10 ** 18;
|
|
42
|
-
_metadata = JBRulesetMetadata({
|
|
43
|
-
reservedPercent: 0,
|
|
44
|
-
cashOutTaxRate: JBConstants.MAX_CASH_OUT_TAX_RATE,
|
|
45
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
46
|
-
pausePay: false,
|
|
47
|
-
pauseCreditTransfers: false,
|
|
48
|
-
allowOwnerMinting: false,
|
|
49
|
-
allowSetCustomToken: true,
|
|
50
|
-
allowTerminalMigration: false,
|
|
51
|
-
allowSetTerminals: false,
|
|
52
|
-
ownerMustSendPayouts: false,
|
|
53
|
-
allowSetController: false,
|
|
54
|
-
allowAddAccountingContext: true,
|
|
55
|
-
allowAddPriceFeed: false,
|
|
56
|
-
holdFees: false,
|
|
57
|
-
useTotalSurplusForCashOuts: false,
|
|
58
|
-
useDataHookForPay: false,
|
|
59
|
-
useDataHookForCashOut: false,
|
|
60
|
-
dataHook: address(0),
|
|
61
|
-
metadata: 0
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
IJBTerminal[] memory _terminals = new IJBTerminal[](1);
|
|
65
|
-
_terminals[0] = (_terminal);
|
|
66
|
-
|
|
67
|
-
// Package up ruleset configuration.
|
|
68
|
-
JBRulesetConfig[] memory _rulesetConfig = new JBRulesetConfig[](1);
|
|
69
|
-
_rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
70
|
-
_rulesetConfig[0].duration = 0;
|
|
71
|
-
_rulesetConfig[0].weight = _weight;
|
|
72
|
-
_rulesetConfig[0].weightCutPercent = 0;
|
|
73
|
-
_rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
74
|
-
_rulesetConfig[0].metadata = _metadata;
|
|
75
|
-
_rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
76
|
-
_rulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
77
|
-
|
|
78
|
-
// Package up terminal configuration.
|
|
79
|
-
JBTerminalConfig[] memory _terminalConfigurations = new JBTerminalConfig[](1);
|
|
80
|
-
JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
|
|
81
|
-
_tokensToAccept[0] = JBAccountingContext({
|
|
82
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
83
|
-
});
|
|
84
|
-
_terminalConfigurations[0] =
|
|
85
|
-
JBTerminalConfig({terminal: _terminal, accountingContextsToAccept: _tokensToAccept});
|
|
86
|
-
|
|
87
|
-
// Dummy project that will receive fees.
|
|
88
|
-
_controller.launchProjectFor({
|
|
89
|
-
owner: _projectOwner,
|
|
90
|
-
projectUri: "myIPFSHash",
|
|
91
|
-
rulesetConfigurations: _rulesetConfig,
|
|
92
|
-
terminalConfigurations: _terminalConfigurations,
|
|
93
|
-
memo: ""
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
_projectId = _controller.launchProjectFor({
|
|
97
|
-
owner: _projectOwner,
|
|
98
|
-
projectUri: "myIPFSHash",
|
|
99
|
-
rulesetConfigurations: _rulesetConfig,
|
|
100
|
-
terminalConfigurations: _terminalConfigurations,
|
|
101
|
-
memo: ""
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
function testFuzzPayBurnCashOutFlow(
|
|
106
|
-
uint112 _nativePayAmount,
|
|
107
|
-
uint256 _burnTokenAmount,
|
|
108
|
-
uint256 _cashOutAmount
|
|
109
|
-
)
|
|
110
|
-
external
|
|
111
|
-
{
|
|
112
|
-
// Issue an ERC-20 token for project.
|
|
113
|
-
vm.prank(_projectOwner);
|
|
114
|
-
_controller.deployERC20For(_projectId, "TestName", "TestSymbol", bytes32(0));
|
|
115
|
-
|
|
116
|
-
address someRandomUser = vm.addr(1);
|
|
117
|
-
vm.prank(someRandomUser);
|
|
118
|
-
vm.deal(someRandomUser, _nativePayAmount);
|
|
119
|
-
// Make a payment.
|
|
120
|
-
_terminal.pay{value: _nativePayAmount}({
|
|
121
|
-
projectId: _projectId,
|
|
122
|
-
amount: _nativePayAmount,
|
|
123
|
-
token: JBConstants.NATIVE_TOKEN, // Unused.
|
|
124
|
-
beneficiary: _beneficiary,
|
|
125
|
-
minReturnedTokens: 0,
|
|
126
|
-
memo: "Take my money!",
|
|
127
|
-
metadata: new bytes(0)
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
// Make sure the beneficiary has a balance of project tokens.
|
|
131
|
-
uint256 _beneficiaryTokenBalance =
|
|
132
|
-
UD60x18unwrap(UD60x18mul(UD60x18wrap(_nativePayAmount), UD60x18wrap(_weight)));
|
|
133
|
-
assertEq(_tokens.totalBalanceOf(_beneficiary, _projectId), _beneficiaryTokenBalance);
|
|
134
|
-
|
|
135
|
-
// Make sure the native token balance in terminal is up to date.
|
|
136
|
-
uint256 _terminalBalance = _nativePayAmount;
|
|
137
|
-
assertEq(
|
|
138
|
-
jbTerminalStore().balanceOf(address(_terminal), _projectId, JBConstants.NATIVE_TOKEN), _terminalBalance
|
|
139
|
-
);
|
|
140
|
-
|
|
141
|
-
// Burn tokens from beneficiary.
|
|
142
|
-
if (_burnTokenAmount == 0) {
|
|
143
|
-
vm.expectRevert(JBController.JBController_ZeroTokensToBurn.selector);
|
|
144
|
-
} else if (_burnTokenAmount > _beneficiaryTokenBalance) {
|
|
145
|
-
vm.expectRevert(
|
|
146
|
-
abi.encodeWithSelector(
|
|
147
|
-
JBTokens.JBTokens_InsufficientTokensToBurn.selector, _burnTokenAmount, _beneficiaryTokenBalance
|
|
148
|
-
)
|
|
149
|
-
);
|
|
150
|
-
} else {
|
|
151
|
-
_beneficiaryTokenBalance -= _burnTokenAmount;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
vm.prank(_beneficiary);
|
|
155
|
-
_controller.burnTokensOf({
|
|
156
|
-
holder: _beneficiary, projectId: _projectId, tokenCount: _burnTokenAmount, memo: "I hate tokens!"
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
// Make sure the beneficiary should has a new balance of project tokens.
|
|
160
|
-
assertEq(_tokens.totalBalanceOf(_beneficiary, _projectId), _beneficiaryTokenBalance);
|
|
161
|
-
|
|
162
|
-
// Cash out tokens.
|
|
163
|
-
if (_cashOutAmount > _beneficiaryTokenBalance) {
|
|
164
|
-
vm.expectRevert(
|
|
165
|
-
abi.encodeWithSelector(
|
|
166
|
-
JBTerminalStore.JBTerminalStore_InsufficientTokens.selector,
|
|
167
|
-
_cashOutAmount,
|
|
168
|
-
_beneficiaryTokenBalance
|
|
169
|
-
)
|
|
170
|
-
);
|
|
171
|
-
} else {
|
|
172
|
-
_beneficiaryTokenBalance -= _cashOutAmount;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
vm.prank(_beneficiary);
|
|
176
|
-
uint256 _reclaimAmt = _terminal.cashOutTokensOf({
|
|
177
|
-
holder: _beneficiary,
|
|
178
|
-
projectId: _projectId,
|
|
179
|
-
cashOutCount: _cashOutAmount,
|
|
180
|
-
tokenToReclaim: JBConstants.NATIVE_TOKEN, // Unused.
|
|
181
|
-
minTokensReclaimed: 0,
|
|
182
|
-
beneficiary: payable(_beneficiary),
|
|
183
|
-
metadata: new bytes(0)
|
|
184
|
-
});
|
|
185
|
-
|
|
186
|
-
// Make sure the beneficiary has a new balance of project tokens.
|
|
187
|
-
assertEq(_tokens.totalBalanceOf(_beneficiary, _projectId), _beneficiaryTokenBalance);
|
|
188
|
-
|
|
189
|
-
// Make sure the native token balance in terminal is up to date.
|
|
190
|
-
assertEq(
|
|
191
|
-
jbTerminalStore().balanceOf(address(_terminal), _projectId, JBConstants.NATIVE_TOKEN),
|
|
192
|
-
_terminalBalance - _reclaimAmt
|
|
193
|
-
);
|
|
194
|
-
}
|
|
195
|
-
}
|
package/test/TestPayHooks.sol
DELETED
|
@@ -1,209 +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 {IJBPayHook} from "../src/interfaces/IJBPayHook.sol";
|
|
7
|
-
import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
|
|
8
|
-
import {IJBRulesetDataHook} from "../src/interfaces/IJBRulesetDataHook.sol";
|
|
9
|
-
import {IJBTerminal} from "../src/interfaces/IJBTerminal.sol";
|
|
10
|
-
import {JBConstants} from "../src/libraries/JBConstants.sol";
|
|
11
|
-
import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
|
|
12
|
-
import {JBAfterPayRecordedContext} from "../src/structs/JBAfterPayRecordedContext.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
|
-
import {JBTokenAmount} from "../src/structs/JBTokenAmount.sol";
|
|
21
|
-
import {mulDiv} from "@prb/math/src/Common.sol";
|
|
22
|
-
|
|
23
|
-
contract TestPayHooks_Local is TestBaseWorkflow {
|
|
24
|
-
uint8 private constant _WEIGHT_DECIMALS = 18;
|
|
25
|
-
uint8 private constant _NATIVE_TOKEN_DECIMALS = 18;
|
|
26
|
-
uint112 private constant _WEIGHT = uint112(1000 * 10 ** _WEIGHT_DECIMALS);
|
|
27
|
-
uint256 private constant _DATA_HOOK_WEIGHT = 2000 * 10 ** _WEIGHT_DECIMALS;
|
|
28
|
-
address private constant _DATA_HOOK = address(bytes20(keccak256("datahook")));
|
|
29
|
-
bytes private constant _PAYER_METADATA = bytes("Some payer metadata");
|
|
30
|
-
|
|
31
|
-
IJBController private _controller;
|
|
32
|
-
IJBTerminal private _terminal;
|
|
33
|
-
address private _projectOwner;
|
|
34
|
-
address private _beneficiary;
|
|
35
|
-
address private _payer;
|
|
36
|
-
|
|
37
|
-
uint64 _projectId;
|
|
38
|
-
|
|
39
|
-
function setUp() public override {
|
|
40
|
-
super.setUp();
|
|
41
|
-
|
|
42
|
-
_controller = jbController();
|
|
43
|
-
_projectOwner = multisig();
|
|
44
|
-
_beneficiary = beneficiary();
|
|
45
|
-
_payer = address(1_234_567);
|
|
46
|
-
_terminal = jbMultiTerminal();
|
|
47
|
-
|
|
48
|
-
JBRulesetMetadata memory _metadata = JBRulesetMetadata({
|
|
49
|
-
reservedPercent: 0,
|
|
50
|
-
cashOutTaxRate: 0,
|
|
51
|
-
baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
|
|
52
|
-
pausePay: false,
|
|
53
|
-
pauseCreditTransfers: false,
|
|
54
|
-
allowOwnerMinting: false,
|
|
55
|
-
allowSetCustomToken: false,
|
|
56
|
-
allowTerminalMigration: false,
|
|
57
|
-
allowSetTerminals: false,
|
|
58
|
-
ownerMustSendPayouts: false,
|
|
59
|
-
allowSetController: false,
|
|
60
|
-
allowAddAccountingContext: true,
|
|
61
|
-
allowAddPriceFeed: false,
|
|
62
|
-
holdFees: false,
|
|
63
|
-
useTotalSurplusForCashOuts: false,
|
|
64
|
-
useDataHookForPay: true,
|
|
65
|
-
useDataHookForCashOut: true,
|
|
66
|
-
dataHook: _DATA_HOOK,
|
|
67
|
-
metadata: 0
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
// Package up ruleset configuration.
|
|
71
|
-
JBRulesetConfig[] memory _rulesetConfig = new JBRulesetConfig[](1);
|
|
72
|
-
_rulesetConfig[0].mustStartAtOrAfter = 0;
|
|
73
|
-
_rulesetConfig[0].duration = 0;
|
|
74
|
-
_rulesetConfig[0].weight = _WEIGHT;
|
|
75
|
-
_rulesetConfig[0].weightCutPercent = 0;
|
|
76
|
-
_rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
|
|
77
|
-
_rulesetConfig[0].metadata = _metadata;
|
|
78
|
-
_rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
|
|
79
|
-
_rulesetConfig[0].fundAccessLimitGroups = new JBFundAccessLimitGroup[](0);
|
|
80
|
-
|
|
81
|
-
JBTerminalConfig[] memory _terminalConfigurations = new JBTerminalConfig[](1);
|
|
82
|
-
JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
|
|
83
|
-
_tokensToAccept[0] = JBAccountingContext({
|
|
84
|
-
token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
|
|
85
|
-
});
|
|
86
|
-
_terminalConfigurations[0] =
|
|
87
|
-
JBTerminalConfig({terminal: _terminal, accountingContextsToAccept: _tokensToAccept});
|
|
88
|
-
|
|
89
|
-
_projectId = uint64(
|
|
90
|
-
_controller.launchProjectFor({
|
|
91
|
-
owner: _projectOwner,
|
|
92
|
-
projectUri: "myIPFSHash",
|
|
93
|
-
rulesetConfigurations: _rulesetConfig,
|
|
94
|
-
terminalConfigurations: _terminalConfigurations,
|
|
95
|
-
memo: ""
|
|
96
|
-
})
|
|
97
|
-
);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
function testPayHooks(uint256 _numberOfSpecifications, uint256 _nativePayAmount) public {
|
|
101
|
-
// Bound the number of specifications to a reasonable amount.
|
|
102
|
-
_numberOfSpecifications = bound(_numberOfSpecifications, 1, 20);
|
|
103
|
-
// Make sure the amount of tokens generated fits in a register, and that each specification can get some.
|
|
104
|
-
_nativePayAmount = bound(_nativePayAmount, _numberOfSpecifications, type(uint256).max / _DATA_HOOK_WEIGHT);
|
|
105
|
-
|
|
106
|
-
// epa * weight / epad < max*epad/weight
|
|
107
|
-
|
|
108
|
-
// Keep a reference to the specifications.
|
|
109
|
-
JBPayHookSpecification[] memory _specifications = new JBPayHookSpecification[](_numberOfSpecifications);
|
|
110
|
-
|
|
111
|
-
// Keep a reference to the amounts in the specifications.
|
|
112
|
-
uint256[] memory _payHookAmounts = new uint256[](_numberOfSpecifications);
|
|
113
|
-
|
|
114
|
-
// Keep a reference to the amount that'll be paid and sent to pay hooks.
|
|
115
|
-
uint256 _totalToAllocate = _nativePayAmount;
|
|
116
|
-
|
|
117
|
-
// Spread the paid amount through all specifications, in various chunks, omitting the last entry.
|
|
118
|
-
for (uint256 i; i < _numberOfSpecifications - 1; i++) {
|
|
119
|
-
_payHookAmounts[i] = _totalToAllocate / (_payHookAmounts.length * 2);
|
|
120
|
-
_totalToAllocate -= _payHookAmounts[i];
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
// Send the rest to the last entry.
|
|
124
|
-
_payHookAmounts[_payHookAmounts.length - 1] = _totalToAllocate;
|
|
125
|
-
|
|
126
|
-
// Keep a reference to the current ruleset.
|
|
127
|
-
(JBRuleset memory _ruleset,) = _controller.currentRulesetOf(_projectId);
|
|
128
|
-
|
|
129
|
-
// Iterate through each specification.
|
|
130
|
-
for (uint256 i = 0; i < _numberOfSpecifications; i++) {
|
|
131
|
-
// Make up an address for the hook.
|
|
132
|
-
address _hookAddress = address(bytes20(keccak256(abi.encodePacked("PayHook", i))));
|
|
133
|
-
|
|
134
|
-
// Send along some metadata to the pay hook.
|
|
135
|
-
bytes memory _hookMetadata = bytes("Some data hook metadata");
|
|
136
|
-
|
|
137
|
-
// Package up the specification struct.
|
|
138
|
-
_specifications[i] = JBPayHookSpecification({
|
|
139
|
-
hook: IJBPayHook(_hookAddress), noop: false, amount: _payHookAmounts[i], metadata: _hookMetadata
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
// Keep a reference to the data that'll be received by the hook.
|
|
143
|
-
JBAfterPayRecordedContext memory _postRecordPayContext = JBAfterPayRecordedContext({
|
|
144
|
-
payer: _payer,
|
|
145
|
-
projectId: _projectId,
|
|
146
|
-
rulesetId: _ruleset.id,
|
|
147
|
-
amount: JBTokenAmount({
|
|
148
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
149
|
-
decimals: _terminal.accountingContextForTokenOf(_projectId, JBConstants.NATIVE_TOKEN).decimals,
|
|
150
|
-
currency: _terminal.accountingContextForTokenOf(_projectId, JBConstants.NATIVE_TOKEN).currency,
|
|
151
|
-
value: _nativePayAmount
|
|
152
|
-
}),
|
|
153
|
-
forwardedAmount: JBTokenAmount({
|
|
154
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
155
|
-
decimals: _terminal.accountingContextForTokenOf(_projectId, JBConstants.NATIVE_TOKEN).decimals,
|
|
156
|
-
currency: _terminal.accountingContextForTokenOf(_projectId, JBConstants.NATIVE_TOKEN).currency,
|
|
157
|
-
value: _payHookAmounts[i]
|
|
158
|
-
}),
|
|
159
|
-
weight: _WEIGHT,
|
|
160
|
-
newlyIssuedTokenCount: mulDiv(_nativePayAmount, _DATA_HOOK_WEIGHT, 10 ** _NATIVE_TOKEN_DECIMALS),
|
|
161
|
-
beneficiary: _beneficiary,
|
|
162
|
-
hookMetadata: _hookMetadata,
|
|
163
|
-
payerMetadata: _PAYER_METADATA
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
// Mock the hook.
|
|
167
|
-
vm.mockCall(
|
|
168
|
-
_hookAddress,
|
|
169
|
-
abi.encodeWithSelector(IJBPayHook.afterPayRecordedWith.selector),
|
|
170
|
-
abi.encode(_postRecordPayContext)
|
|
171
|
-
);
|
|
172
|
-
|
|
173
|
-
// Assert that the hook gets called with the expected value.
|
|
174
|
-
vm.expectCall(
|
|
175
|
-
_hookAddress,
|
|
176
|
-
_payHookAmounts[i],
|
|
177
|
-
abi.encodeWithSelector(IJBPayHook.afterPayRecordedWith.selector, _postRecordPayContext)
|
|
178
|
-
);
|
|
179
|
-
|
|
180
|
-
// Expect an event to be emitted for every hook.
|
|
181
|
-
vm.expectEmit(true, true, true, true);
|
|
182
|
-
emit HookAfterRecordPay(IJBPayHook(_hookAddress), _postRecordPayContext, _payHookAmounts[i], _payer);
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
vm.mockCall(
|
|
186
|
-
_DATA_HOOK,
|
|
187
|
-
abi.encodeWithSelector(IJBRulesetDataHook.beforePayRecordedWith.selector),
|
|
188
|
-
abi.encode(_DATA_HOOK_WEIGHT, _specifications)
|
|
189
|
-
);
|
|
190
|
-
|
|
191
|
-
vm.deal(_payer, _nativePayAmount);
|
|
192
|
-
vm.prank(_payer);
|
|
193
|
-
|
|
194
|
-
// Pay the project such that the `_beneficiary` receives project tokens.
|
|
195
|
-
_terminal.pay{value: _nativePayAmount}({
|
|
196
|
-
projectId: _projectId,
|
|
197
|
-
amount: _nativePayAmount,
|
|
198
|
-
token: JBConstants.NATIVE_TOKEN,
|
|
199
|
-
beneficiary: _beneficiary,
|
|
200
|
-
minReturnedTokens: 0,
|
|
201
|
-
memo: "Forge Test",
|
|
202
|
-
metadata: _PAYER_METADATA
|
|
203
|
-
});
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
event HookAfterRecordPay(
|
|
207
|
-
IJBPayHook indexed hook, JBAfterPayRecordedContext context, uint256 specificationAmount, address caller
|
|
208
|
-
);
|
|
209
|
-
}
|