@bananapus/core-v6 0.0.37 → 0.0.39

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (324) hide show
  1. package/foundry.lock +1 -7
  2. package/foundry.toml +1 -1
  3. package/package.json +19 -7
  4. package/src/JBChainlinkV3PriceFeed.sol +4 -1
  5. package/src/JBChainlinkV3SequencerPriceFeed.sol +4 -2
  6. package/src/JBController.sol +71 -44
  7. package/src/JBDeadline.sol +4 -4
  8. package/src/JBDirectory.sol +34 -32
  9. package/src/JBERC20.sol +5 -4
  10. package/src/JBFeelessAddresses.sol +6 -3
  11. package/src/JBFundAccessLimits.sol +25 -21
  12. package/src/JBMultiTerminal.sol +121 -84
  13. package/src/JBPermissions.sol +34 -37
  14. package/src/JBPrices.sol +23 -18
  15. package/src/JBProjects.sol +6 -3
  16. package/src/JBRulesets.sol +44 -41
  17. package/src/JBSplits.sol +18 -16
  18. package/src/JBTerminalStore.sol +32 -25
  19. package/src/JBTokens.sol +36 -26
  20. package/src/abstract/JBControlled.sol +3 -1
  21. package/src/abstract/JBPermissioned.sol +3 -1
  22. package/src/enums/JBApprovalStatus.sol +7 -1
  23. package/src/interfaces/IJBController.sol +7 -3
  24. package/src/interfaces/IJBDirectory.sol +3 -1
  25. package/src/interfaces/IJBMultiTerminal.sol +3 -2
  26. package/src/interfaces/IJBPermissions.sol +2 -1
  27. package/src/interfaces/IJBPrices.sol +3 -1
  28. package/src/interfaces/IJBRulesets.sol +2 -1
  29. package/src/interfaces/IJBSplits.sol +2 -1
  30. package/src/interfaces/IJBTerminal.sol +3 -1
  31. package/src/interfaces/IJBTerminalStore.sol +3 -1
  32. package/src/interfaces/IJBTokens.sol +2 -1
  33. package/src/libraries/JBCashOuts.sol +6 -1
  34. package/src/libraries/JBConstants.sol +12 -3
  35. package/src/libraries/JBCurrencyIds.sol +2 -0
  36. package/src/libraries/JBFees.sol +52 -10
  37. package/src/libraries/JBFixedPointNumber.sol +2 -0
  38. package/src/libraries/JBPayoutSplitGroupLib.sol +7 -4
  39. package/src/libraries/JBRulesetMetadataResolver.sol +4 -0
  40. package/src/libraries/JBSplitGroupIds.sol +2 -1
  41. package/src/libraries/JBSurplus.sol +3 -1
  42. package/src/periphery/JBMatchingPriceFeed.sol +3 -1
  43. package/src/structs/JBAccountingContext.sol +7 -4
  44. package/src/structs/JBFundAccessLimitGroup.sol +10 -17
  45. package/src/structs/JBRuleset.sol +18 -26
  46. package/src/structs/JBRulesetConfig.sol +13 -25
  47. package/src/structs/JBRulesetMetadata.sol +25 -32
  48. package/test/mock/MockMaliciousBeneficiary.sol +15 -15
  49. package/ADMINISTRATION.md +0 -103
  50. package/ARCHITECTURE.md +0 -133
  51. package/AUDIT_INSTRUCTIONS.md +0 -139
  52. package/RISKS.md +0 -215
  53. package/SKILLS.md +0 -55
  54. package/STYLE_GUIDE.md +0 -610
  55. package/USER_JOURNEYS.md +0 -215
  56. package/script/Deploy.s.sol +0 -124
  57. package/script/DeployPeriphery.s.sol +0 -354
  58. package/slither-ci.config.json +0 -10
  59. package/test/AuditFixes.t.sol +0 -808
  60. package/test/ComprehensiveInvariant.t.sol +0 -306
  61. package/test/CoreExploitTests.t.sol +0 -2741
  62. package/test/EconomicSimulation.t.sol +0 -348
  63. package/test/EntryPointPermutations.t.sol +0 -684
  64. package/test/FlashLoanAttacks.t.sol +0 -797
  65. package/test/PermissionEscalation.t.sol +0 -711
  66. package/test/PermissionsInvariant.t.sol +0 -403
  67. package/test/RulesetTransitions.t.sol +0 -713
  68. package/test/SplitLoopTests.t.sol +0 -752
  69. package/test/TestAccessToFunds.sol +0 -2683
  70. package/test/TestAuditResponseDesignProofs.sol +0 -434
  71. package/test/TestCashOut.sol +0 -198
  72. package/test/TestCashOutCountFor.sol +0 -271
  73. package/test/TestCashOutHooks.sol +0 -351
  74. package/test/TestCashOutTimingEdge.sol +0 -241
  75. package/test/TestDataHookFuzzing.sol +0 -524
  76. package/test/TestDurationUnderflow.sol +0 -233
  77. package/test/TestFeeFreeCashOutBypass.sol +0 -949
  78. package/test/TestFeeProcessingFailure.sol +0 -218
  79. package/test/TestFees.sol +0 -619
  80. package/test/TestForwardedTokenConsumption.sol +0 -425
  81. package/test/TestInterfaceSupport.sol +0 -81
  82. package/test/TestJBERC20Inheritance.sol +0 -103
  83. package/test/TestL2SequencerPriceFeed.sol +0 -292
  84. package/test/TestLaunchProject.sol +0 -188
  85. package/test/TestMetaTx.sol +0 -217
  86. package/test/TestMetadataOffsetOverflow.sol +0 -179
  87. package/test/TestMetadataParserLib.sol +0 -471
  88. package/test/TestMigrationHeldFees.sol +0 -255
  89. package/test/TestMintTokensOf.sol +0 -185
  90. package/test/TestMultiTerminalSurplus.sol +0 -348
  91. package/test/TestMultiTokenSurplus.sol +0 -202
  92. package/test/TestMultipleAccessLimits.sol +0 -664
  93. package/test/TestPayBurnRedeemFlow.sol +0 -195
  94. package/test/TestPayHooks.sol +0 -209
  95. package/test/TestPermissions.sol +0 -324
  96. package/test/TestPermissionsEdge.sol +0 -290
  97. package/test/TestPermit2DataHook.t.sol +0 -360
  98. package/test/TestPermit2Terminal.sol +0 -372
  99. package/test/TestRulesetQueueing.sol +0 -1025
  100. package/test/TestRulesetQueuingStress.sol +0 -806
  101. package/test/TestRulesetWeightCaching.sol +0 -178
  102. package/test/TestSplits.sol +0 -391
  103. package/test/TestTerminalMigration.sol +0 -274
  104. package/test/TestTerminalPreviewParity.sol +0 -208
  105. package/test/TestTokenFlow.sol +0 -191
  106. package/test/TestWeightCacheStaleAfterRejection.sol +0 -303
  107. package/test/WeirdTokenTests.t.sol +0 -817
  108. package/test/audit/CashOutReenterPay.t.sol +0 -501
  109. package/test/audit/CodexHeldFeeRounding.t.sol +0 -159
  110. package/test/audit/CodexMigrationFeeFailure.t.sol +0 -163
  111. package/test/audit/CrossTerminalSurplusSpoof.t.sol +0 -140
  112. package/test/audit/CycledSurplusAllowanceReset.t.sol +0 -184
  113. package/test/audit/FeeFreeSurplusLifecycle.t.sol +0 -399
  114. package/test/audit/FeeFreeSurplusStale.t.sol +0 -248
  115. package/test/audit/USDTVoidReturnCompat.t.sol +0 -525
  116. package/test/fork/TestChainlinkPriceFeedFork.sol +0 -254
  117. package/test/fork/TestSequencerPriceFeedFork.sol +0 -168
  118. package/test/fork/TestTerminalPreviewParityFork.sol +0 -108
  119. package/test/formal/BondingCurveProperties.t.sol +0 -420
  120. package/test/formal/FeeProperties.t.sol +0 -252
  121. package/test/invariants/Phase3DeepInvariant.t.sol +0 -412
  122. package/test/invariants/RulesetsInvariant.t.sol +0 -125
  123. package/test/invariants/TerminalStoreInvariant.t.sol +0 -227
  124. package/test/invariants/TokensInvariant.t.sol +0 -195
  125. package/test/invariants/handlers/ComprehensiveHandler.sol +0 -303
  126. package/test/invariants/handlers/EconomicHandler.sol +0 -377
  127. package/test/invariants/handlers/Phase3Handler.sol +0 -443
  128. package/test/invariants/handlers/RulesetsHandler.sol +0 -115
  129. package/test/invariants/handlers/TerminalStoreHandler.sol +0 -151
  130. package/test/invariants/handlers/TokensHandler.sol +0 -126
  131. package/test/regression/HoldFeesCashOutReserved.t.sol +0 -415
  132. package/test/regression/WeightCacheBoundary.t.sol +0 -291
  133. package/test/trees/JBController/burnTokensOf.tree +0 -9
  134. package/test/trees/JBController/claimTokensFor.tree +0 -5
  135. package/test/trees/JBController/deployERC20For.tree +0 -5
  136. package/test/trees/JBController/getRulesetOf.tree +0 -5
  137. package/test/trees/JBController/launchProjectFor.tree +0 -12
  138. package/test/trees/JBController/launchRulesetsFor.tree +0 -8
  139. package/test/trees/JBController/migrateController.tree +0 -12
  140. package/test/trees/JBController/mintTokensOf.tree +0 -12
  141. package/test/trees/JBController/payReservedTokenToTerminal.tree +0 -8
  142. package/test/trees/JBController/receiveMigrationFrom.tree +0 -4
  143. package/test/trees/JBController/sendReservedTokensToSplitsOf.tree +0 -12
  144. package/test/trees/JBController/setMetadataOf.tree +0 -5
  145. package/test/trees/JBController/setSplitGroupsOf.tree +0 -5
  146. package/test/trees/JBController/setTokenFor.tree +0 -5
  147. package/test/trees/JBController/transferCreditsFrom.tree +0 -8
  148. package/test/trees/JBDirectory/primaryTerminalOf.tree +0 -8
  149. package/test/trees/JBDirectory/setControllerOf.tree +0 -11
  150. package/test/trees/JBDirectory/setPrimaryTerminalOf.tree +0 -15
  151. package/test/trees/JBDirectory/setTerminalsOf.tree +0 -11
  152. package/test/trees/JBERC20/initialize.tree +0 -7
  153. package/test/trees/JBERC20/name.tree +0 -5
  154. package/test/trees/JBERC20/nonces.tree +0 -5
  155. package/test/trees/JBERC20/symbol.tree +0 -5
  156. package/test/trees/JBFeelessAddresses/setFeelessAddress.tree +0 -5
  157. package/test/trees/JBFeelessAddresses/supportsInterface.tree +0 -5
  158. package/test/trees/JBFundAccessLimits/payoutLimitOf.tree +0 -5
  159. package/test/trees/JBFundAccessLimits/payoutLimitsOf.tree +0 -8
  160. package/test/trees/JBFundAccessLimits/setFundAccessLimitsFor.tree +0 -18
  161. package/test/trees/JBFundAccessLimits/surplusAllowanceOf.tree +0 -5
  162. package/test/trees/JBFundAccessLimits/surplusAllowancesOf.tree +0 -8
  163. package/test/trees/JBMetadataResolver/getDataFor.tree +0 -8
  164. package/test/trees/JBMultiTerminal/accountingContextsOf.tree +0 -5
  165. package/test/trees/JBMultiTerminal/addAccountingContextsFor.tree +0 -10
  166. package/test/trees/JBMultiTerminal/addToBalanceOf.tree +0 -23
  167. package/test/trees/JBMultiTerminal/cashOutTokensOf.tree +0 -23
  168. package/test/trees/JBMultiTerminal/executePayout.tree +0 -32
  169. package/test/trees/JBMultiTerminal/executeProcessFee.tree +0 -14
  170. package/test/trees/JBMultiTerminal/migrateBalanceOf.tree +0 -12
  171. package/test/trees/JBMultiTerminal/pay.tree +0 -23
  172. package/test/trees/JBMultiTerminal/processHeldFeesOf.tree +0 -8
  173. package/test/trees/JBMultiTerminal/sendPayoutsOf.tree +0 -34
  174. package/test/trees/JBMultiTerminal/useAllowanceOf.tree +0 -16
  175. package/test/trees/JBPermissions/hasPermission.tree +0 -8
  176. package/test/trees/JBPermissions/hasPermissions.tree +0 -8
  177. package/test/trees/JBPermissions/setPermissionsFor.tree +0 -5
  178. package/test/trees/JBPrices/addPriceFeedFor.tree +0 -14
  179. package/test/trees/JBPrices/pricePerUnitOf.tree +0 -11
  180. package/test/trees/JBProjects/createFor.tree +0 -11
  181. package/test/trees/JBProjects/setTokenUriResolver.tree +0 -5
  182. package/test/trees/JBProjects/supportsInterface.tree +0 -9
  183. package/test/trees/JBProjects/tokenURI.tree +0 -5
  184. package/test/trees/JBRulesets/currentApprovalStatusForLatestRulesetOf.tree +0 -8
  185. package/test/trees/JBRulesets/currentOf.tree +0 -12
  186. package/test/trees/JBRulesets/getRulesetOf.tree +0 -5
  187. package/test/trees/JBRulesets/latestQueuedRulesetOf.tree +0 -10
  188. package/test/trees/JBRulesets/rulesetsOf.tree +0 -11
  189. package/test/trees/JBRulesets/upcomingRulesetOf.tree +0 -20
  190. package/test/trees/JBRulesets/updateRulesetWeightCache.tree +0 -5
  191. package/test/trees/JBSplits/setSplitGroupsOf.tree +0 -17
  192. package/test/trees/JBSplits/splitsOf.tree +0 -5
  193. package/test/trees/JBTerminalStore/currentReclaimableSurplusOf.tree +0 -16
  194. package/test/trees/JBTerminalStore/currentSurplusOf.tree +0 -25
  195. package/test/trees/JBTerminalStore/currentTotalSurplusOf.tree +0 -5
  196. package/test/trees/JBTerminalStore/recordCashOutsFor.tree +0 -16
  197. package/test/trees/JBTerminalStore/recordPaymentFrom.tree +0 -14
  198. package/test/trees/JBTerminalStore/recordPayoutFor.tree +0 -10
  199. package/test/trees/JBTerminalStore/recordTerminalMigration.tree +0 -5
  200. package/test/trees/JBTerminalStore/recordUsedAllowanceOf.tree +0 -10
  201. package/test/trees/JBTokens/burnFrom.tree +0 -10
  202. package/test/trees/JBTokens/claimTokensFor.tree +0 -10
  203. package/test/trees/JBTokens/deployERC20For.tree +0 -12
  204. package/test/trees/JBTokens/mintFor.tree +0 -10
  205. package/test/trees/JBTokens/setTokenFor.tree +0 -11
  206. package/test/trees/JBTokens/totalBalanceOf.tree +0 -5
  207. package/test/trees/JBTokens/totalSupplyOf.tree +0 -5
  208. package/test/trees/JBTokens/transferCreditsFrom.tree +0 -8
  209. package/test/trees/mintTokensOf.tree +0 -12
  210. package/test/units/static/JBChainlinkV3PriceFeed/TestPriceFeed.sol +0 -223
  211. package/test/units/static/JBController/JBControllerSetup.sol +0 -50
  212. package/test/units/static/JBController/TestBurnTokensOf.sol +0 -114
  213. package/test/units/static/JBController/TestClaimTokensFor.sol +0 -63
  214. package/test/units/static/JBController/TestDeployErc20For.sol +0 -86
  215. package/test/units/static/JBController/TestLaunchProjectFor.sol +0 -302
  216. package/test/units/static/JBController/TestLaunchRulesetsFor.sol +0 -342
  217. package/test/units/static/JBController/TestMigrateController.sol +0 -157
  218. package/test/units/static/JBController/TestMintTokensOfUnits.sol +0 -111
  219. package/test/units/static/JBController/TestOmnichainRulesetOperator.sol +0 -324
  220. package/test/units/static/JBController/TestPayReservedTokenToTerminal.sol +0 -74
  221. package/test/units/static/JBController/TestPreviewMintOf.sol +0 -117
  222. package/test/units/static/JBController/TestReceiveMigrationFrom.sol +0 -99
  223. package/test/units/static/JBController/TestRulesetViews.sol +0 -225
  224. package/test/units/static/JBController/TestSendReservedTokensToSplitsOf.sol +0 -615
  225. package/test/units/static/JBController/TestSetSplitGroupsOf.sol +0 -68
  226. package/test/units/static/JBController/TestSetTokenFor.sol +0 -239
  227. package/test/units/static/JBController/TestSetUriOf.sol +0 -57
  228. package/test/units/static/JBController/TestTransferCreditsFrom.sol +0 -169
  229. package/test/units/static/JBDeadline/TestDeadlineFuzz.sol +0 -211
  230. package/test/units/static/JBDirectory/JBDirectorySetup.sol +0 -26
  231. package/test/units/static/JBDirectory/TestPrimaryTerminalOf.sol +0 -126
  232. package/test/units/static/JBDirectory/TestSetControllerOf.sol +0 -183
  233. package/test/units/static/JBDirectory/TestSetControllerOfMigrationOrder.sol +0 -104
  234. package/test/units/static/JBDirectory/TestSetPrimaryTerminalOf.sol +0 -179
  235. package/test/units/static/JBDirectory/TestSetTerminalsOf.sol +0 -137
  236. package/test/units/static/JBERC20/JBERC20Setup.sol +0 -34
  237. package/test/units/static/JBERC20/SigUtils.sol +0 -36
  238. package/test/units/static/JBERC20/TestInitialize.sol +0 -60
  239. package/test/units/static/JBERC20/TestName.sol +0 -30
  240. package/test/units/static/JBERC20/TestNonces.sol +0 -62
  241. package/test/units/static/JBERC20/TestSymbol.sol +0 -31
  242. package/test/units/static/JBFeelessAdresses/JBFeelessSetup.sol +0 -22
  243. package/test/units/static/JBFeelessAdresses/TestInterfaces.sol +0 -30
  244. package/test/units/static/JBFeelessAdresses/TestSetFeelessAddress.sol +0 -35
  245. package/test/units/static/JBFees/TestFeesFuzz.sol +0 -79
  246. package/test/units/static/JBFixedPointNumber/TestAdjustDecimals.sol +0 -16
  247. package/test/units/static/JBFixedPointNumber/TestAdjustDecimalsFuzz.sol +0 -71
  248. package/test/units/static/JBFundAccessLimits/JBFundAccessSetup.sol +0 -24
  249. package/test/units/static/JBFundAccessLimits/TestFundAccessLimitsEdge.sol +0 -163
  250. package/test/units/static/JBFundAccessLimits/TestPayoutLimitOf.sol +0 -59
  251. package/test/units/static/JBFundAccessLimits/TestPayoutLimitsOf.sol +0 -101
  252. package/test/units/static/JBFundAccessLimits/TestSetFundAccessLimitsFor.sol +0 -189
  253. package/test/units/static/JBFundAccessLimits/TestSurplusAllowanceOf.sol +0 -64
  254. package/test/units/static/JBFundAccessLimits/TestSurplusAllowancesOf.sol +0 -102
  255. package/test/units/static/JBMetadataResolver/TestGetDataFor.sol +0 -90
  256. package/test/units/static/JBMetadataResolver/TestMetadataResolverEdgeCases.sol +0 -247
  257. package/test/units/static/JBMetadataResolver/TestMetadataResolverFuzz.sol +0 -229
  258. package/test/units/static/JBMultiTerminal/JBMultiTerminalSetup.sol +0 -50
  259. package/test/units/static/JBMultiTerminal/TestAccountingContextsOf.sol +0 -72
  260. package/test/units/static/JBMultiTerminal/TestAddAccountingContextsFor.sol +0 -289
  261. package/test/units/static/JBMultiTerminal/TestAddToBalanceOf.sol +0 -474
  262. package/test/units/static/JBMultiTerminal/TestCashOutTokensOf.sol +0 -624
  263. package/test/units/static/JBMultiTerminal/TestExecutePayout.sol +0 -578
  264. package/test/units/static/JBMultiTerminal/TestExecuteProcessFee.sol +0 -202
  265. package/test/units/static/JBMultiTerminal/TestMigrateBalanceOf.sol +0 -222
  266. package/test/units/static/JBMultiTerminal/TestPay.sol +0 -604
  267. package/test/units/static/JBMultiTerminal/TestPreviewCashOutFrom.sol +0 -117
  268. package/test/units/static/JBMultiTerminal/TestPreviewPayFor.sol +0 -114
  269. package/test/units/static/JBMultiTerminal/TestProcessHeldFeesOf.sol +0 -228
  270. package/test/units/static/JBMultiTerminal/TestSelfPayRevert.sol +0 -55
  271. package/test/units/static/JBMultiTerminal/TestSendPayoutsOf.sol +0 -257
  272. package/test/units/static/JBMultiTerminal/TestUseAllowanceOf.sol +0 -611
  273. package/test/units/static/JBPermissions/JBPermissionsSetup.sol +0 -20
  274. package/test/units/static/JBPermissions/TestHasPermission.sol +0 -50
  275. package/test/units/static/JBPermissions/TestHasPermissions.sol +0 -93
  276. package/test/units/static/JBPermissions/TestSetPermissionsFor.sol +0 -64
  277. package/test/units/static/JBPrices/JBPricesSetup.sol +0 -32
  278. package/test/units/static/JBPrices/TestAddPriceFeedFor.sol +0 -107
  279. package/test/units/static/JBPrices/TestPricePerUnitOf.sol +0 -132
  280. package/test/units/static/JBPrices/TestPrices.sol +0 -265
  281. package/test/units/static/JBProjects/JBProjectsSetup.sol +0 -22
  282. package/test/units/static/JBProjects/TestCreateFor.sol +0 -71
  283. package/test/units/static/JBProjects/TestInitialProject.sol +0 -21
  284. package/test/units/static/JBProjects/TestInterfaces.sol +0 -26
  285. package/test/units/static/JBProjects/TestSetResolver.sol +0 -37
  286. package/test/units/static/JBProjects/TestTokenUri.sol +0 -40
  287. package/test/units/static/JBRulesetMetadataResolver/TestSetCashOutTaxRateTo.sol +0 -108
  288. package/test/units/static/JBRulesets/JBRulesetsSetup.sol +0 -24
  289. package/test/units/static/JBRulesets/TestCurrentApprovalStatusForLatestRulesetOf.sol +0 -265
  290. package/test/units/static/JBRulesets/TestCurrentOf.sol +0 -242
  291. package/test/units/static/JBRulesets/TestGetRulesetOf.sol +0 -100
  292. package/test/units/static/JBRulesets/TestLatestQueuedRulesetOf.sol +0 -260
  293. package/test/units/static/JBRulesets/TestRulesets.sol +0 -632
  294. package/test/units/static/JBRulesets/TestRulesetsOf.sol +0 -37
  295. package/test/units/static/JBRulesets/TestUpcomingRulesetOf.sol +0 -522
  296. package/test/units/static/JBRulesets/TestUpdateRulesetWeightCache.sol +0 -96
  297. package/test/units/static/JBSplits/JBSplitsSetup.sol +0 -26
  298. package/test/units/static/JBSplits/TestSelfManagedSplitGroups.sol +0 -552
  299. package/test/units/static/JBSplits/TestSetSplitGroupsOf.sol +0 -377
  300. package/test/units/static/JBSplits/TestSplitsLockedEdge.sol +0 -267
  301. package/test/units/static/JBSplits/TestSplitsOf.sol +0 -24
  302. package/test/units/static/JBSplits/TestSplitsPacking.sol +0 -36
  303. package/test/units/static/JBSurplus/TestSurplusFuzz.sol +0 -160
  304. package/test/units/static/JBTerminalStore/JBTerminalStoreSetup.sol +0 -45
  305. package/test/units/static/JBTerminalStore/TestCurrentReclaimableSurplusOf.sol +0 -536
  306. package/test/units/static/JBTerminalStore/TestCurrentSurplusOf.sol +0 -463
  307. package/test/units/static/JBTerminalStore/TestCurrentTotalSurplusOf.sol +0 -135
  308. package/test/units/static/JBTerminalStore/TestPreviewCashOutFrom.sol +0 -476
  309. package/test/units/static/JBTerminalStore/TestPreviewPayFrom.sol +0 -494
  310. package/test/units/static/JBTerminalStore/TestRecordCashOutsFor.sol +0 -652
  311. package/test/units/static/JBTerminalStore/TestRecordPaymentFrom.sol +0 -744
  312. package/test/units/static/JBTerminalStore/TestRecordPayoutFor.sol +0 -289
  313. package/test/units/static/JBTerminalStore/TestRecordTerminalMigration.sol +0 -138
  314. package/test/units/static/JBTerminalStore/TestRecordUsedAllowanceOf.sol +0 -415
  315. package/test/units/static/JBTerminalStore/TestUint224Overflow.sol +0 -219
  316. package/test/units/static/JBTokens/JBTokensSetup.sol +0 -32
  317. package/test/units/static/JBTokens/TestBurnFrom.sol +0 -107
  318. package/test/units/static/JBTokens/TestClaimTokensFor.sol +0 -110
  319. package/test/units/static/JBTokens/TestDeployERC20ForUnits.sol +0 -92
  320. package/test/units/static/JBTokens/TestMintFor.sol +0 -100
  321. package/test/units/static/JBTokens/TestSetTokenFor.sol +0 -98
  322. package/test/units/static/JBTokens/TestTotalBalanceOf.sol +0 -65
  323. package/test/units/static/JBTokens/TestTotalSupplyOf.sol +0 -56
  324. package/test/units/static/JBTokens/TestTransferCreditsFrom.sol +0 -56
