@boostxyz/sdk 0.0.0-alpha.2 → 0.0.0-alpha.21

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 (271) hide show
  1. package/dist/Actions/Action.cjs +2 -1
  2. package/dist/Actions/Action.cjs.map +1 -0
  3. package/dist/Actions/Action.d.ts +1 -1
  4. package/dist/Actions/Action.d.ts.map +1 -1
  5. package/dist/Actions/Action.js +14 -12
  6. package/dist/Actions/Action.js.map +1 -0
  7. package/dist/Actions/ContractAction.d.ts +57 -14
  8. package/dist/Actions/ContractAction.d.ts.map +1 -1
  9. package/dist/Actions/ERC721MintAction.d.ts +50 -23
  10. package/dist/Actions/ERC721MintAction.d.ts.map +1 -1
  11. package/dist/Actions/EventAction.cjs +2 -1
  12. package/dist/Actions/EventAction.cjs.map +1 -0
  13. package/dist/Actions/EventAction.d.ts +405 -36
  14. package/dist/Actions/EventAction.d.ts.map +1 -1
  15. package/dist/Actions/EventAction.js +15 -209
  16. package/dist/Actions/EventAction.js.map +1 -0
  17. package/dist/AllowLists/AllowList.cjs +2 -1
  18. package/dist/AllowLists/AllowList.cjs.map +1 -0
  19. package/dist/AllowLists/AllowList.d.ts +6 -5
  20. package/dist/AllowLists/AllowList.d.ts.map +1 -1
  21. package/dist/AllowLists/AllowList.js +46 -22
  22. package/dist/AllowLists/AllowList.js.map +1 -0
  23. package/dist/AllowLists/OpenAllowList.d.ts +423 -0
  24. package/dist/AllowLists/OpenAllowList.d.ts.map +1 -0
  25. package/dist/AllowLists/SimpleAllowList.cjs +2 -1
  26. package/dist/AllowLists/SimpleAllowList.cjs.map +1 -0
  27. package/dist/AllowLists/SimpleAllowList.d.ts +124 -40
  28. package/dist/AllowLists/SimpleAllowList.d.ts.map +1 -1
  29. package/dist/AllowLists/SimpleAllowList.js +76 -76
  30. package/dist/AllowLists/SimpleAllowList.js.map +1 -0
  31. package/dist/AllowLists/SimpleDenyList.cjs +2 -1
  32. package/dist/AllowLists/SimpleDenyList.cjs.map +1 -0
  33. package/dist/AllowLists/SimpleDenyList.d.ts +234 -13
  34. package/dist/AllowLists/SimpleDenyList.d.ts.map +1 -1
  35. package/dist/AllowLists/SimpleDenyList.js +12 -200
  36. package/dist/AllowLists/SimpleDenyList.js.map +1 -0
  37. package/dist/Auth/Auth.cjs +1 -0
  38. package/dist/Auth/Auth.cjs.map +1 -0
  39. package/dist/Auth/Auth.js +1 -0
  40. package/dist/Auth/Auth.js.map +1 -0
  41. package/dist/Auth/PassthroughAuth.cjs +2 -1
  42. package/dist/Auth/PassthroughAuth.cjs.map +1 -0
  43. package/dist/Auth/PassthroughAuth.js +5 -4
  44. package/dist/Auth/PassthroughAuth.js.map +1 -0
  45. package/dist/Boost.cjs +2 -1
  46. package/dist/Boost.cjs.map +1 -0
  47. package/dist/Boost.d.ts +105 -14
  48. package/dist/Boost.d.ts.map +1 -1
  49. package/dist/Boost.js +138 -5
  50. package/dist/Boost.js.map +1 -0
  51. package/dist/BoostCore-DolmDuXW.cjs +3 -0
  52. package/dist/BoostCore-DolmDuXW.cjs.map +1 -0
  53. package/dist/BoostCore-Z97KVu4V.js +1448 -0
  54. package/dist/BoostCore-Z97KVu4V.js.map +1 -0
  55. package/dist/BoostCore.cjs +2 -2
  56. package/dist/BoostCore.cjs.map +1 -0
  57. package/dist/BoostCore.d.ts +788 -79
  58. package/dist/BoostCore.d.ts.map +1 -1
  59. package/dist/BoostCore.js +30 -1103
  60. package/dist/BoostCore.js.map +1 -0
  61. package/dist/BoostRegistry.cjs +2 -1
  62. package/dist/BoostRegistry.cjs.map +1 -0
  63. package/dist/BoostRegistry.d.ts +95 -26
  64. package/dist/BoostRegistry.d.ts.map +1 -1
  65. package/dist/BoostRegistry.js +183 -89
  66. package/dist/BoostRegistry.js.map +1 -0
  67. package/dist/Budgets/Budget.cjs +2 -1
  68. package/dist/Budgets/Budget.cjs.map +1 -0
  69. package/dist/Budgets/Budget.d.ts +1 -1
  70. package/dist/Budgets/Budget.d.ts.map +1 -1
  71. package/dist/Budgets/Budget.js +15 -13
  72. package/dist/Budgets/Budget.js.map +1 -0
  73. package/dist/Budgets/ManagedBudget.cjs +2 -1
  74. package/dist/Budgets/ManagedBudget.cjs.map +1 -0
  75. package/dist/Budgets/ManagedBudget.d.ts +112 -192
  76. package/dist/Budgets/ManagedBudget.d.ts.map +1 -1
  77. package/dist/Budgets/ManagedBudget.js +91 -291
  78. package/dist/Budgets/ManagedBudget.js.map +1 -0
  79. package/dist/Budgets/VestingBudget.d.ts +277 -91
  80. package/dist/Budgets/VestingBudget.d.ts.map +1 -1
  81. package/dist/Deployable/Contract.cjs +2 -1
  82. package/dist/Deployable/Contract.cjs.map +1 -0
  83. package/dist/Deployable/Contract.d.ts +4 -5
  84. package/dist/Deployable/Contract.d.ts.map +1 -1
  85. package/dist/Deployable/Contract.js +7 -8
  86. package/dist/Deployable/Contract.js.map +1 -0
  87. package/dist/Deployable/Deployable.cjs +1 -0
  88. package/dist/Deployable/Deployable.cjs.map +1 -0
  89. package/dist/Deployable/Deployable.d.ts +9 -3
  90. package/dist/Deployable/Deployable.d.ts.map +1 -1
  91. package/dist/Deployable/Deployable.js +10 -5
  92. package/dist/Deployable/Deployable.js.map +1 -0
  93. package/dist/Deployable/DeployableTarget.cjs +2 -1
  94. package/dist/Deployable/DeployableTarget.cjs.map +1 -0
  95. package/dist/Deployable/DeployableTarget.d.ts +16 -15
  96. package/dist/Deployable/DeployableTarget.d.ts.map +1 -1
  97. package/dist/Deployable/DeployableTarget.js +49 -42
  98. package/dist/Deployable/DeployableTarget.js.map +1 -0
  99. package/dist/Deployable/DeployableTargetWithRBAC.cjs +2 -0
  100. package/dist/Deployable/DeployableTargetWithRBAC.cjs.map +1 -0
  101. package/dist/Deployable/DeployableTargetWithRBAC.d.ts +179 -0
  102. package/dist/Deployable/DeployableTargetWithRBAC.d.ts.map +1 -0
  103. package/dist/Deployable/DeployableTargetWithRBAC.js +222 -0
  104. package/dist/Deployable/DeployableTargetWithRBAC.js.map +1 -0
  105. package/dist/EventAction-CBKzuNoN.cjs +2 -0
  106. package/dist/EventAction-CBKzuNoN.cjs.map +1 -0
  107. package/dist/EventAction-DWuuc_Qy.js +1528 -0
  108. package/dist/EventAction-DWuuc_Qy.js.map +1 -0
  109. package/dist/Incentive-BxzEtN26.js +298 -0
  110. package/dist/Incentive-BxzEtN26.js.map +1 -0
  111. package/dist/Incentive-CrF3-ayL.cjs +2 -0
  112. package/dist/Incentive-CrF3-ayL.cjs.map +1 -0
  113. package/dist/Incentives/AllowListIncentive.cjs +2 -1
  114. package/dist/Incentives/AllowListIncentive.cjs.map +1 -0
  115. package/dist/Incentives/AllowListIncentive.d.ts +65 -21
  116. package/dist/Incentives/AllowListIncentive.d.ts.map +1 -1
  117. package/dist/Incentives/AllowListIncentive.js +52 -36
  118. package/dist/Incentives/AllowListIncentive.js.map +1 -0
  119. package/dist/Incentives/CGDAIncentive.cjs +2 -1
  120. package/dist/Incentives/CGDAIncentive.cjs.map +1 -0
  121. package/dist/Incentives/CGDAIncentive.d.ts +315 -26
  122. package/dist/Incentives/CGDAIncentive.d.ts.map +1 -1
  123. package/dist/Incentives/CGDAIncentive.js +64 -39
  124. package/dist/Incentives/CGDAIncentive.js.map +1 -0
  125. package/dist/Incentives/ERC1155Incentive.d.ts +291 -43
  126. package/dist/Incentives/ERC1155Incentive.d.ts.map +1 -1
  127. package/dist/Incentives/ERC20Incentive.cjs +2 -1
  128. package/dist/Incentives/ERC20Incentive.cjs.map +1 -0
  129. package/dist/Incentives/ERC20Incentive.d.ts +270 -33
  130. package/dist/Incentives/ERC20Incentive.d.ts.map +1 -1
  131. package/dist/Incentives/ERC20Incentive.js +69 -46
  132. package/dist/Incentives/ERC20Incentive.js.map +1 -0
  133. package/dist/{Budgets/SimpleBudget.d.ts → Incentives/ERC20VariableCriteriaIncentive.d.ts} +338 -421
  134. package/dist/Incentives/ERC20VariableCriteriaIncentive.d.ts.map +1 -0
  135. package/dist/Incentives/ERC20VariableIncentive.d.ts +262 -32
  136. package/dist/Incentives/ERC20VariableIncentive.d.ts.map +1 -1
  137. package/dist/Incentives/Incentive.cjs +2 -1
  138. package/dist/Incentives/Incentive.cjs.map +1 -0
  139. package/dist/Incentives/Incentive.d.ts +5 -8
  140. package/dist/Incentives/Incentive.d.ts.map +1 -1
  141. package/dist/Incentives/Incentive.js +17 -278
  142. package/dist/Incentives/Incentive.js.map +1 -0
  143. package/dist/Incentives/PointsIncentive.cjs +2 -1
  144. package/dist/Incentives/PointsIncentive.cjs.map +1 -0
  145. package/dist/Incentives/PointsIncentive.d.ts +81 -23
  146. package/dist/Incentives/PointsIncentive.d.ts.map +1 -1
  147. package/dist/Incentives/PointsIncentive.js +57 -36
  148. package/dist/Incentives/PointsIncentive.js.map +1 -0
  149. package/dist/SimpleDenyList-BUR17Tt1.cjs +2 -0
  150. package/dist/SimpleDenyList-BUR17Tt1.cjs.map +1 -0
  151. package/dist/SimpleDenyList-CGaWjuld.js +132 -0
  152. package/dist/SimpleDenyList-CGaWjuld.js.map +1 -0
  153. package/dist/Validators/SignerValidator.cjs +2 -1
  154. package/dist/Validators/SignerValidator.cjs.map +1 -0
  155. package/dist/Validators/SignerValidator.d.ts +310 -17
  156. package/dist/Validators/SignerValidator.d.ts.map +1 -1
  157. package/dist/Validators/SignerValidator.js +165 -36
  158. package/dist/Validators/SignerValidator.js.map +1 -0
  159. package/dist/Validators/Validator.cjs +2 -1
  160. package/dist/Validators/Validator.cjs.map +1 -0
  161. package/dist/Validators/Validator.d.ts +2 -2
  162. package/dist/Validators/Validator.d.ts.map +1 -1
  163. package/dist/Validators/Validator.js +10 -8
  164. package/dist/Validators/Validator.js.map +1 -0
  165. package/dist/claiming.cjs +2 -0
  166. package/dist/claiming.cjs.map +1 -0
  167. package/dist/claiming.d.ts +43 -0
  168. package/dist/claiming.d.ts.map +1 -0
  169. package/dist/claiming.js +17 -0
  170. package/dist/claiming.js.map +1 -0
  171. package/dist/componentInterfaces-BBCFkrZv.js +14 -0
  172. package/dist/componentInterfaces-BBCFkrZv.js.map +1 -0
  173. package/dist/componentInterfaces-DRI_dQ-P.cjs +2 -0
  174. package/dist/componentInterfaces-DRI_dQ-P.cjs.map +1 -0
  175. package/dist/deployments-DVXioW2i.cjs +2 -0
  176. package/dist/deployments-DVXioW2i.cjs.map +1 -0
  177. package/dist/deployments-oykLv3_Z.js +43 -0
  178. package/dist/deployments-oykLv3_Z.js.map +1 -0
  179. package/dist/deployments.json +44 -0
  180. package/dist/errors.cjs +2 -1
  181. package/dist/errors.cjs.map +1 -0
  182. package/dist/errors.d.ts +421 -1
  183. package/dist/errors.d.ts.map +1 -1
  184. package/dist/errors.js +297 -39
  185. package/dist/errors.js.map +1 -0
  186. package/dist/{generated-x_abr3Yv.js → generated-CKt2yCQd.js} +3143 -3002
  187. package/dist/generated-CKt2yCQd.js.map +1 -0
  188. package/dist/generated-CyTNlOwM.cjs +3 -0
  189. package/dist/generated-CyTNlOwM.cjs.map +1 -0
  190. package/dist/index.cjs +2 -1
  191. package/dist/index.cjs.map +1 -0
  192. package/dist/index.d.ts +10 -9
  193. package/dist/index.d.ts.map +1 -1
  194. package/dist/index.js +144 -1353
  195. package/dist/index.js.map +1 -0
  196. package/dist/transfers.cjs +2 -0
  197. package/dist/transfers.cjs.map +1 -0
  198. package/dist/transfers.d.ts +198 -0
  199. package/dist/transfers.d.ts.map +1 -0
  200. package/dist/transfers.js +84 -0
  201. package/dist/transfers.js.map +1 -0
  202. package/dist/utils.cjs +2 -1
  203. package/dist/utils.cjs.map +1 -0
  204. package/dist/utils.d.ts +26 -1350
  205. package/dist/utils.d.ts.map +1 -1
  206. package/dist/utils.js +38 -636
  207. package/dist/utils.js.map +1 -0
  208. package/package.json +37 -11
  209. package/src/Actions/Action.test.ts +79 -0
  210. package/src/Actions/Action.ts +61 -0
  211. package/src/Actions/ContractAction.test.ts +197 -0
  212. package/src/Actions/ContractAction.ts +300 -0
  213. package/src/Actions/ERC721MintAction.test.ts +112 -0
  214. package/src/Actions/ERC721MintAction.ts +291 -0
  215. package/src/Actions/EventAction.test.ts +787 -0
  216. package/src/Actions/EventAction.ts +1218 -0
  217. package/src/AllowLists/AllowList.test.ts +64 -0
  218. package/src/AllowLists/AllowList.ts +62 -0
  219. package/src/AllowLists/OpenAllowList.test.ts +40 -0
  220. package/src/AllowLists/OpenAllowList.ts +45 -0
  221. package/src/AllowLists/SimpleAllowList.test.ts +52 -0
  222. package/src/AllowLists/SimpleAllowList.ts +262 -0
  223. package/src/AllowLists/SimpleDenyList.test.ts +52 -0
  224. package/src/AllowLists/SimpleDenyList.ts +250 -0
  225. package/src/Auth/Auth.ts +11 -0
  226. package/src/Auth/PassthroughAuth.test.ts +12 -0
  227. package/src/Auth/PassthroughAuth.ts +80 -0
  228. package/src/Boost.ts +287 -0
  229. package/src/BoostCore.test.ts +894 -0
  230. package/src/BoostCore.ts +1438 -0
  231. package/src/BoostRegistry.test.ts +53 -0
  232. package/src/BoostRegistry.ts +588 -0
  233. package/src/Budgets/Budget.test.ts +27 -0
  234. package/src/Budgets/Budget.ts +60 -0
  235. package/src/Budgets/ManagedBudget.test.ts +217 -0
  236. package/src/Budgets/ManagedBudget.ts +534 -0
  237. package/src/Budgets/VestingBudget.test.ts +123 -0
  238. package/src/Budgets/VestingBudget.ts +530 -0
  239. package/src/Deployable/Contract.ts +228 -0
  240. package/src/Deployable/Deployable.ts +250 -0
  241. package/src/Deployable/DeployableTarget.ts +234 -0
  242. package/src/Deployable/DeployableTargetWithRBAC.ts +323 -0
  243. package/src/Incentives/AllowListIncentive.test.ts +143 -0
  244. package/src/Incentives/AllowListIncentive.ts +336 -0
  245. package/src/Incentives/CGDAIncentive.test.ts +135 -0
  246. package/src/Incentives/CGDAIncentive.ts +476 -0
  247. package/src/Incentives/ERC1155Incentive.test.ts +87 -0
  248. package/src/Incentives/ERC1155Incentive.ts +465 -0
  249. package/src/Incentives/ERC20Incentive.test.ts +133 -0
  250. package/src/Incentives/ERC20Incentive.ts +490 -0
  251. package/src/Incentives/ERC20VariableCriteriaIncentive.test.ts +184 -0
  252. package/src/Incentives/ERC20VariableCriteriaIncentive.ts +309 -0
  253. package/src/Incentives/ERC20VariableIncentive.test.ts +139 -0
  254. package/src/Incentives/ERC20VariableIncentive.ts +428 -0
  255. package/src/Incentives/Incentive.test.ts +95 -0
  256. package/src/Incentives/Incentive.ts +86 -0
  257. package/src/Incentives/PointsIncentive.test.ts +138 -0
  258. package/src/Incentives/PointsIncentive.ts +367 -0
  259. package/src/Validators/SignerValidator.test.ts +159 -0
  260. package/src/Validators/SignerValidator.ts +683 -0
  261. package/src/Validators/Validator.test.ts +21 -0
  262. package/src/Validators/Validator.ts +55 -0
  263. package/src/claiming.ts +56 -0
  264. package/src/errors.ts +866 -0
  265. package/src/index.test.ts +122 -0
  266. package/src/index.ts +58 -0
  267. package/src/transfers.ts +284 -0
  268. package/src/utils.test.ts +44 -0
  269. package/src/utils.ts +247 -0
  270. package/dist/Budgets/SimpleBudget.d.ts.map +0 -1
  271. package/dist/generated-BaaleHW-.cjs +0 -2
@@ -0,0 +1,60 @@
1
+ import { aBudgetAbi } from '@boostxyz/evm';
2
+ import { AManagedBudget } from '@boostxyz/evm/deploys/componentInterfaces.json';
3
+ import { readContract } from '@wagmi/core';
4
+ import type { Address, Hex } from 'viem';
5
+ import type { DeployableOptions } from '../Deployable/Deployable';
6
+ import { InvalidComponentInterfaceError } from '../errors';
7
+ import { ManagedBudget } from './ManagedBudget';
8
+
9
+ export {
10
+ // VestingBudget,
11
+ ManagedBudget,
12
+ };
13
+
14
+ /**
15
+ * A union type representing all valid protocol Budget implementations
16
+ *
17
+ * @export
18
+ * @typedef {Budget}
19
+ */
20
+ export type Budget = ManagedBudget; // | VestingBudget
21
+
22
+ /**
23
+ * A map of Budget component interfaces to their constructors.
24
+ *
25
+ * @type {{ "0xa0109882": typeof ManagedBudget; }}
26
+ */
27
+ export const BudgetByComponentInterface = {
28
+ // ['0x64683da1']: VestingBudget,
29
+ // ['0x2929d19c']: SimpleBudget,
30
+ [AManagedBudget as Hex]: ManagedBudget,
31
+ };
32
+
33
+ /**
34
+ * A function that will read a contract's component interface using `getComponentInterface` and return the correct instantiated instance.
35
+ *
36
+ * @export
37
+ * @async
38
+ * @param {DeployableOptions} options
39
+ * @param {Address} address
40
+ * @returns {Promise<ManagedBudget>}
41
+ * @throws {@link InvalidComponentInterfaceError}
42
+ */
43
+ export async function budgetFromAddress(
44
+ options: DeployableOptions,
45
+ address: Address,
46
+ ) {
47
+ const interfaceId = (await readContract(options.config, {
48
+ abi: aBudgetAbi,
49
+ functionName: 'getComponentInterface',
50
+ address,
51
+ })) as keyof typeof BudgetByComponentInterface;
52
+ const Ctor = BudgetByComponentInterface[interfaceId];
53
+ if (!Ctor) {
54
+ throw new InvalidComponentInterfaceError(
55
+ Object.keys(BudgetByComponentInterface) as Hex[],
56
+ interfaceId as Hex,
57
+ );
58
+ }
59
+ return new Ctor(options, address);
60
+ }
@@ -0,0 +1,217 @@
1
+ import { writeMockErc1155SetApprovalForAll } from '@boostxyz/evm';
2
+ import { loadFixture } from '@nomicfoundation/hardhat-network-helpers';
3
+ import { isAddress, parseEther, zeroAddress } from 'viem';
4
+ import { beforeAll, beforeEach, describe, expect, test } from 'vitest';
5
+ import type { MockERC20 } from '@boostxyz/test/MockERC20';
6
+ import type { MockERC1155 } from '@boostxyz/test/MockERC1155';
7
+ import { accounts } from '@boostxyz/test/accounts';
8
+ import {
9
+ type Fixtures,
10
+ defaultOptions,
11
+ deployFixtures,
12
+ freshBudget,
13
+ freshManagedBudget,
14
+ fundErc20,
15
+ fundErc1155,
16
+ fundManagedBudget,
17
+ } from '@boostxyz/test/helpers';
18
+ import { testAccount } from '@boostxyz/test/viem';
19
+ import { ManagedBudget, ManagedBudgetRoles } from './ManagedBudget';
20
+
21
+ let fixtures: Fixtures,
22
+ budget: ManagedBudget,
23
+ erc20: MockERC20,
24
+ erc1155: MockERC1155;
25
+
26
+ beforeAll(async () => {
27
+ fixtures = await loadFixture(deployFixtures(defaultOptions));
28
+ });
29
+
30
+ describe('ManagedBudget', () => {
31
+ test('can successfully be deployed', async () => {
32
+ const action = new ManagedBudget(defaultOptions, {
33
+ owner: testAccount.address,
34
+ authorized: [],
35
+ roles: [],
36
+ });
37
+ await action.deploy();
38
+ expect(isAddress(action.assertValidAddress())).toBe(true);
39
+ });
40
+
41
+ test('can grant manager role to many users', async () => {
42
+ const budget = await loadFixture(
43
+ freshManagedBudget(defaultOptions, fixtures),
44
+ );
45
+ const one = accounts[1].account;
46
+ const two = accounts[2].account;
47
+ await budget.setAuthorized([one, two], [true, true]);
48
+ expect(await budget.hasAllRoles(one, ManagedBudgetRoles.ADMIN)).toBe(false);
49
+ expect(await budget.hasAllRoles(one, ManagedBudgetRoles.MANAGER)).toBe(
50
+ true,
51
+ );
52
+ expect(await budget.hasAllRoles(two, ManagedBudgetRoles.MANAGER)).toBe(
53
+ true,
54
+ );
55
+ });
56
+
57
+ test('can grant roles', async () => {
58
+ const budget = await loadFixture(
59
+ freshManagedBudget(defaultOptions, fixtures),
60
+ );
61
+ const admin = accounts[1].account;
62
+ const manager = accounts[2].account;
63
+ await budget.grantRoles(
64
+ [admin, manager],
65
+ [ManagedBudgetRoles.ADMIN, ManagedBudgetRoles.MANAGER],
66
+ );
67
+ expect(await budget.hasAllRoles(admin, ManagedBudgetRoles.ADMIN)).toBe(
68
+ true,
69
+ );
70
+ expect(await budget.hasAllRoles(manager, ManagedBudgetRoles.MANAGER)).toBe(
71
+ true,
72
+ );
73
+ });
74
+
75
+ test('can revoke roles', async () => {
76
+ const budget = await loadFixture(
77
+ freshManagedBudget(defaultOptions, fixtures),
78
+ );
79
+ const admin = accounts[1].account;
80
+ const manager = accounts[2].account;
81
+ await budget.grantRoles(
82
+ [admin, manager],
83
+ [ManagedBudgetRoles.ADMIN, ManagedBudgetRoles.MANAGER],
84
+ );
85
+ await budget.revokeRoles(
86
+ [admin, manager],
87
+ [ManagedBudgetRoles.ADMIN, ManagedBudgetRoles.MANAGER],
88
+ );
89
+ expect(await budget.hasAllRoles(admin, ManagedBudgetRoles.ADMIN)).toBe(
90
+ false,
91
+ );
92
+ expect(await budget.hasAllRoles(manager, ManagedBudgetRoles.MANAGER)).toBe(
93
+ false,
94
+ );
95
+ });
96
+
97
+ test('can be owned', async () => {
98
+ const budget = await loadFixture(
99
+ freshManagedBudget(defaultOptions, fixtures),
100
+ );
101
+ expect(await budget.owner()).toBe(defaultOptions.account.address);
102
+ });
103
+
104
+ test('can have authorized users', async () => {
105
+ const budget = await loadFixture(
106
+ freshManagedBudget(defaultOptions, fixtures),
107
+ );
108
+ expect(await budget.isAuthorized(defaultOptions.account.address)).toBe(
109
+ true,
110
+ );
111
+ expect(await budget.isAuthorized(zeroAddress)).toBe(false);
112
+ });
113
+
114
+ test('can have no initial balance', async () => {
115
+ const budget = await loadFixture(
116
+ freshManagedBudget(defaultOptions, fixtures),
117
+ );
118
+ expect(await budget.available()).toBe(0n);
119
+ });
120
+
121
+ describe('can allocate', () => {
122
+ beforeEach(async () => {
123
+ budget = await loadFixture(freshManagedBudget(defaultOptions, fixtures));
124
+ erc20 = await loadFixture(fundErc20(defaultOptions));
125
+ erc1155 = await loadFixture(fundErc1155(defaultOptions));
126
+ });
127
+
128
+ test('native assets', async () => {
129
+ await budget.allocate(
130
+ {
131
+ amount: parseEther('1.0'),
132
+ asset: zeroAddress,
133
+ target: defaultOptions.account.address,
134
+ },
135
+ {
136
+ value: parseEther('1.0'),
137
+ },
138
+ );
139
+ expect(await budget.available()).toBe(parseEther('1.0'));
140
+ });
141
+
142
+ test('erc20', async () => {
143
+ await erc20.approve(budget.assertValidAddress(), parseEther('110'));
144
+ await budget.allocate({
145
+ amount: parseEther('110'),
146
+ asset: erc20.assertValidAddress(),
147
+ target: defaultOptions.account.address,
148
+ });
149
+ expect(await budget.available(erc20.assertValidAddress())).toBe(
150
+ parseEther('110'),
151
+ );
152
+ });
153
+
154
+ test('erc1155', async () => {
155
+ await writeMockErc1155SetApprovalForAll(defaultOptions.config, {
156
+ args: [budget.assertValidAddress(), true],
157
+ address: erc1155.assertValidAddress(),
158
+ account: defaultOptions.account,
159
+ });
160
+ await budget.allocate({
161
+ tokenId: 1n,
162
+ amount: 110n,
163
+ asset: erc1155.assertValidAddress(),
164
+ target: defaultOptions.account.address,
165
+ });
166
+ expect(await budget.available(erc1155.assertValidAddress(), 1n)).toBe(
167
+ 110n,
168
+ );
169
+ });
170
+ });
171
+
172
+ describe('can disburse', () => {
173
+ beforeEach(async () => {
174
+ const budgetFixtures = await loadFixture(
175
+ fundManagedBudget(defaultOptions, fixtures),
176
+ );
177
+ budget = budgetFixtures.budget as ManagedBudget;
178
+ erc20 = budgetFixtures.erc20;
179
+ erc1155 = budgetFixtures.erc1155;
180
+ });
181
+
182
+ test('native assets', async () => {
183
+ await budget.disburse({
184
+ amount: parseEther('1.0'),
185
+ asset: zeroAddress,
186
+ target: defaultOptions.account.address,
187
+ });
188
+
189
+ expect(await budget.available()).toBe(0n);
190
+ });
191
+
192
+ test('erc20 assets', async () => {
193
+ await budget.disburse({
194
+ amount: parseEther('10'),
195
+ asset: erc20.assertValidAddress(),
196
+ target: defaultOptions.account.address,
197
+ });
198
+
199
+ expect(await budget.available(erc20.assertValidAddress())).toBe(
200
+ parseEther('100'),
201
+ );
202
+ });
203
+
204
+ test('erc1155 assets', async () => {
205
+ await budget.disburse({
206
+ tokenId: 1n,
207
+ amount: 5n,
208
+ asset: erc1155.assertValidAddress(),
209
+ target: defaultOptions.account.address,
210
+ });
211
+
212
+ expect(await budget.available(erc1155.assertValidAddress(), 1n)).to.equal(
213
+ 105n,
214
+ );
215
+ });
216
+ });
217
+ });