package/test/TestFees.sol DELETED
@@ -1,619 +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 {IJBMultiTerminal} from "../src/interfaces/IJBMultiTerminal.sol";
7
- import {IJBRulesetApprovalHook} from "../src/interfaces/IJBRulesetApprovalHook.sol";
8
- import {IJBRulesets} from "../src/interfaces/IJBRulesets.sol";
9
- import {JBConstants} from "../src/libraries/JBConstants.sol";
10
- import {JBAccountingContext} from "../src/structs/JBAccountingContext.sol";
11
- import {JBCurrencyAmount} from "../src/structs/JBCurrencyAmount.sol";
12
- import {JBFee} from "../src/structs/JBFee.sol";
13
- import {JBFundAccessLimitGroup} from "../src/structs/JBFundAccessLimitGroup.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
- // Projects can be launched.
20
- contract TestFees_Local is TestBaseWorkflow {
21
- IJBController private _controller;
22
- JBRulesetMetadata private _metadata;
23
- JBRulesetMetadata private _feeProjectMetadata;
24
- IJBMultiTerminal private _terminal;
25
- IJBMultiTerminal private _terminal2;
26
- IJBRulesets private _rulesets;
27
-
28
- uint224 _nativePayAmount;
29
- uint224 _nativeDistLimit;
30
-
31
- uint256 private _projectId;
32
- address private _projectOwner;
33
- address private _beneficiary;
34
-
35
- function setUp() public override {
36
- super.setUp();
37
-
38
- _projectOwner = multisig();
39
- _beneficiary = beneficiary();
40
- _terminal = jbMultiTerminal();
41
- _terminal2 = jbMultiTerminal2();
42
- _controller = jbController();
43
- _rulesets = jbRulesets();
44
- _nativePayAmount = 2 ether;
45
- _nativeDistLimit = 1 ether;
46
-
47
- _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: false,
57
- ownerMustSendPayouts: false,
58
- allowSetController: false,
59
- allowAddAccountingContext: true,
60
- allowAddPriceFeed: false,
61
- holdFees: true,
62
- useTotalSurplusForCashOuts: false,
63
- useDataHookForPay: false,
64
- useDataHookForCashOut: false,
65
- dataHook: address(0),
66
- metadata: 0
67
- });
68
-
69
- _feeProjectMetadata = JBRulesetMetadata({
70
- reservedPercent: 0,
71
- cashOutTaxRate: 0,
72
- baseCurrency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
73
- pausePay: false,
74
- pauseCreditTransfers: false,
75
- allowOwnerMinting: false,
76
- allowSetCustomToken: false,
77
- allowTerminalMigration: true,
78
- allowSetTerminals: false,
79
- ownerMustSendPayouts: false,
80
- allowSetController: false,
81
- allowAddAccountingContext: true,
82
- allowAddPriceFeed: false,
83
- holdFees: true,
84
- useTotalSurplusForCashOuts: false,
85
- useDataHookForPay: false,
86
- useDataHookForCashOut: false,
87
- dataHook: address(0),
88
- metadata: 0
89
- });
90
-
91
- // Package up the limits for the given terminal.
92
- JBFundAccessLimitGroup[] memory _fundAccessLimitGroupProjectOne = new JBFundAccessLimitGroup[](1);
93
- {
94
- // Specify a payout limit.
95
- JBCurrencyAmount[] memory _payoutLimits = new JBCurrencyAmount[](1);
96
- _payoutLimits[0] = JBCurrencyAmount({amount: 2 ether, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))});
97
-
98
- // Specify a surplus allowance.
99
- JBCurrencyAmount[] memory _surplusAllowances = new JBCurrencyAmount[](1);
100
- _surplusAllowances[0] = JBCurrencyAmount({amount: 0, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))});
101
-
102
- _fundAccessLimitGroupProjectOne[0] = JBFundAccessLimitGroup({
103
- terminal: address(_terminal),
104
- token: JBConstants.NATIVE_TOKEN,
105
- payoutLimits: _payoutLimits,
106
- surplusAllowances: _surplusAllowances
107
- });
108
- }
109
-
110
- JBFundAccessLimitGroup[] memory _fundAccessLimitGroupProjectTwo = new JBFundAccessLimitGroup[](1);
111
- {
112
- // Specify a payout limit.
113
- JBCurrencyAmount[] memory _payoutLimits = new JBCurrencyAmount[](1);
114
- _payoutLimits[0] =
115
- JBCurrencyAmount({amount: _nativeDistLimit, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))});
116
-
117
- // Specify a surplus allowance.
118
- JBCurrencyAmount[] memory _surplusAllowances = new JBCurrencyAmount[](1);
119
- _surplusAllowances[0] =
120
- JBCurrencyAmount({amount: _nativeDistLimit, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))});
121
-
122
- _fundAccessLimitGroupProjectTwo[0] = JBFundAccessLimitGroup({
123
- terminal: address(_terminal),
124
- token: JBConstants.NATIVE_TOKEN,
125
- payoutLimits: _payoutLimits,
126
- surplusAllowances: _surplusAllowances
127
- });
128
- }
129
-
130
- // Package up ruleset configuration.
131
- JBRulesetConfig[] memory _feeProjectRuleset = new JBRulesetConfig[](1);
132
- _feeProjectRuleset[0].mustStartAtOrAfter = 0;
133
- _feeProjectRuleset[0].duration = 0;
134
- _feeProjectRuleset[0].weight = 0;
135
- _feeProjectRuleset[0].weightCutPercent = 0;
136
- _feeProjectRuleset[0].approvalHook = IJBRulesetApprovalHook(address(0));
137
- _feeProjectRuleset[0].metadata = _feeProjectMetadata;
138
- _feeProjectRuleset[0].splitGroups = new JBSplitGroup[](0);
139
- _feeProjectRuleset[0].fundAccessLimitGroups = _fundAccessLimitGroupProjectOne;
140
-
141
- // Package up ruleset configuration.
142
- JBRulesetConfig[] memory _rulesetConfig = new JBRulesetConfig[](1);
143
- _rulesetConfig[0].mustStartAtOrAfter = 0;
144
- _rulesetConfig[0].duration = 0;
145
- _rulesetConfig[0].weight = 0;
146
- _rulesetConfig[0].weightCutPercent = 0;
147
- _rulesetConfig[0].approvalHook = IJBRulesetApprovalHook(address(0));
148
- _rulesetConfig[0].metadata = _metadata;
149
- _rulesetConfig[0].splitGroups = new JBSplitGroup[](0);
150
- _rulesetConfig[0].fundAccessLimitGroups = _fundAccessLimitGroupProjectTwo;
151
-
152
- JBTerminalConfig[] memory _terminalConfigurations = new JBTerminalConfig[](2);
153
-
154
- JBAccountingContext[] memory _tokensToAccept = new JBAccountingContext[](1);
155
- _tokensToAccept[0] = JBAccountingContext({
156
- token: JBConstants.NATIVE_TOKEN, decimals: 18, currency: uint32(uint160(JBConstants.NATIVE_TOKEN))
157
- });
158
-
159
- _terminalConfigurations[0] =
160
- JBTerminalConfig({terminal: _terminal, accountingContextsToAccept: _tokensToAccept});
161
- _terminalConfigurations[1] =
162
- JBTerminalConfig({terminal: _terminal2, accountingContextsToAccept: _tokensToAccept});
163
-
164
- // Dummy project that receive fees.
165
- _controller.launchProjectFor({
166
- owner: _projectOwner,
167
- projectUri: "myIPFSHash",
168
- rulesetConfigurations: _feeProjectRuleset,
169
- terminalConfigurations: _terminalConfigurations,
170
- memo: ""
171
- });
172
-
173
- _projectId = _controller.launchProjectFor({
174
- owner: _projectOwner,
175
- projectUri: "myIPFSHash",
176
- rulesetConfigurations: _rulesetConfig,
177
- terminalConfigurations: _terminalConfigurations,
178
- memo: ""
179
- });
180
- }
181
-
182
- function testHeldFeeIsProcessedOnMigrate() public {
183
- // Setup: Pay so we have balance to use
184
- _terminal.pay{value: _nativePayAmount}({
185
- projectId: _projectId,
186
- amount: _nativePayAmount,
187
- token: JBConstants.NATIVE_TOKEN,
188
- beneficiary: _beneficiary,
189
- minReturnedTokens: 0,
190
- memo: "",
191
- metadata: new bytes(0)
192
- });
193
-
194
- // Setup: use allowance so we incur a fee
195
- vm.startPrank(_projectOwner);
196
- _terminal.useAllowanceOf({
197
- projectId: _projectId,
198
- amount: _nativeDistLimit,
199
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
200
- token: JBConstants.NATIVE_TOKEN,
201
- minTokensPaidOut: 0,
202
- beneficiary: payable(_projectOwner),
203
- feeBeneficiary: payable(_projectOwner),
204
- memo: "MEMO"
205
- });
206
-
207
- // Calculate the fee from the allowance use.
208
- uint256 _feeAmount = _nativeDistLimit * _terminal.FEE() / JBConstants.MAX_FEE;
209
-
210
- uint256 _afterFee = _nativeDistLimit - _feeAmount;
211
-
212
- // Check: Owner balance is accurate (dist - fee) and fee is in the terminal (held but not processed)
213
- assertEq(_projectOwner.balance, _afterFee);
214
- assertEq(address(_terminal).balance, _nativeDistLimit + _feeAmount);
215
-
216
- // Send: Migration to terminal2
217
- _terminal.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, _terminal2);
218
-
219
- // Check: Held fee remains in terminal, plus migration fee paid to fee project (on same terminal)
220
- uint256 _migrationFee = _nativeDistLimit * _terminal.FEE() / JBConstants.MAX_FEE;
221
- assertEq(address(_terminal).balance, _feeAmount + _migrationFee);
222
-
223
- vm.stopPrank();
224
- }
225
-
226
- function testHeldFeeRepaymentWithMigration() public {
227
- // Setup: Pay so we have balance to use
228
- _terminal.pay{value: _nativePayAmount}({
229
- projectId: _projectId,
230
- amount: _nativePayAmount,
231
- token: JBConstants.NATIVE_TOKEN,
232
- beneficiary: _beneficiary,
233
- minReturnedTokens: 0,
234
- memo: "",
235
- metadata: new bytes(0)
236
- });
237
-
238
- // Setup: use allowance so we incur a fee
239
- vm.startPrank(_projectOwner);
240
- _terminal.useAllowanceOf({
241
- projectId: _projectId,
242
- amount: _nativeDistLimit,
243
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
244
- token: JBConstants.NATIVE_TOKEN,
245
- minTokensPaidOut: 0,
246
- beneficiary: payable(_projectOwner),
247
- feeBeneficiary: payable(_projectOwner),
248
- memo: "MEMO"
249
- });
250
-
251
- // Calculate the fee from the allowance use.
252
- uint256 _feeAmount = _nativeDistLimit * _terminal.FEE() / JBConstants.MAX_FEE;
253
-
254
- uint256 _afterFee = _nativeDistLimit - _feeAmount;
255
-
256
- // Check: Owner balance is accurate (dist - fee) and fee is in the terminal (held but not processed)
257
- assertEq(_projectOwner.balance, _afterFee);
258
- assertEq(address(_terminal).balance, _nativeDistLimit + _feeAmount);
259
-
260
- vm.startPrank(_projectOwner);
261
- // Setup: addToBalance to reset our held fees
262
- _terminal.addToBalanceOf{value: _nativeDistLimit - _feeAmount}(
263
- _projectId, JBConstants.NATIVE_TOKEN, _nativeDistLimit - _feeAmount, true, "forge test", ""
264
- );
265
-
266
- // Send: Migration to terminal2
267
- _terminal.migrateBalanceOf(_projectId, JBConstants.NATIVE_TOKEN, _terminal2);
268
-
269
- // Check: Held fee has been repaid. Migration fee paid to fee project remains on this terminal.
270
- uint256 _migrationFee = _nativePayAmount * _terminal.FEE() / JBConstants.MAX_FEE;
271
- assertEq(address(_terminal).balance, _migrationFee);
272
-
273
- vm.stopPrank();
274
- }
275
-
276
- function testHeldFeeUnlockAndProcess() public {
277
- // Setup: Pay so we have balance to use
278
- _terminal.pay{value: _nativePayAmount}({
279
- projectId: _projectId,
280
- amount: _nativePayAmount,
281
- token: JBConstants.NATIVE_TOKEN,
282
- beneficiary: _beneficiary,
283
- minReturnedTokens: 0,
284
- memo: "",
285
- metadata: new bytes(0)
286
- });
287
-
288
- // Setup: use allowance so we incur a fee
289
- vm.startPrank(_projectOwner);
290
- _terminal.useAllowanceOf({
291
- projectId: _projectId,
292
- amount: _nativeDistLimit,
293
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
294
- token: JBConstants.NATIVE_TOKEN,
295
- minTokensPaidOut: 0,
296
- beneficiary: payable(_projectOwner),
297
- feeBeneficiary: payable(_projectOwner),
298
- memo: "MEMO"
299
- });
300
-
301
- // Calculate the fee from the allowance use.
302
- uint256 _feeAmount = _nativeDistLimit * _terminal.FEE() / JBConstants.MAX_FEE;
303
-
304
- uint256 _afterFee = _nativeDistLimit - _feeAmount;
305
-
306
- // Check: Owner balance is accurate (dist - fee) and fee is in the terminal (held but not processed)
307
- assertEq(_projectOwner.balance, _afterFee);
308
- assertEq(address(_terminal).balance, _nativeDistLimit + _feeAmount);
309
-
310
- // Setup: fast-forward to when fees can be processed
311
- vm.warp(block.timestamp + 2_419_200);
312
-
313
- // Send: Process the fees
314
- _terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
315
-
316
- // Check: Reflected in terminal
317
- JBFee[] memory _emptyFee = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
318
- assertEq(_emptyFee.length, 0);
319
- }
320
-
321
- function testDoubleHeldFeeUnlockAndProcess() public {
322
- // Setup: Pay so we have balance to use.
323
- _terminal.pay{value: _nativePayAmount}({
324
- projectId: _projectId,
325
- amount: _nativePayAmount,
326
- token: JBConstants.NATIVE_TOKEN,
327
- beneficiary: _beneficiary,
328
- minReturnedTokens: 0,
329
- memo: "",
330
- metadata: new bytes(0)
331
- });
332
-
333
- // Half the dist limit to be able to use allowance twice.
334
- uint256 _halfDistLimit = _nativeDistLimit / 2;
335
-
336
- // Setup: use allowance so we incur a fee
337
- vm.startPrank(_projectOwner);
338
- _terminal.useAllowanceOf({
339
- projectId: _projectId,
340
- amount: _halfDistLimit,
341
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
342
- token: JBConstants.NATIVE_TOKEN,
343
- minTokensPaidOut: 0,
344
- beneficiary: payable(_projectOwner),
345
- feeBeneficiary: payable(_projectOwner),
346
- memo: "MEMO"
347
- });
348
- // Setup: use allowance so we incur a fee
349
- vm.startPrank(_projectOwner);
350
- _terminal.useAllowanceOf({
351
- projectId: _projectId,
352
- amount: _halfDistLimit,
353
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
354
- token: JBConstants.NATIVE_TOKEN,
355
- minTokensPaidOut: 0,
356
- beneficiary: payable(_projectOwner),
357
- feeBeneficiary: payable(_projectOwner),
358
- memo: "MEMO"
359
- });
360
-
361
- // Calculate the fee from the allowance use.
362
- uint256 _feeAmount = _halfDistLimit * _terminal.FEE() / JBConstants.MAX_FEE;
363
-
364
- uint256 _afterFee = (_halfDistLimit - _feeAmount) * 2;
365
-
366
- // Check: Owner balance is accurate (dist - fee) and fee is in the terminal (held but not processed)
367
- assertEq(_projectOwner.balance, _afterFee);
368
- assertEq(address(_terminal).balance, _nativeDistLimit + (_feeAmount * 2));
369
-
370
- // Setup: fast-forward to when fees can be processed
371
- vm.warp(block.timestamp + 2_419_200);
372
-
373
- // Send: Process the fees
374
- _terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 2);
375
-
376
- // Check: Reflected in terminal
377
- JBFee[] memory _emptyFee = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
378
- assertEq(_emptyFee.length, 0);
379
- }
380
-
381
- function testDoubleSequentialHeldFeeUnlockAndProcess() public {
382
- // Setup: Pay so we have balance to use.
383
- _terminal.pay{value: _nativePayAmount}({
384
- projectId: _projectId,
385
- amount: _nativePayAmount,
386
- token: JBConstants.NATIVE_TOKEN,
387
- beneficiary: _beneficiary,
388
- minReturnedTokens: 0,
389
- memo: "",
390
- metadata: new bytes(0)
391
- });
392
-
393
- // Half the dist limit to be able to use allowance twice.
394
- uint256 _halfDistLimit = _nativeDistLimit / 2;
395
-
396
- // Setup: use allowance so we incur a fee
397
- vm.startPrank(_projectOwner);
398
- _terminal.useAllowanceOf({
399
- projectId: _projectId,
400
- amount: _halfDistLimit,
401
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
402
- token: JBConstants.NATIVE_TOKEN,
403
- minTokensPaidOut: 0,
404
- beneficiary: payable(_projectOwner),
405
- feeBeneficiary: payable(_projectOwner),
406
- memo: "MEMO"
407
- });
408
- // Setup: use allowance so we incur a fee
409
- vm.startPrank(_projectOwner);
410
- _terminal.useAllowanceOf({
411
- projectId: _projectId,
412
- amount: _halfDistLimit,
413
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
414
- token: JBConstants.NATIVE_TOKEN,
415
- minTokensPaidOut: 0,
416
- beneficiary: payable(_projectOwner),
417
- feeBeneficiary: payable(_projectOwner),
418
- memo: "MEMO"
419
- });
420
-
421
- // Calculate the fee from the allowance use.
422
- uint256 _feeAmount = _halfDistLimit * _terminal.FEE() / JBConstants.MAX_FEE;
423
-
424
- uint256 _afterFee = (_halfDistLimit - _feeAmount) * 2;
425
-
426
- // Check: Owner balance is accurate (dist - fee) and fee is in the terminal (held but not processed)
427
- assertEq(_projectOwner.balance, _afterFee);
428
- assertEq(address(_terminal).balance, _nativeDistLimit + (_feeAmount * 2));
429
-
430
- // Setup: fast-forward to when fees can be processed
431
- vm.warp(block.timestamp + 2_419_200);
432
-
433
- // Send: Process the fees
434
- _terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 1);
435
-
436
- // Check: Reflected in terminal
437
- JBFee[] memory _oneFee = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
438
- assertEq(_oneFee.length, 1);
439
-
440
- // Send: Process the fees
441
- _terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 1);
442
-
443
- // Check: Reflected in terminal
444
- JBFee[] memory _emptyFee = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
445
- assertEq(_emptyFee.length, 0);
446
- }
447
-
448
- function testHeldFeeUnlockTooSoon() public {
449
- // Setup: Pay so we have balance to use
450
- _terminal.pay{value: _nativePayAmount}({
451
- projectId: _projectId,
452
- amount: _nativePayAmount,
453
- token: JBConstants.NATIVE_TOKEN,
454
- beneficiary: _beneficiary,
455
- minReturnedTokens: 0,
456
- memo: "",
457
- metadata: new bytes(0)
458
- });
459
-
460
- // Setup: use allowance so we incur a fee
461
- vm.prank(_projectOwner);
462
- _terminal.useAllowanceOf({
463
- projectId: _projectId,
464
- amount: _nativeDistLimit,
465
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
466
- token: JBConstants.NATIVE_TOKEN,
467
- minTokensPaidOut: 0,
468
- beneficiary: payable(_projectOwner),
469
- feeBeneficiary: payable(_projectOwner),
470
- memo: "MEMO"
471
- });
472
-
473
- // Calculate the fee from the allowance use.
474
- uint256 _feeAmount = _nativeDistLimit * _terminal.FEE() / JBConstants.MAX_FEE;
475
-
476
- uint256 _afterFee = _nativeDistLimit - _feeAmount;
477
-
478
- // Check: Owner balance is accurate (dist - fee) and fee is in the terminal (held but not processed)
479
- assertEq(_projectOwner.balance, _afterFee);
480
- assertEq(address(_terminal).balance, _nativeDistLimit + _feeAmount);
481
-
482
- // Check: Heldfee unlock timestamp
483
- JBFee[] memory _checkOgFee = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
484
- assertEq(_checkOgFee[0].unlockTimestamp, block.timestamp + 2_419_200);
485
-
486
- // Setup: fast-forward to next block where fee shouldn't process (too early)
487
- vm.warp(block.timestamp + 1);
488
-
489
- // Send: Fail to process the fees
490
- _terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
491
-
492
- // Check: Fee persists in terminal
493
- JBFee[] memory _persistingFee = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
494
-
495
- // Wher go fee..?
496
- assertEq(_persistingFee.length, 1);
497
- }
498
-
499
- function test_doubleFeeEdgeCase() external {
500
- vm.skip(true);
501
-
502
- // Setup: Pay the zero project so the terminal has balance of 1 eth from another project.
503
- _terminal.pay{value: 1 ether}({
504
- projectId: 1,
505
- amount: _nativePayAmount,
506
- token: JBConstants.NATIVE_TOKEN,
507
- beneficiary: _beneficiary,
508
- minReturnedTokens: 0,
509
- memo: "",
510
- metadata: new bytes(0)
511
- });
512
-
513
- // Setup: Pay project 2 so we have balance to use
514
- _terminal.pay{value: 1 ether}({
515
- projectId: _projectId,
516
- amount: _nativePayAmount,
517
- token: JBConstants.NATIVE_TOKEN,
518
- beneficiary: _beneficiary,
519
- minReturnedTokens: 0,
520
- memo: "",
521
- metadata: new bytes(0)
522
- });
523
-
524
- uint256 prevBalance = _projectOwner.balance;
525
-
526
- // Ensure we start with zero balance before payout
527
- assertEq(prevBalance, 0);
528
-
529
- // Send payout
530
- // So you don't have to scroll up, _nativeDistAmount = 1 ether.
531
- _terminal.sendPayoutsOf(
532
- _projectId,
533
- JBConstants.NATIVE_TOKEN,
534
- _nativeDistLimit,
535
- uint32(uint160(JBConstants.NATIVE_TOKEN)),
536
- _nativeDistLimit
537
- );
538
-
539
- // Ensure the payout was successful
540
- uint256 _feeAmount =
541
- _nativeDistLimit - _nativeDistLimit * JBConstants.MAX_FEE / (_terminal.FEE() + JBConstants.MAX_FEE);
542
- uint256 _afterFee = _nativeDistLimit - _feeAmount;
543
- assertEq(_projectOwner.balance, _afterFee);
544
-
545
- // Terminal has accepted 2 pays (totaling 2 eth), payout of nativeDistLimit (1eth) was sent, and fee was taken.
546
- // So we only have 1 eth and the fee taken left in the terminal.
547
- assertEq(address(_terminal).balance, _nativeDistLimit + _feeAmount);
548
-
549
- // Check the fee attributes
550
- JBFee[] memory _checkOgFee = _terminal.heldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
551
-
552
- // Check the unlock timestamp
553
- assertEq(_checkOgFee[0].unlockTimestamp, block.timestamp + 2_419_200);
554
-
555
- // The fee amount is 1 ETH
556
- assertEq(_checkOgFee[0].amount, _nativeDistLimit);
557
-
558
- // The project's balance in terminal store will be zero.
559
- uint256 project2BalanceStore =
560
- jbTerminalStore().balanceOf(address(_terminal), _projectId, JBConstants.NATIVE_TOKEN);
561
- assertEq(project2BalanceStore, 0);
562
-
563
- // We continue on with the example, where another project carries a balance (1 eth here).
564
- uint256 project1BalanceStore = jbTerminalStore().balanceOf(address(_terminal), 1, JBConstants.NATIVE_TOKEN);
565
- assertEq(project1BalanceStore, 1 ether);
566
-
567
- // Warp to when we can call processHeldFeesOf.
568
- vm.warp(_checkOgFee[0].unlockTimestamp);
569
-
570
- // Accounting should be incorrectly adjusted for the fee project after the process call.
571
- uint256 feeProjectBalanceBefore = project1BalanceStore;
572
-
573
- // Process the held fees, which adds 1 ether 'amount' to the fee project.
574
- _terminal.processHeldFeesOf(_projectId, JBConstants.NATIVE_TOKEN, 100);
575
-
576
- // Reference the balance now (for the fee project).
577
- uint256 feeProjectBalanceAfter = jbTerminalStore().balanceOf(address(_terminal), 1, JBConstants.NATIVE_TOKEN);
578
-
579
- // Fee project now has a balance of 2 eth even though it has only been paid one eth.
580
- assertEq(feeProjectBalanceAfter, 2 ether);
581
- assertGt(feeProjectBalanceAfter, feeProjectBalanceBefore);
582
-
583
- // Pay project 2 again so the terminal holds enough balance for the excess usage via the fee project.
584
- _terminal.pay{value: 1 ether}({
585
- projectId: _projectId,
586
- amount: _nativePayAmount,
587
- token: JBConstants.NATIVE_TOKEN,
588
- beneficiary: _beneficiary,
589
- minReturnedTokens: 0,
590
- memo: "",
591
- metadata: new bytes(0)
592
- });
593
-
594
- // Reference the owner balance before payout.
595
- uint256 ownerBalanceBefore = _projectOwner.balance;
596
-
597
- // Now we see if we can use the 2 ether minus fees via project 1.
598
- uint256 paidOutFromProjectOne = _terminal.sendPayoutsOf({
599
- projectId: 1,
600
- token: JBConstants.NATIVE_TOKEN,
601
- amount: 2 ether,
602
- currency: uint32(uint160(JBConstants.NATIVE_TOKEN)),
603
- minTokensPaidOut: 0
604
- });
605
-
606
- // Calculate the fee from the allowance use.
607
- uint256 _feeAmount2 = paidOutFromProjectOne - paidOutFromProjectOne * JBConstants.MAX_FEE
608
- / (_terminal.FEE() + JBConstants.MAX_FEE);
609
-
610
- // The payout happens as described in the example.
611
- uint256 _afterFee2 = paidOutFromProjectOne - _feeAmount2;
612
- assertEq(_projectOwner.balance - ownerBalanceBefore, _afterFee2);
613
-
614
- // Confirm the total terminal balance < the balance of project 2.
615
- uint256 balanceOfProject2 =
616
- jbTerminalStore().balanceOf(address(_terminal), _projectId, JBConstants.NATIVE_TOKEN);
617
- assertLt(address(_terminal).balance, balanceOfProject2);
618
- }
619
- }