@elizaos/autonomous 2.0.0-alpha.21 → 2.0.0-alpha.23

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 (1077) hide show
  1. package/package.json +14 -6
  2. package/test/agent-export.e2e.test.ts +376 -0
  3. package/test/agent-orchestration.e2e.test.ts +1568 -0
  4. package/test/agent-restart-recovery.e2e.test.ts +149 -0
  5. package/test/agent-runtime.e2e.test.ts +1515 -0
  6. package/test/anvil-contracts.e2e.test.ts +533 -0
  7. package/test/anvil-helper.ts +285 -0
  8. package/test/api-auth-live.e2e.test.ts +519 -0
  9. package/test/api-auth.e2e.test.ts +1039 -0
  10. package/test/api-server.e2e.test.ts +4582 -0
  11. package/test/apps-e2e.e2e.test.ts +1108 -0
  12. package/test/auth-modules.e2e.test.ts +71 -0
  13. package/test/cloud-auth-state.e2e.test.ts +145 -0
  14. package/test/cloud-persistence.e2e.test.ts +260 -0
  15. package/test/cloud-providers.e2e.test.ts +781 -0
  16. package/test/config-hot-reload.e2e.test.ts +131 -0
  17. package/test/contract-deployer.ts +151 -0
  18. package/test/contracts/MockMiladyAgentRegistry.sol +216 -0
  19. package/test/contracts/MockMiladyCollection.sol +195 -0
  20. package/test/contracts/cache/solidity-files-cache.json +1 -0
  21. package/test/contracts/foundry.toml +14 -0
  22. package/test/contracts/lib/openzeppelin-contracts/.changeset/config.json +12 -0
  23. package/test/contracts/lib/openzeppelin-contracts/.codecov.yml +12 -0
  24. package/test/contracts/lib/openzeppelin-contracts/.editorconfig +21 -0
  25. package/test/contracts/lib/openzeppelin-contracts/.eslintrc +20 -0
  26. package/test/contracts/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/bug_report.md +21 -0
  27. package/test/contracts/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/config.yml +4 -0
  28. package/test/contracts/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/feature_request.md +14 -0
  29. package/test/contracts/lib/openzeppelin-contracts/.github/PULL_REQUEST_TEMPLATE.md +20 -0
  30. package/test/contracts/lib/openzeppelin-contracts/.github/actions/gas-compare/action.yml +49 -0
  31. package/test/contracts/lib/openzeppelin-contracts/.github/actions/setup/action.yml +19 -0
  32. package/test/contracts/lib/openzeppelin-contracts/.github/actions/storage-layout/action.yml +55 -0
  33. package/test/contracts/lib/openzeppelin-contracts/.github/workflows/actionlint.yml +18 -0
  34. package/test/contracts/lib/openzeppelin-contracts/.github/workflows/changeset.yml +28 -0
  35. package/test/contracts/lib/openzeppelin-contracts/.github/workflows/checks.yml +111 -0
  36. package/test/contracts/lib/openzeppelin-contracts/.github/workflows/docs.yml +19 -0
  37. package/test/contracts/lib/openzeppelin-contracts/.github/workflows/formal-verification.yml +68 -0
  38. package/test/contracts/lib/openzeppelin-contracts/.github/workflows/release-cycle.yml +218 -0
  39. package/test/contracts/lib/openzeppelin-contracts/.github/workflows/upgradeable.yml +30 -0
  40. package/test/contracts/lib/openzeppelin-contracts/.gitmodules +7 -0
  41. package/test/contracts/lib/openzeppelin-contracts/.mocharc.js +4 -0
  42. package/test/contracts/lib/openzeppelin-contracts/.prettierrc +14 -0
  43. package/test/contracts/lib/openzeppelin-contracts/.solcover.js +13 -0
  44. package/test/contracts/lib/openzeppelin-contracts/.solhint.json +14 -0
  45. package/test/contracts/lib/openzeppelin-contracts/CHANGELOG.md +743 -0
  46. package/test/contracts/lib/openzeppelin-contracts/CODE_OF_CONDUCT.md +73 -0
  47. package/test/contracts/lib/openzeppelin-contracts/CONTRIBUTING.md +36 -0
  48. package/test/contracts/lib/openzeppelin-contracts/GUIDELINES.md +117 -0
  49. package/test/contracts/lib/openzeppelin-contracts/LICENSE +22 -0
  50. package/test/contracts/lib/openzeppelin-contracts/README.md +90 -0
  51. package/test/contracts/lib/openzeppelin-contracts/RELEASING.md +47 -0
  52. package/test/contracts/lib/openzeppelin-contracts/SECURITY.md +42 -0
  53. package/test/contracts/lib/openzeppelin-contracts/audits/2017-03.md +292 -0
  54. package/test/contracts/lib/openzeppelin-contracts/audits/2018-10.pdf +0 -0
  55. package/test/contracts/lib/openzeppelin-contracts/audits/2022-10-Checkpoints.pdf +0 -0
  56. package/test/contracts/lib/openzeppelin-contracts/audits/2022-10-ERC4626.pdf +0 -0
  57. package/test/contracts/lib/openzeppelin-contracts/audits/2023-05-v4.9.pdf +0 -0
  58. package/test/contracts/lib/openzeppelin-contracts/audits/README.md +16 -0
  59. package/test/contracts/lib/openzeppelin-contracts/certora/Makefile +54 -0
  60. package/test/contracts/lib/openzeppelin-contracts/certora/README.md +60 -0
  61. package/test/contracts/lib/openzeppelin-contracts/certora/diff/token_ERC721_ERC721.sol.patch +14 -0
  62. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/AccessControlDefaultAdminRulesHarness.sol +47 -0
  63. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/AccessControlHarness.sol +7 -0
  64. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/DoubleEndedQueueHarness.sol +59 -0
  65. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/ERC20FlashMintHarness.sol +36 -0
  66. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/ERC20PermitHarness.sol +17 -0
  67. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/ERC20WrapperHarness.sol +25 -0
  68. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/ERC3156FlashBorrowerHarness.sol +13 -0
  69. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/ERC721Harness.sol +37 -0
  70. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/ERC721ReceiverHarness.sol +11 -0
  71. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/EnumerableMapHarness.sol +55 -0
  72. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/EnumerableSetHarness.sol +35 -0
  73. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/InitializableHarness.sol +23 -0
  74. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/Ownable2StepHarness.sol +9 -0
  75. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/OwnableHarness.sol +9 -0
  76. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/PausableHarness.sol +19 -0
  77. package/test/contracts/lib/openzeppelin-contracts/certora/harnesses/TimelockControllerHarness.sol +12 -0
  78. package/test/contracts/lib/openzeppelin-contracts/certora/reports/2021-10.pdf +0 -0
  79. package/test/contracts/lib/openzeppelin-contracts/certora/reports/2022-03.pdf +0 -0
  80. package/test/contracts/lib/openzeppelin-contracts/certora/reports/2022-05.pdf +0 -0
  81. package/test/contracts/lib/openzeppelin-contracts/certora/run.js +146 -0
  82. package/test/contracts/lib/openzeppelin-contracts/certora/specs/AccessControl.spec +126 -0
  83. package/test/contracts/lib/openzeppelin-contracts/certora/specs/AccessControlDefaultAdminRules.spec +500 -0
  84. package/test/contracts/lib/openzeppelin-contracts/certora/specs/DoubleEndedQueue.spec +366 -0
  85. package/test/contracts/lib/openzeppelin-contracts/certora/specs/ERC20.spec +414 -0
  86. package/test/contracts/lib/openzeppelin-contracts/certora/specs/ERC20FlashMint.spec +48 -0
  87. package/test/contracts/lib/openzeppelin-contracts/certora/specs/ERC20Wrapper.spec +198 -0
  88. package/test/contracts/lib/openzeppelin-contracts/certora/specs/ERC721.spec +589 -0
  89. package/test/contracts/lib/openzeppelin-contracts/certora/specs/EnumerableMap.spec +334 -0
  90. package/test/contracts/lib/openzeppelin-contracts/certora/specs/EnumerableSet.spec +247 -0
  91. package/test/contracts/lib/openzeppelin-contracts/certora/specs/Initializable.spec +165 -0
  92. package/test/contracts/lib/openzeppelin-contracts/certora/specs/Ownable.spec +78 -0
  93. package/test/contracts/lib/openzeppelin-contracts/certora/specs/Ownable2Step.spec +108 -0
  94. package/test/contracts/lib/openzeppelin-contracts/certora/specs/Pausable.spec +96 -0
  95. package/test/contracts/lib/openzeppelin-contracts/certora/specs/TimelockController.spec +275 -0
  96. package/test/contracts/lib/openzeppelin-contracts/certora/specs/helpers/helpers.spec +1 -0
  97. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IAccessControl.spec +7 -0
  98. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IAccessControlDefaultAdminRules.spec +36 -0
  99. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IERC20.spec +11 -0
  100. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IERC2612.spec +5 -0
  101. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IERC3156.spec +5 -0
  102. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IERC5313.spec +3 -0
  103. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IERC721.spec +20 -0
  104. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IOwnable.spec +5 -0
  105. package/test/contracts/lib/openzeppelin-contracts/certora/specs/methods/IOwnable2Step.spec +7 -0
  106. package/test/contracts/lib/openzeppelin-contracts/certora/specs.json +86 -0
  107. package/test/contracts/lib/openzeppelin-contracts/contracts/access/AccessControl.sol +248 -0
  108. package/test/contracts/lib/openzeppelin-contracts/contracts/access/AccessControlCrossChain.sol +45 -0
  109. package/test/contracts/lib/openzeppelin-contracts/contracts/access/AccessControlDefaultAdminRules.sol +383 -0
  110. package/test/contracts/lib/openzeppelin-contracts/contracts/access/AccessControlEnumerable.sol +64 -0
  111. package/test/contracts/lib/openzeppelin-contracts/contracts/access/IAccessControl.sol +88 -0
  112. package/test/contracts/lib/openzeppelin-contracts/contracts/access/IAccessControlDefaultAdminRules.sol +172 -0
  113. package/test/contracts/lib/openzeppelin-contracts/contracts/access/IAccessControlEnumerable.sol +31 -0
  114. package/test/contracts/lib/openzeppelin-contracts/contracts/access/Ownable.sol +83 -0
  115. package/test/contracts/lib/openzeppelin-contracts/contracts/access/Ownable2Step.sol +57 -0
  116. package/test/contracts/lib/openzeppelin-contracts/contracts/access/README.adoc +27 -0
  117. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/CrossChainEnabled.sol +54 -0
  118. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/README.adoc +34 -0
  119. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/amb/CrossChainEnabledAMB.sol +49 -0
  120. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/amb/LibAMB.sol +35 -0
  121. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/CrossChainEnabledArbitrumL1.sol +44 -0
  122. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/CrossChainEnabledArbitrumL2.sol +40 -0
  123. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/LibArbitrumL1.sol +42 -0
  124. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/LibArbitrumL2.sol +45 -0
  125. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/errors.sol +7 -0
  126. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/optimism/CrossChainEnabledOptimism.sol +41 -0
  127. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/optimism/LibOptimism.sol +36 -0
  128. package/test/contracts/lib/openzeppelin-contracts/contracts/crosschain/polygon/CrossChainEnabledPolygonChild.sol +72 -0
  129. package/test/contracts/lib/openzeppelin-contracts/contracts/finance/PaymentSplitter.sol +214 -0
  130. package/test/contracts/lib/openzeppelin-contracts/contracts/finance/README.adoc +20 -0
  131. package/test/contracts/lib/openzeppelin-contracts/contracts/finance/VestingWallet.sol +145 -0
  132. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/Governor.sol +723 -0
  133. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/IGovernor.sol +313 -0
  134. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/README.adoc +176 -0
  135. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/TimelockController.sol +422 -0
  136. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/compatibility/GovernorCompatibilityBravo.sol +333 -0
  137. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/compatibility/IGovernorCompatibilityBravo.sol +118 -0
  138. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingSimple.sol +100 -0
  139. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorPreventLateQuorum.sol +105 -0
  140. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorProposalThreshold.sol +23 -0
  141. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSettings.sol +110 -0
  142. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockCompound.sol +190 -0
  143. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockControl.sol +166 -0
  144. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotes.sol +55 -0
  145. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesComp.sol +55 -0
  146. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesQuorumFraction.sol +121 -0
  147. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/extensions/IGovernorTimelock.sol +26 -0
  148. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/utils/IVotes.sol +56 -0
  149. package/test/contracts/lib/openzeppelin-contracts/contracts/governance/utils/Votes.sol +244 -0
  150. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1155.sol +6 -0
  151. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1155MetadataURI.sol +6 -0
  152. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1155Receiver.sol +6 -0
  153. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1271.sol +19 -0
  154. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1363.sol +80 -0
  155. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Receiver.sol +35 -0
  156. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Spender.sol +29 -0
  157. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC165.sol +6 -0
  158. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Implementer.sol +6 -0
  159. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Registry.sol +6 -0
  160. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC1967.sol +26 -0
  161. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC20.sol +6 -0
  162. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC20Metadata.sol +6 -0
  163. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC2309.sol +21 -0
  164. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC2612.sol +8 -0
  165. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC2981.sol +25 -0
  166. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC3156.sol +7 -0
  167. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashBorrower.sol +29 -0
  168. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashLender.sol +43 -0
  169. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC4626.sol +232 -0
  170. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC4906.sol +20 -0
  171. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC5267.sol +28 -0
  172. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC5313.sol +18 -0
  173. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC5805.sol +9 -0
  174. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC6372.sol +17 -0
  175. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC721.sol +6 -0
  176. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC721Enumerable.sol +6 -0
  177. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC721Metadata.sol +6 -0
  178. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC721Receiver.sol +6 -0
  179. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC777.sol +6 -0
  180. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC777Recipient.sol +6 -0
  181. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/IERC777Sender.sol +6 -0
  182. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/README.adoc +73 -0
  183. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC1822.sol +20 -0
  184. package/test/contracts/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC2612.sol +8 -0
  185. package/test/contracts/lib/openzeppelin-contracts/contracts/metatx/ERC2771Context.sol +54 -0
  186. package/test/contracts/lib/openzeppelin-contracts/contracts/metatx/MinimalForwarder.sol +72 -0
  187. package/test/contracts/lib/openzeppelin-contracts/contracts/metatx/README.adoc +12 -0
  188. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/AccessControlCrossChainMock.sol +8 -0
  189. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ArraysMock.sol +51 -0
  190. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/Base64Dirty.sol +19 -0
  191. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/CallReceiverMock.sol +61 -0
  192. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ConditionalEscrowMock.sol +18 -0
  193. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ContextMock.sol +35 -0
  194. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/DummyImplementation.sol +57 -0
  195. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/EIP712Verifier.sol +16 -0
  196. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC1271WalletMock.sol +26 -0
  197. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165MaliciousData.sol +12 -0
  198. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165MissingData.sol +7 -0
  199. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165NotSupported.sol +5 -0
  200. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165ReturnBomb.sol +18 -0
  201. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC20Mock.sol +16 -0
  202. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC20Reentrant.sol +43 -0
  203. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC2771ContextMock.sol +27 -0
  204. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC3156FlashBorrowerMock.sol +53 -0
  205. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ERC4626Mock.sol +16 -0
  206. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/EtherReceiverMock.sol +17 -0
  207. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/InitializableMock.sol +130 -0
  208. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/MulticallTest.sol +23 -0
  209. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/MultipleInheritanceInitializableMocks.sol +131 -0
  210. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/PausableMock.sol +31 -0
  211. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/PullPaymentMock.sol +15 -0
  212. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ReentrancyAttack.sol +12 -0
  213. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/ReentrancyMock.sol +51 -0
  214. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/RegressionImplementation.sol +61 -0
  215. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/SafeMathMemoryCheck.sol +72 -0
  216. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/SingleInheritanceInitializableMocks.sol +49 -0
  217. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/StorageSlotMock.sol +77 -0
  218. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/TimelockReentrant.sol +26 -0
  219. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/TimersBlockNumberImpl.sol +39 -0
  220. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/TimersTimestampImpl.sol +39 -0
  221. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/VotesMock.sol +45 -0
  222. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/compound/CompTimelock.sol +174 -0
  223. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/crosschain/bridges.sol +94 -0
  224. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/crosschain/receivers.sol +54 -0
  225. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/docs/ERC4626Fees.sol +100 -0
  226. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyGovernor.sol +88 -0
  227. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyToken.sol +24 -0
  228. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenTimestampBased.sol +35 -0
  229. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenWrapped.sol +31 -0
  230. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorCompMock.sol +20 -0
  231. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorCompatibilityBravoMock.sol +100 -0
  232. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorMock.sol +28 -0
  233. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorPreventLateQuorumMock.sol +45 -0
  234. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockCompoundMock.sol +60 -0
  235. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockControlMock.sol +60 -0
  236. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorVoteMock.sol +20 -0
  237. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorWithParamsMock.sol +50 -0
  238. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/proxy/BadBeacon.sol +11 -0
  239. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/proxy/ClashingImplementation.sol +17 -0
  240. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/proxy/UUPSLegacy.sol +54 -0
  241. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/proxy/UUPSUpgradeableMock.sol +33 -0
  242. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC1155ReceiverMock.sol +47 -0
  243. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20DecimalsMock.sol +17 -0
  244. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ExcessDecimalsMock.sol +9 -0
  245. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20FlashMintMock.sol +26 -0
  246. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ForceApproveMock.sol +13 -0
  247. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20MulticallMock.sol +8 -0
  248. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20NoReturnMock.sol +28 -0
  249. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20PermitNoRevertMock.sol +36 -0
  250. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ReturnFalseMock.sol +19 -0
  251. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesLegacyMock.sol +262 -0
  252. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626OffsetMock.sol +17 -0
  253. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC4646FeesMock.sol +40 -0
  254. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveEnumerableMock.sol +51 -0
  255. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveMock.sol +61 -0
  256. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ReceiverMock.sol +42 -0
  257. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC721URIStorageMock.sol +17 -0
  258. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC777Mock.sol +13 -0
  259. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/ERC777SenderRecipientMock.sol +152 -0
  260. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/token/VotesTimestamp.sol +40 -0
  261. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/wizard/MyGovernor1.sol +79 -0
  262. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/wizard/MyGovernor2.sol +85 -0
  263. package/test/contracts/lib/openzeppelin-contracts/contracts/mocks/wizard/MyGovernor3.sol +94 -0
  264. package/test/contracts/lib/openzeppelin-contracts/contracts/package.json +32 -0
  265. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/Clones.sol +88 -0
  266. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Proxy.sol +32 -0
  267. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Upgrade.sol +157 -0
  268. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/Proxy.sol +86 -0
  269. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/README.adoc +87 -0
  270. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/beacon/BeaconProxy.sol +61 -0
  271. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/beacon/IBeacon.sol +16 -0
  272. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/beacon/UpgradeableBeacon.sol +65 -0
  273. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/transparent/ProxyAdmin.sol +81 -0
  274. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/transparent/TransparentUpgradeableProxy.sol +191 -0
  275. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/utils/Initializable.sol +166 -0
  276. package/test/contracts/lib/openzeppelin-contracts/contracts/proxy/utils/UUPSUpgradeable.sol +99 -0
  277. package/test/contracts/lib/openzeppelin-contracts/contracts/security/Pausable.sol +105 -0
  278. package/test/contracts/lib/openzeppelin-contracts/contracts/security/PullPayment.sol +74 -0
  279. package/test/contracts/lib/openzeppelin-contracts/contracts/security/README.adoc +20 -0
  280. package/test/contracts/lib/openzeppelin-contracts/contracts/security/ReentrancyGuard.sol +77 -0
  281. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/ERC1155.sol +497 -0
  282. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155.sol +119 -0
  283. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155Receiver.sol +58 -0
  284. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/README.adoc +49 -0
  285. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Burnable.sol +32 -0
  286. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Pausable.sol +44 -0
  287. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Supply.sol +64 -0
  288. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155URIStorage.sol +63 -0
  289. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/IERC1155MetadataURI.sol +22 -0
  290. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/presets/ERC1155PresetMinterPauser.sol +114 -0
  291. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/presets/README.md +1 -0
  292. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Holder.sol +36 -0
  293. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Receiver.sol +19 -0
  294. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/ERC20.sol +365 -0
  295. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/IERC20.sol +78 -0
  296. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/README.adoc +80 -0
  297. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Burnable.sol +39 -0
  298. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Capped.sol +37 -0
  299. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20FlashMint.sol +109 -0
  300. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Pausable.sol +35 -0
  301. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Permit.sol +95 -0
  302. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Snapshot.sol +191 -0
  303. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Votes.sol +290 -0
  304. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20VotesComp.sol +46 -0
  305. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Wrapper.sol +73 -0
  306. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC4626.sol +256 -0
  307. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Metadata.sol +28 -0
  308. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Permit.sol +90 -0
  309. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20Permit.sol +8 -0
  310. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-IERC20Permit.sol +8 -0
  311. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/presets/ERC20PresetFixedSupply.sol +30 -0
  312. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol +94 -0
  313. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/presets/README.md +1 -0
  314. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/utils/SafeERC20.sol +143 -0
  315. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC20/utils/TokenTimelock.sol +72 -0
  316. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol +466 -0
  317. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721.sol +132 -0
  318. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721Receiver.sol +27 -0
  319. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/README.adoc +73 -0
  320. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Burnable.sol +26 -0
  321. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Consecutive.sol +148 -0
  322. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Enumerable.sol +159 -0
  323. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Pausable.sol +40 -0
  324. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Royalty.sol +38 -0
  325. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721URIStorage.sol +74 -0
  326. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Votes.sol +43 -0
  327. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Wrapper.sol +97 -0
  328. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Enumerable.sol +29 -0
  329. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Metadata.sol +27 -0
  330. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/draft-ERC721Votes.sol +9 -0
  331. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/presets/ERC721PresetMinterPauserAutoId.sol +132 -0
  332. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/presets/README.md +1 -0
  333. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Holder.sol +23 -0
  334. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC777/ERC777.sol +514 -0
  335. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC777/IERC777.sol +200 -0
  336. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC777/IERC777Recipient.sol +35 -0
  337. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC777/IERC777Sender.sol +35 -0
  338. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC777/README.adoc +32 -0
  339. package/test/contracts/lib/openzeppelin-contracts/contracts/token/ERC777/presets/ERC777PresetFixedSupply.sol +30 -0
  340. package/test/contracts/lib/openzeppelin-contracts/contracts/token/common/ERC2981.sol +107 -0
  341. package/test/contracts/lib/openzeppelin-contracts/contracts/token/common/README.adoc +10 -0
  342. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Address.sol +244 -0
  343. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Arrays.sol +105 -0
  344. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Base64.sol +101 -0
  345. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Checkpoints.sol +560 -0
  346. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Context.sol +28 -0
  347. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Counters.sol +43 -0
  348. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Create2.sol +75 -0
  349. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Multicall.sol +39 -0
  350. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/README.adoc +113 -0
  351. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/ShortStrings.sol +122 -0
  352. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/StorageSlot.sol +138 -0
  353. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Strings.sol +85 -0
  354. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/Timers.sol +75 -0
  355. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/cryptography/ECDSA.sol +217 -0
  356. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/cryptography/EIP712.sol +142 -0
  357. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/cryptography/MerkleProof.sol +227 -0
  358. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/cryptography/SignatureChecker.sol +50 -0
  359. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/cryptography/draft-EIP712.sol +8 -0
  360. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/escrow/ConditionalEscrow.sol +25 -0
  361. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/escrow/Escrow.sol +67 -0
  362. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/escrow/RefundEscrow.sol +100 -0
  363. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165.sol +29 -0
  364. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165Checker.sol +126 -0
  365. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165Storage.sol +42 -0
  366. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/introspection/ERC1820Implementer.sol +43 -0
  367. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/introspection/IERC165.sol +25 -0
  368. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/introspection/IERC1820Implementer.sol +20 -0
  369. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/introspection/IERC1820Registry.sol +112 -0
  370. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/math/Math.sol +339 -0
  371. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/math/SafeCast.sol +1136 -0
  372. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/math/SafeMath.sol +215 -0
  373. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/math/SignedMath.sol +43 -0
  374. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/math/SignedSafeMath.sol +68 -0
  375. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/structs/BitMaps.sol +51 -0
  376. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/structs/DoubleEndedQueue.sol +170 -0
  377. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableMap.sol +598 -0
  378. package/test/contracts/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableSet.sol +378 -0
  379. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/amb/IAMB.sol +41 -0
  380. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IArbSys.sol +134 -0
  381. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IBridge.sol +102 -0
  382. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IDelayedMessageProvider.sol +16 -0
  383. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IInbox.sol +152 -0
  384. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IOutbox.sol +117 -0
  385. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/compound/ICompoundTimelock.sol +86 -0
  386. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/compound/LICENSE +11 -0
  387. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/optimism/ICrossDomainMessenger.sol +34 -0
  388. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/optimism/LICENSE +22 -0
  389. package/test/contracts/lib/openzeppelin-contracts/contracts/vendor/polygon/IFxMessageProcessor.sol +7 -0
  390. package/test/contracts/lib/openzeppelin-contracts/docs/README.md +16 -0
  391. package/test/contracts/lib/openzeppelin-contracts/docs/antora.yml +6 -0
  392. package/test/contracts/lib/openzeppelin-contracts/docs/config.js +21 -0
  393. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
  394. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
  395. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
  396. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack.png +0 -0
  397. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
  398. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-mint.png +0 -0
  399. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
  400. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
  401. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
  402. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-exec.png +0 -0
  403. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-vote.png +0 -0
  404. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/nav.adoc +23 -0
  405. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +219 -0
  406. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/crosschain.adoc +210 -0
  407. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/crowdsales.adoc +11 -0
  408. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/drafts.adoc +19 -0
  409. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc1155.adoc +153 -0
  410. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +113 -0
  411. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +85 -0
  412. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc4626.adoc +214 -0
  413. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc721.adoc +90 -0
  414. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc777.adoc +75 -0
  415. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +131 -0
  416. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +237 -0
  417. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +65 -0
  418. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/releases-stability.adoc +85 -0
  419. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +32 -0
  420. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +73 -0
  421. package/test/contracts/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +190 -0
  422. package/test/contracts/lib/openzeppelin-contracts/docs/templates/contract.hbs +85 -0
  423. package/test/contracts/lib/openzeppelin-contracts/docs/templates/helpers.js +46 -0
  424. package/test/contracts/lib/openzeppelin-contracts/docs/templates/page.hbs +4 -0
  425. package/test/contracts/lib/openzeppelin-contracts/docs/templates/properties.js +45 -0
  426. package/test/contracts/lib/openzeppelin-contracts/foundry.toml +3 -0
  427. package/test/contracts/lib/openzeppelin-contracts/hardhat/env-artifacts.js +24 -0
  428. package/test/contracts/lib/openzeppelin-contracts/hardhat/env-contract.js +10 -0
  429. package/test/contracts/lib/openzeppelin-contracts/hardhat/ignore-unreachable-warnings.js +45 -0
  430. package/test/contracts/lib/openzeppelin-contracts/hardhat/skip-foundry-tests.js +6 -0
  431. package/test/contracts/lib/openzeppelin-contracts/hardhat/task-test-get-files.js +25 -0
  432. package/test/contracts/lib/openzeppelin-contracts/hardhat.config.js +118 -0
  433. package/test/contracts/lib/openzeppelin-contracts/lib/erc4626-tests/ERC4626.prop.sol +404 -0
  434. package/test/contracts/lib/openzeppelin-contracts/lib/erc4626-tests/ERC4626.test.sol +349 -0
  435. package/test/contracts/lib/openzeppelin-contracts/lib/erc4626-tests/LICENSE +661 -0
  436. package/test/contracts/lib/openzeppelin-contracts/lib/erc4626-tests/README.md +116 -0
  437. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/.github/workflows/ci.yml +92 -0
  438. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/.gitmodules +3 -0
  439. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/LICENSE-APACHE +203 -0
  440. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/LICENSE-MIT +25 -0
  441. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/README.md +250 -0
  442. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/foundry.toml +21 -0
  443. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/.github/workflows/build.yml +41 -0
  444. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/LICENSE +674 -0
  445. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/Makefile +14 -0
  446. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/default.nix +4 -0
  447. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/demo/demo.sol +222 -0
  448. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/package.json +15 -0
  449. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/src/test.sol +469 -0
  450. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/src/test.t.sol +313 -0
  451. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/package.json +16 -0
  452. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/Base.sol +33 -0
  453. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/Script.sol +26 -0
  454. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdAssertions.sol +376 -0
  455. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdChains.sol +233 -0
  456. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdCheats.sol +624 -0
  457. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdError.sol +15 -0
  458. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdInvariant.sol +92 -0
  459. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdJson.sol +179 -0
  460. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdMath.sol +43 -0
  461. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdStorage.sol +327 -0
  462. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdStyle.sol +333 -0
  463. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/StdUtils.sol +189 -0
  464. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/Test.sol +32 -0
  465. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/Vm.sol +409 -0
  466. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/console.sol +1533 -0
  467. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/console2.sol +1546 -0
  468. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC1155.sol +105 -0
  469. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC165.sol +12 -0
  470. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC20.sol +43 -0
  471. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC4626.sol +190 -0
  472. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC721.sol +164 -0
  473. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IMulticall3.sol +73 -0
  474. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdAssertions.t.sol +954 -0
  475. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdChains.t.sol +160 -0
  476. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdCheats.t.sol +401 -0
  477. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdError.t.sol +118 -0
  478. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdMath.t.sol +197 -0
  479. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdStorage.t.sol +283 -0
  480. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdStyle.t.sol +110 -0
  481. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/StdUtils.t.sol +297 -0
  482. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationScript.sol +10 -0
  483. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationScriptBase.sol +10 -0
  484. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationTest.sol +10 -0
  485. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationTestBase.sol +10 -0
  486. package/test/contracts/lib/openzeppelin-contracts/lib/forge-std/test/fixtures/broadcast.log.json +187 -0
  487. package/test/contracts/lib/openzeppelin-contracts/logo.svg +15 -0
  488. package/test/contracts/lib/openzeppelin-contracts/netlify.toml +3 -0
  489. package/test/contracts/lib/openzeppelin-contracts/package-lock.json +28833 -0
  490. package/test/contracts/lib/openzeppelin-contracts/package.json +96 -0
  491. package/test/contracts/lib/openzeppelin-contracts/remappings.txt +1 -0
  492. package/test/contracts/lib/openzeppelin-contracts/renovate.json +4 -0
  493. package/test/contracts/lib/openzeppelin-contracts/requirements.txt +1 -0
  494. package/test/contracts/lib/openzeppelin-contracts/scripts/checks/compare-layout.js +19 -0
  495. package/test/contracts/lib/openzeppelin-contracts/scripts/checks/compareGasReports.js +243 -0
  496. package/test/contracts/lib/openzeppelin-contracts/scripts/checks/extract-layout.js +40 -0
  497. package/test/contracts/lib/openzeppelin-contracts/scripts/checks/generation.sh +6 -0
  498. package/test/contracts/lib/openzeppelin-contracts/scripts/checks/inheritance-ordering.js +54 -0
  499. package/test/contracts/lib/openzeppelin-contracts/scripts/gen-nav.js +41 -0
  500. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/format-lines.js +16 -0
  501. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/run.js +49 -0
  502. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.js +304 -0
  503. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.opts.js +22 -0
  504. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.t.js +256 -0
  505. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableMap.js +310 -0
  506. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableSet.js +250 -0
  507. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/SafeCast.js +163 -0
  508. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlot.js +87 -0
  509. package/test/contracts/lib/openzeppelin-contracts/scripts/generate/templates/conversion.js +30 -0
  510. package/test/contracts/lib/openzeppelin-contracts/scripts/git-user-config.sh +6 -0
  511. package/test/contracts/lib/openzeppelin-contracts/scripts/helpers.js +37 -0
  512. package/test/contracts/lib/openzeppelin-contracts/scripts/migrate-imports.js +180 -0
  513. package/test/contracts/lib/openzeppelin-contracts/scripts/prepack.sh +12 -0
  514. package/test/contracts/lib/openzeppelin-contracts/scripts/prepare-contracts-package.sh +15 -0
  515. package/test/contracts/lib/openzeppelin-contracts/scripts/prepare-docs.sh +26 -0
  516. package/test/contracts/lib/openzeppelin-contracts/scripts/prepare.sh +10 -0
  517. package/test/contracts/lib/openzeppelin-contracts/scripts/release/format-changelog.js +33 -0
  518. package/test/contracts/lib/openzeppelin-contracts/scripts/release/synchronize-versions.js +15 -0
  519. package/test/contracts/lib/openzeppelin-contracts/scripts/release/update-comment.js +34 -0
  520. package/test/contracts/lib/openzeppelin-contracts/scripts/release/version.sh +11 -0
  521. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/exit-prerelease.sh +8 -0
  522. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/github-release.js +47 -0
  523. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/integrity-check.sh +20 -0
  524. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/pack.sh +26 -0
  525. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/publish.sh +26 -0
  526. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/rerun.js +7 -0
  527. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/set-changesets-pr-title.js +17 -0
  528. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/start.sh +35 -0
  529. package/test/contracts/lib/openzeppelin-contracts/scripts/release/workflow/state.js +112 -0
  530. package/test/contracts/lib/openzeppelin-contracts/scripts/remove-ignored-artifacts.js +45 -0
  531. package/test/contracts/lib/openzeppelin-contracts/scripts/update-docs-branch.js +63 -0
  532. package/test/contracts/lib/openzeppelin-contracts/scripts/upgradeable/README.md +21 -0
  533. package/test/contracts/lib/openzeppelin-contracts/scripts/upgradeable/patch-apply.sh +19 -0
  534. package/test/contracts/lib/openzeppelin-contracts/scripts/upgradeable/patch-save.sh +18 -0
  535. package/test/contracts/lib/openzeppelin-contracts/scripts/upgradeable/transpile-onto.sh +44 -0
  536. package/test/contracts/lib/openzeppelin-contracts/scripts/upgradeable/transpile.sh +35 -0
  537. package/test/contracts/lib/openzeppelin-contracts/scripts/upgradeable/upgradeable.patch +481 -0
  538. package/test/contracts/lib/openzeppelin-contracts/slither.config.json +5 -0
  539. package/test/contracts/lib/openzeppelin-contracts/test/TESTING.md +3 -0
  540. package/test/contracts/lib/openzeppelin-contracts/test/access/AccessControl.behavior.js +867 -0
  541. package/test/contracts/lib/openzeppelin-contracts/test/access/AccessControl.test.js +12 -0
  542. package/test/contracts/lib/openzeppelin-contracts/test/access/AccessControlCrossChain.test.js +49 -0
  543. package/test/contracts/lib/openzeppelin-contracts/test/access/AccessControlDefaultAdminRules.test.js +25 -0
  544. package/test/contracts/lib/openzeppelin-contracts/test/access/AccessControlEnumerable.test.js +17 -0
  545. package/test/contracts/lib/openzeppelin-contracts/test/access/Ownable.test.js +59 -0
  546. package/test/contracts/lib/openzeppelin-contracts/test/access/Ownable2Step.test.js +67 -0
  547. package/test/contracts/lib/openzeppelin-contracts/test/crosschain/CrossChainEnabled.test.js +78 -0
  548. package/test/contracts/lib/openzeppelin-contracts/test/finance/PaymentSplitter.test.js +217 -0
  549. package/test/contracts/lib/openzeppelin-contracts/test/finance/VestingWallet.behavior.js +59 -0
  550. package/test/contracts/lib/openzeppelin-contracts/test/finance/VestingWallet.test.js +67 -0
  551. package/test/contracts/lib/openzeppelin-contracts/test/governance/Governor.t.sol +55 -0
  552. package/test/contracts/lib/openzeppelin-contracts/test/governance/Governor.test.js +782 -0
  553. package/test/contracts/lib/openzeppelin-contracts/test/governance/TimelockController.test.js +1254 -0
  554. package/test/contracts/lib/openzeppelin-contracts/test/governance/compatibility/GovernorCompatibilityBravo.test.js +283 -0
  555. package/test/contracts/lib/openzeppelin-contracts/test/governance/extensions/GovernorComp.test.js +88 -0
  556. package/test/contracts/lib/openzeppelin-contracts/test/governance/extensions/GovernorERC721.test.js +115 -0
  557. package/test/contracts/lib/openzeppelin-contracts/test/governance/extensions/GovernorPreventLateQuorum.test.js +189 -0
  558. package/test/contracts/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockCompound.test.js +352 -0
  559. package/test/contracts/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockControl.test.js +445 -0
  560. package/test/contracts/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesQuorumFraction.test.js +154 -0
  561. package/test/contracts/lib/openzeppelin-contracts/test/governance/extensions/GovernorWithParams.test.js +173 -0
  562. package/test/contracts/lib/openzeppelin-contracts/test/governance/utils/EIP6372.behavior.js +23 -0
  563. package/test/contracts/lib/openzeppelin-contracts/test/governance/utils/Votes.behavior.js +361 -0
  564. package/test/contracts/lib/openzeppelin-contracts/test/governance/utils/Votes.test.js +71 -0
  565. package/test/contracts/lib/openzeppelin-contracts/test/helpers/chainid.js +10 -0
  566. package/test/contracts/lib/openzeppelin-contracts/test/helpers/create2.js +11 -0
  567. package/test/contracts/lib/openzeppelin-contracts/test/helpers/crosschain.js +61 -0
  568. package/test/contracts/lib/openzeppelin-contracts/test/helpers/customError.js +24 -0
  569. package/test/contracts/lib/openzeppelin-contracts/test/helpers/eip712.js +67 -0
  570. package/test/contracts/lib/openzeppelin-contracts/test/helpers/enums.js +12 -0
  571. package/test/contracts/lib/openzeppelin-contracts/test/helpers/erc1967.js +24 -0
  572. package/test/contracts/lib/openzeppelin-contracts/test/helpers/governance.js +201 -0
  573. package/test/contracts/lib/openzeppelin-contracts/test/helpers/map-values.js +7 -0
  574. package/test/contracts/lib/openzeppelin-contracts/test/helpers/sign.js +63 -0
  575. package/test/contracts/lib/openzeppelin-contracts/test/helpers/time.js +17 -0
  576. package/test/contracts/lib/openzeppelin-contracts/test/helpers/txpool.js +38 -0
  577. package/test/contracts/lib/openzeppelin-contracts/test/metatx/ERC2771Context.test.js +175 -0
  578. package/test/contracts/lib/openzeppelin-contracts/test/metatx/MinimalForwarder.test.js +169 -0
  579. package/test/contracts/lib/openzeppelin-contracts/test/migrate-imports.test.js +33 -0
  580. package/test/contracts/lib/openzeppelin-contracts/test/proxy/Clones.behaviour.js +136 -0
  581. package/test/contracts/lib/openzeppelin-contracts/test/proxy/Clones.test.js +61 -0
  582. package/test/contracts/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Proxy.test.js +13 -0
  583. package/test/contracts/lib/openzeppelin-contracts/test/proxy/Proxy.behaviour.js +225 -0
  584. package/test/contracts/lib/openzeppelin-contracts/test/proxy/beacon/BeaconProxy.test.js +139 -0
  585. package/test/contracts/lib/openzeppelin-contracts/test/proxy/beacon/UpgradeableBeacon.test.js +44 -0
  586. package/test/contracts/lib/openzeppelin-contracts/test/proxy/transparent/ProxyAdmin.test.js +127 -0
  587. package/test/contracts/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.behaviour.js +433 -0
  588. package/test/contracts/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.test.js +17 -0
  589. package/test/contracts/lib/openzeppelin-contracts/test/proxy/utils/Initializable.test.js +218 -0
  590. package/test/contracts/lib/openzeppelin-contracts/test/proxy/utils/UUPSUpgradeable.test.js +85 -0
  591. package/test/contracts/lib/openzeppelin-contracts/test/security/Pausable.test.js +85 -0
  592. package/test/contracts/lib/openzeppelin-contracts/test/security/PullPayment.test.js +51 -0
  593. package/test/contracts/lib/openzeppelin-contracts/test/security/ReentrancyGuard.test.js +43 -0
  594. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.behavior.js +767 -0
  595. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.test.js +235 -0
  596. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Burnable.test.js +67 -0
  597. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Pausable.test.js +108 -0
  598. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Supply.test.js +107 -0
  599. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155URIStorage.test.js +66 -0
  600. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/presets/ERC1155PresetMinterPauser.test.js +156 -0
  601. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Holder.test.js +64 -0
  602. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/ERC20.behavior.js +322 -0
  603. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/ERC20.test.js +305 -0
  604. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Burnable.behavior.js +106 -0
  605. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Burnable.test.js +20 -0
  606. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Capped.behavior.js +32 -0
  607. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Capped.test.js +23 -0
  608. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20FlashMint.test.js +204 -0
  609. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Pausable.test.js +133 -0
  610. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Snapshot.test.js +207 -0
  611. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Votes.test.js +578 -0
  612. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20VotesComp.test.js +543 -0
  613. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Wrapper.test.js +190 -0
  614. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.t.sol +42 -0
  615. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.test.js +1031 -0
  616. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20Permit.test.js +103 -0
  617. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/presets/ERC20PresetFixedSupply.test.js +42 -0
  618. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/presets/ERC20PresetMinterPauser.test.js +110 -0
  619. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/utils/SafeERC20.test.js +350 -0
  620. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC20/utils/TokenTimelock.test.js +71 -0
  621. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/ERC721.behavior.js +893 -0
  622. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/ERC721.test.js +15 -0
  623. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/ERC721Enumerable.test.js +20 -0
  624. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Burnable.test.js +70 -0
  625. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.t.sol +122 -0
  626. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.test.js +206 -0
  627. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Pausable.test.js +92 -0
  628. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Royalty.test.js +41 -0
  629. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721URIStorage.test.js +100 -0
  630. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Votes.test.js +184 -0
  631. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Wrapper.test.js +283 -0
  632. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/presets/ERC721PresetMinterPauserAutoId.test.js +122 -0
  633. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Holder.test.js +22 -0
  634. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC777/ERC777.behavior.js +597 -0
  635. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC777/ERC777.test.js +556 -0
  636. package/test/contracts/lib/openzeppelin-contracts/test/token/ERC777/presets/ERC777PresetFixedSupply.test.js +49 -0
  637. package/test/contracts/lib/openzeppelin-contracts/test/token/common/ERC2981.behavior.js +157 -0
  638. package/test/contracts/lib/openzeppelin-contracts/test/utils/Address.test.js +361 -0
  639. package/test/contracts/lib/openzeppelin-contracts/test/utils/Arrays.test.js +123 -0
  640. package/test/contracts/lib/openzeppelin-contracts/test/utils/Base64.test.js +43 -0
  641. package/test/contracts/lib/openzeppelin-contracts/test/utils/Checkpoints.t.sol +347 -0
  642. package/test/contracts/lib/openzeppelin-contracts/test/utils/Checkpoints.test.js +255 -0
  643. package/test/contracts/lib/openzeppelin-contracts/test/utils/Context.behavior.js +42 -0
  644. package/test/contracts/lib/openzeppelin-contracts/test/utils/Context.test.js +17 -0
  645. package/test/contracts/lib/openzeppelin-contracts/test/utils/Counters.test.js +84 -0
  646. package/test/contracts/lib/openzeppelin-contracts/test/utils/Create2.test.js +89 -0
  647. package/test/contracts/lib/openzeppelin-contracts/test/utils/Multicall.test.js +68 -0
  648. package/test/contracts/lib/openzeppelin-contracts/test/utils/ShortStrings.t.sol +55 -0
  649. package/test/contracts/lib/openzeppelin-contracts/test/utils/ShortStrings.test.js +55 -0
  650. package/test/contracts/lib/openzeppelin-contracts/test/utils/StorageSlot.test.js +210 -0
  651. package/test/contracts/lib/openzeppelin-contracts/test/utils/Strings.test.js +150 -0
  652. package/test/contracts/lib/openzeppelin-contracts/test/utils/TimersBlockNumberImpl.test.js +55 -0
  653. package/test/contracts/lib/openzeppelin-contracts/test/utils/TimersTimestamp.test.js +55 -0
  654. package/test/contracts/lib/openzeppelin-contracts/test/utils/cryptography/ECDSA.test.js +260 -0
  655. package/test/contracts/lib/openzeppelin-contracts/test/utils/cryptography/EIP712.test.js +103 -0
  656. package/test/contracts/lib/openzeppelin-contracts/test/utils/cryptography/MerkleProof.test.js +200 -0
  657. package/test/contracts/lib/openzeppelin-contracts/test/utils/cryptography/SignatureChecker.test.js +87 -0
  658. package/test/contracts/lib/openzeppelin-contracts/test/utils/escrow/ConditionalEscrow.test.js +37 -0
  659. package/test/contracts/lib/openzeppelin-contracts/test/utils/escrow/Escrow.behavior.js +90 -0
  660. package/test/contracts/lib/openzeppelin-contracts/test/utils/escrow/Escrow.test.js +14 -0
  661. package/test/contracts/lib/openzeppelin-contracts/test/utils/escrow/RefundEscrow.test.js +143 -0
  662. package/test/contracts/lib/openzeppelin-contracts/test/utils/introspection/ERC165.test.js +11 -0
  663. package/test/contracts/lib/openzeppelin-contracts/test/utils/introspection/ERC165Checker.test.js +302 -0
  664. package/test/contracts/lib/openzeppelin-contracts/test/utils/introspection/ERC165Storage.test.js +23 -0
  665. package/test/contracts/lib/openzeppelin-contracts/test/utils/introspection/ERC1820Implementer.test.js +71 -0
  666. package/test/contracts/lib/openzeppelin-contracts/test/utils/introspection/SupportsInterface.behavior.js +146 -0
  667. package/test/contracts/lib/openzeppelin-contracts/test/utils/math/Math.t.sol +217 -0
  668. package/test/contracts/lib/openzeppelin-contracts/test/utils/math/Math.test.js +289 -0
  669. package/test/contracts/lib/openzeppelin-contracts/test/utils/math/SafeCast.test.js +152 -0
  670. package/test/contracts/lib/openzeppelin-contracts/test/utils/math/SafeMath.test.js +433 -0
  671. package/test/contracts/lib/openzeppelin-contracts/test/utils/math/SignedMath.test.js +95 -0
  672. package/test/contracts/lib/openzeppelin-contracts/test/utils/math/SignedSafeMath.test.js +152 -0
  673. package/test/contracts/lib/openzeppelin-contracts/test/utils/structs/BitMap.test.js +145 -0
  674. package/test/contracts/lib/openzeppelin-contracts/test/utils/structs/DoubleEndedQueue.test.js +99 -0
  675. package/test/contracts/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.behavior.js +185 -0
  676. package/test/contracts/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.test.js +154 -0
  677. package/test/contracts/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.behavior.js +129 -0
  678. package/test/contracts/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.test.js +79 -0
  679. package/test/contracts/out/AccessControl.sol/AccessControl.json +1 -0
  680. package/test/contracts/out/AccessControlCrossChain.sol/AccessControlCrossChain.json +1 -0
  681. package/test/contracts/out/AccessControlCrossChainMock.sol/AccessControlCrossChainMock.json +1 -0
  682. package/test/contracts/out/AccessControlDefaultAdminRules.sol/AccessControlDefaultAdminRules.json +1 -0
  683. package/test/contracts/out/AccessControlEnumerable.sol/AccessControlEnumerable.json +1 -0
  684. package/test/contracts/out/Address.sol/Address.json +1 -0
  685. package/test/contracts/out/Arrays.sol/Arrays.json +1 -0
  686. package/test/contracts/out/ArraysMock.sol/AddressArraysMock.json +1 -0
  687. package/test/contracts/out/ArraysMock.sol/Bytes32ArraysMock.json +1 -0
  688. package/test/contracts/out/ArraysMock.sol/Uint256ArraysMock.json +1 -0
  689. package/test/contracts/out/BadBeacon.sol/BadBeaconNoImpl.json +1 -0
  690. package/test/contracts/out/BadBeacon.sol/BadBeaconNotContract.json +1 -0
  691. package/test/contracts/out/Base.sol/CommonBase.json +1 -0
  692. package/test/contracts/out/Base.sol/ScriptBase.json +1 -0
  693. package/test/contracts/out/Base.sol/TestBase.json +1 -0
  694. package/test/contracts/out/Base64.sol/Base64.json +1 -0
  695. package/test/contracts/out/Base64Dirty.sol/Base64Dirty.json +1 -0
  696. package/test/contracts/out/BeaconProxy.sol/BeaconProxy.json +1 -0
  697. package/test/contracts/out/BitMaps.sol/BitMaps.json +1 -0
  698. package/test/contracts/out/CallReceiverMock.sol/CallReceiverMock.json +1 -0
  699. package/test/contracts/out/Checkpoints.sol/Checkpoints.json +1 -0
  700. package/test/contracts/out/Checkpoints.t.sol/CheckpointsHistoryTest.json +1 -0
  701. package/test/contracts/out/Checkpoints.t.sol/CheckpointsTrace160Test.json +1 -0
  702. package/test/contracts/out/Checkpoints.t.sol/CheckpointsTrace224Test.json +1 -0
  703. package/test/contracts/out/ClashingImplementation.sol/ClashingImplementation.json +1 -0
  704. package/test/contracts/out/Clones.sol/Clones.json +1 -0
  705. package/test/contracts/out/CompTimelock.sol/CompTimelock.json +1 -0
  706. package/test/contracts/out/CompilationScript.sol/CompilationScript.json +1 -0
  707. package/test/contracts/out/CompilationScriptBase.sol/CompilationScriptBase.json +1 -0
  708. package/test/contracts/out/CompilationTest.sol/CompilationTest.json +1 -0
  709. package/test/contracts/out/CompilationTestBase.sol/CompilationTestBase.json +1 -0
  710. package/test/contracts/out/ConditionalEscrow.sol/ConditionalEscrow.json +1 -0
  711. package/test/contracts/out/ConditionalEscrowMock.sol/ConditionalEscrowMock.json +1 -0
  712. package/test/contracts/out/Context.sol/Context.json +1 -0
  713. package/test/contracts/out/ContextMock.sol/ContextMock.json +1 -0
  714. package/test/contracts/out/ContextMock.sol/ContextMockCaller.json +1 -0
  715. package/test/contracts/out/Counters.sol/Counters.json +1 -0
  716. package/test/contracts/out/Create2.sol/Create2.json +1 -0
  717. package/test/contracts/out/CrossChainEnabled.sol/CrossChainEnabled.json +1 -0
  718. package/test/contracts/out/CrossChainEnabledAMB.sol/CrossChainEnabledAMB.json +1 -0
  719. package/test/contracts/out/CrossChainEnabledArbitrumL1.sol/CrossChainEnabledArbitrumL1.json +1 -0
  720. package/test/contracts/out/CrossChainEnabledArbitrumL2.sol/CrossChainEnabledArbitrumL2.json +1 -0
  721. package/test/contracts/out/CrossChainEnabledOptimism.sol/CrossChainEnabledOptimism.json +1 -0
  722. package/test/contracts/out/CrossChainEnabledPolygonChild.sol/CrossChainEnabledPolygonChild.json +1 -0
  723. package/test/contracts/out/DoubleEndedQueue.sol/DoubleEndedQueue.json +1 -0
  724. package/test/contracts/out/DummyImplementation.sol/DummyImplementation.json +1 -0
  725. package/test/contracts/out/DummyImplementation.sol/DummyImplementationV2.json +1 -0
  726. package/test/contracts/out/DummyImplementation.sol/Impl.json +1 -0
  727. package/test/contracts/out/ECDSA.sol/ECDSA.json +1 -0
  728. package/test/contracts/out/EIP712.sol/EIP712.json +1 -0
  729. package/test/contracts/out/EIP712Verifier.sol/EIP712Verifier.json +1 -0
  730. package/test/contracts/out/ERC1155.sol/ERC1155.json +1 -0
  731. package/test/contracts/out/ERC1155Burnable.sol/ERC1155Burnable.json +1 -0
  732. package/test/contracts/out/ERC1155Holder.sol/ERC1155Holder.json +1 -0
  733. package/test/contracts/out/ERC1155Pausable.sol/ERC1155Pausable.json +1 -0
  734. package/test/contracts/out/ERC1155PresetMinterPauser.sol/ERC1155PresetMinterPauser.json +1 -0
  735. package/test/contracts/out/ERC1155Receiver.sol/ERC1155Receiver.json +1 -0
  736. package/test/contracts/out/ERC1155ReceiverMock.sol/ERC1155ReceiverMock.json +1 -0
  737. package/test/contracts/out/ERC1155Supply.sol/ERC1155Supply.json +1 -0
  738. package/test/contracts/out/ERC1155URIStorage.sol/ERC1155URIStorage.json +1 -0
  739. package/test/contracts/out/ERC1271WalletMock.sol/ERC1271MaliciousMock.json +1 -0
  740. package/test/contracts/out/ERC1271WalletMock.sol/ERC1271WalletMock.json +1 -0
  741. package/test/contracts/out/ERC165.sol/ERC165.json +1 -0
  742. package/test/contracts/out/ERC165Checker.sol/ERC165Checker.json +1 -0
  743. package/test/contracts/out/ERC165MaliciousData.sol/ERC165MaliciousData.json +1 -0
  744. package/test/contracts/out/ERC165MissingData.sol/ERC165MissingData.json +1 -0
  745. package/test/contracts/out/ERC165NotSupported.sol/ERC165NotSupported.json +1 -0
  746. package/test/contracts/out/ERC165ReturnBomb.sol/ERC165ReturnBombMock.json +1 -0
  747. package/test/contracts/out/ERC165Storage.sol/ERC165Storage.json +1 -0
  748. package/test/contracts/out/ERC1820Implementer.sol/ERC1820Implementer.json +1 -0
  749. package/test/contracts/out/ERC1967Proxy.sol/ERC1967Proxy.json +1 -0
  750. package/test/contracts/out/ERC1967Upgrade.sol/ERC1967Upgrade.json +1 -0
  751. package/test/contracts/out/ERC20.sol/ERC20.json +1 -0
  752. package/test/contracts/out/ERC20Burnable.sol/ERC20Burnable.json +1 -0
  753. package/test/contracts/out/ERC20Capped.sol/ERC20Capped.json +1 -0
  754. package/test/contracts/out/ERC20DecimalsMock.sol/ERC20DecimalsMock.json +1 -0
  755. package/test/contracts/out/ERC20ExcessDecimalsMock.sol/ERC20ExcessDecimalsMock.json +1 -0
  756. package/test/contracts/out/ERC20FlashMint.sol/ERC20FlashMint.json +1 -0
  757. package/test/contracts/out/ERC20FlashMintMock.sol/ERC20FlashMintMock.json +1 -0
  758. package/test/contracts/out/ERC20ForceApproveMock.sol/ERC20ForceApproveMock.json +1 -0
  759. package/test/contracts/out/ERC20Mock.sol/ERC20Mock.json +1 -0
  760. package/test/contracts/out/ERC20MulticallMock.sol/ERC20MulticallMock.json +1 -0
  761. package/test/contracts/out/ERC20NoReturnMock.sol/ERC20NoReturnMock.json +1 -0
  762. package/test/contracts/out/ERC20Pausable.sol/ERC20Pausable.json +1 -0
  763. package/test/contracts/out/ERC20Permit.sol/ERC20Permit.json +1 -0
  764. package/test/contracts/out/ERC20PermitNoRevertMock.sol/ERC20PermitNoRevertMock.json +1 -0
  765. package/test/contracts/out/ERC20PresetFixedSupply.sol/ERC20PresetFixedSupply.json +1 -0
  766. package/test/contracts/out/ERC20PresetMinterPauser.sol/ERC20PresetMinterPauser.json +1 -0
  767. package/test/contracts/out/ERC20Reentrant.sol/ERC20Reentrant.json +1 -0
  768. package/test/contracts/out/ERC20ReturnFalseMock.sol/ERC20ReturnFalseMock.json +1 -0
  769. package/test/contracts/out/ERC20Snapshot.sol/ERC20Snapshot.json +1 -0
  770. package/test/contracts/out/ERC20Votes.sol/ERC20Votes.json +1 -0
  771. package/test/contracts/out/ERC20VotesComp.sol/ERC20VotesComp.json +1 -0
  772. package/test/contracts/out/ERC20VotesLegacyMock.sol/ERC20VotesLegacyMock.json +1 -0
  773. package/test/contracts/out/ERC20Wrapper.sol/ERC20Wrapper.json +1 -0
  774. package/test/contracts/out/ERC2771Context.sol/ERC2771Context.json +1 -0
  775. package/test/contracts/out/ERC2771ContextMock.sol/ERC2771ContextMock.json +1 -0
  776. package/test/contracts/out/ERC2981.sol/ERC2981.json +1 -0
  777. package/test/contracts/out/ERC3156FlashBorrowerMock.sol/ERC3156FlashBorrowerMock.json +1 -0
  778. package/test/contracts/out/ERC4626.prop.sol/ERC4626Prop.json +1 -0
  779. package/test/contracts/out/ERC4626.prop.sol/IERC20.json +1 -0
  780. package/test/contracts/out/ERC4626.prop.sol/IERC4626.json +1 -0
  781. package/test/contracts/out/ERC4626.sol/ERC4626.json +1 -0
  782. package/test/contracts/out/ERC4626.t.sol/ERC4626StdTest.json +1 -0
  783. package/test/contracts/out/ERC4626.t.sol/ERC4626VaultOffsetMock.json +1 -0
  784. package/test/contracts/out/ERC4626.test.sol/ERC4626Test.json +1 -0
  785. package/test/contracts/out/ERC4626.test.sol/IMockERC20.json +1 -0
  786. package/test/contracts/out/ERC4626Fees.sol/ERC4626Fees.json +1 -0
  787. package/test/contracts/out/ERC4626Mock.sol/ERC4626Mock.json +1 -0
  788. package/test/contracts/out/ERC4626OffsetMock.sol/ERC4626OffsetMock.json +1 -0
  789. package/test/contracts/out/ERC4646FeesMock.sol/ERC4626FeesMock.json +1 -0
  790. package/test/contracts/out/ERC721.sol/ERC721.json +1 -0
  791. package/test/contracts/out/ERC721Burnable.sol/ERC721Burnable.json +1 -0
  792. package/test/contracts/out/ERC721Consecutive.sol/ERC721Consecutive.json +1 -0
  793. package/test/contracts/out/ERC721Consecutive.t.sol/ERC721ConsecutiveTarget.json +1 -0
  794. package/test/contracts/out/ERC721Consecutive.t.sol/ERC721ConsecutiveTest.json +1 -0
  795. package/test/contracts/out/ERC721ConsecutiveEnumerableMock.sol/ERC721ConsecutiveEnumerableMock.json +1 -0
  796. package/test/contracts/out/ERC721ConsecutiveMock.sol/ERC721ConsecutiveMock.json +1 -0
  797. package/test/contracts/out/ERC721ConsecutiveMock.sol/ERC721ConsecutiveNoConstructorMintMock.json +1 -0
  798. package/test/contracts/out/ERC721Enumerable.sol/ERC721Enumerable.json +1 -0
  799. package/test/contracts/out/ERC721Holder.sol/ERC721Holder.json +1 -0
  800. package/test/contracts/out/ERC721Pausable.sol/ERC721Pausable.json +1 -0
  801. package/test/contracts/out/ERC721PresetMinterPauserAutoId.sol/ERC721PresetMinterPauserAutoId.json +1 -0
  802. package/test/contracts/out/ERC721ReceiverMock.sol/ERC721ReceiverMock.json +1 -0
  803. package/test/contracts/out/ERC721Royalty.sol/ERC721Royalty.json +1 -0
  804. package/test/contracts/out/ERC721URIStorage.sol/ERC721URIStorage.json +1 -0
  805. package/test/contracts/out/ERC721URIStorageMock.sol/ERC721URIStorageMock.json +1 -0
  806. package/test/contracts/out/ERC721Votes.sol/ERC721Votes.json +1 -0
  807. package/test/contracts/out/ERC721Wrapper.sol/ERC721Wrapper.json +1 -0
  808. package/test/contracts/out/ERC777.sol/ERC777.json +1 -0
  809. package/test/contracts/out/ERC777Mock.sol/ERC777Mock.json +1 -0
  810. package/test/contracts/out/ERC777PresetFixedSupply.sol/ERC777PresetFixedSupply.json +1 -0
  811. package/test/contracts/out/ERC777SenderRecipientMock.sol/ERC777SenderRecipientMock.json +1 -0
  812. package/test/contracts/out/EnumerableMap.sol/EnumerableMap.json +1 -0
  813. package/test/contracts/out/EnumerableSet.sol/EnumerableSet.json +1 -0
  814. package/test/contracts/out/Escrow.sol/Escrow.json +1 -0
  815. package/test/contracts/out/EtherReceiverMock.sol/EtherReceiverMock.json +1 -0
  816. package/test/contracts/out/Governor.sol/Governor.json +1 -0
  817. package/test/contracts/out/Governor.t.sol/GovernorInternalTest.json +1 -0
  818. package/test/contracts/out/GovernorCompMock.sol/GovernorCompMock.json +1 -0
  819. package/test/contracts/out/GovernorCompatibilityBravo.sol/GovernorCompatibilityBravo.json +1 -0
  820. package/test/contracts/out/GovernorCompatibilityBravoMock.sol/GovernorCompatibilityBravoMock.json +1 -0
  821. package/test/contracts/out/GovernorCountingSimple.sol/GovernorCountingSimple.json +1 -0
  822. package/test/contracts/out/GovernorMock.sol/GovernorMock.json +1 -0
  823. package/test/contracts/out/GovernorPreventLateQuorum.sol/GovernorPreventLateQuorum.json +1 -0
  824. package/test/contracts/out/GovernorPreventLateQuorumMock.sol/GovernorPreventLateQuorumMock.json +1 -0
  825. package/test/contracts/out/GovernorProposalThreshold.sol/GovernorProposalThreshold.json +1 -0
  826. package/test/contracts/out/GovernorSettings.sol/GovernorSettings.json +1 -0
  827. package/test/contracts/out/GovernorTimelockCompound.sol/GovernorTimelockCompound.json +1 -0
  828. package/test/contracts/out/GovernorTimelockCompoundMock.sol/GovernorTimelockCompoundMock.json +1 -0
  829. package/test/contracts/out/GovernorTimelockControl.sol/GovernorTimelockControl.json +1 -0
  830. package/test/contracts/out/GovernorTimelockControlMock.sol/GovernorTimelockControlMock.json +1 -0
  831. package/test/contracts/out/GovernorVoteMock.sol/GovernorVoteMocks.json +1 -0
  832. package/test/contracts/out/GovernorVotes.sol/GovernorVotes.json +1 -0
  833. package/test/contracts/out/GovernorVotesComp.sol/GovernorVotesComp.json +1 -0
  834. package/test/contracts/out/GovernorVotesQuorumFraction.sol/GovernorVotesQuorumFraction.json +1 -0
  835. package/test/contracts/out/GovernorWithParamsMock.sol/GovernorWithParamsMock.json +1 -0
  836. package/test/contracts/out/IAMB.sol/IAMB.json +1 -0
  837. package/test/contracts/out/IAccessControl.sol/IAccessControl.json +1 -0
  838. package/test/contracts/out/IAccessControlDefaultAdminRules.sol/IAccessControlDefaultAdminRules.json +1 -0
  839. package/test/contracts/out/IAccessControlEnumerable.sol/IAccessControlEnumerable.json +1 -0
  840. package/test/contracts/out/IArbSys.sol/IArbSys.json +1 -0
  841. package/test/contracts/out/IBeacon.sol/IBeacon.json +1 -0
  842. package/test/contracts/out/IBridge.sol/IBridge.json +1 -0
  843. package/test/contracts/out/ICompoundTimelock.sol/ICompoundTimelock.json +1 -0
  844. package/test/contracts/out/ICrossDomainMessenger.sol/ICrossDomainMessenger.json +1 -0
  845. package/test/contracts/out/IDelayedMessageProvider.sol/IDelayedMessageProvider.json +1 -0
  846. package/test/contracts/out/IERC1155.sol/IERC1155.json +1 -0
  847. package/test/contracts/out/IERC1155MetadataURI.sol/IERC1155MetadataURI.json +1 -0
  848. package/test/contracts/out/IERC1155Receiver.sol/IERC1155Receiver.json +1 -0
  849. package/test/contracts/out/IERC1271.sol/IERC1271.json +1 -0
  850. package/test/contracts/out/IERC1363.sol/IERC1363.json +1 -0
  851. package/test/contracts/out/IERC1363Receiver.sol/IERC1363Receiver.json +1 -0
  852. package/test/contracts/out/IERC1363Spender.sol/IERC1363Spender.json +1 -0
  853. package/test/contracts/out/IERC165.sol/IERC165.json +1 -0
  854. package/test/contracts/out/IERC1820Implementer.sol/IERC1820Implementer.json +1 -0
  855. package/test/contracts/out/IERC1820Registry.sol/IERC1820Registry.json +1 -0
  856. package/test/contracts/out/IERC1967.sol/IERC1967.json +1 -0
  857. package/test/contracts/out/IERC20.sol/IERC20.json +1 -0
  858. package/test/contracts/out/IERC20Metadata.sol/IERC20Metadata.json +1 -0
  859. package/test/contracts/out/IERC20Permit.sol/IERC20Permit.json +1 -0
  860. package/test/contracts/out/IERC2309.sol/IERC2309.json +1 -0
  861. package/test/contracts/out/IERC2612.sol/IERC2612.json +1 -0
  862. package/test/contracts/out/IERC2981.sol/IERC2981.json +1 -0
  863. package/test/contracts/out/IERC3156FlashBorrower.sol/IERC3156FlashBorrower.json +1 -0
  864. package/test/contracts/out/IERC3156FlashLender.sol/IERC3156FlashLender.json +1 -0
  865. package/test/contracts/out/IERC4626.sol/IERC4626.json +1 -0
  866. package/test/contracts/out/IERC4906.sol/IERC4906.json +1 -0
  867. package/test/contracts/out/IERC5267.sol/IERC5267.json +1 -0
  868. package/test/contracts/out/IERC5313.sol/IERC5313.json +1 -0
  869. package/test/contracts/out/IERC5805.sol/IERC5805.json +1 -0
  870. package/test/contracts/out/IERC6372.sol/IERC6372.json +1 -0
  871. package/test/contracts/out/IERC721.sol/IERC721.json +1 -0
  872. package/test/contracts/out/IERC721.sol/IERC721Enumerable.json +1 -0
  873. package/test/contracts/out/IERC721.sol/IERC721Metadata.json +1 -0
  874. package/test/contracts/out/IERC721.sol/IERC721TokenReceiver.json +1 -0
  875. package/test/contracts/out/IERC721Enumerable.sol/IERC721Enumerable.json +1 -0
  876. package/test/contracts/out/IERC721Metadata.sol/IERC721Metadata.json +1 -0
  877. package/test/contracts/out/IERC721Receiver.sol/IERC721Receiver.json +1 -0
  878. package/test/contracts/out/IERC777.sol/IERC777.json +1 -0
  879. package/test/contracts/out/IERC777Recipient.sol/IERC777Recipient.json +1 -0
  880. package/test/contracts/out/IERC777Sender.sol/IERC777Sender.json +1 -0
  881. package/test/contracts/out/IFxMessageProcessor.sol/IFxMessageProcessor.json +1 -0
  882. package/test/contracts/out/IGovernor.sol/IGovernor.json +1 -0
  883. package/test/contracts/out/IGovernorCompatibilityBravo.sol/IGovernorCompatibilityBravo.json +1 -0
  884. package/test/contracts/out/IGovernorTimelock.sol/IGovernorTimelock.json +1 -0
  885. package/test/contracts/out/IInbox.sol/IInbox.json +1 -0
  886. package/test/contracts/out/IMulticall3.sol/IMulticall3.json +1 -0
  887. package/test/contracts/out/IOutbox.sol/IOutbox.json +1 -0
  888. package/test/contracts/out/IVotes.sol/IVotes.json +1 -0
  889. package/test/contracts/out/Initializable.sol/Initializable.json +1 -0
  890. package/test/contracts/out/InitializableMock.sol/ChildConstructorInitializableMock.json +1 -0
  891. package/test/contracts/out/InitializableMock.sol/ConstructorInitializableMock.json +1 -0
  892. package/test/contracts/out/InitializableMock.sol/DisableBad1.json +1 -0
  893. package/test/contracts/out/InitializableMock.sol/DisableBad2.json +1 -0
  894. package/test/contracts/out/InitializableMock.sol/DisableNew.json +1 -0
  895. package/test/contracts/out/InitializableMock.sol/DisableOk.json +1 -0
  896. package/test/contracts/out/InitializableMock.sol/DisableOld.json +1 -0
  897. package/test/contracts/out/InitializableMock.sol/InitializableMock.json +1 -0
  898. package/test/contracts/out/InitializableMock.sol/ReinitializerMock.json +1 -0
  899. package/test/contracts/out/LibAMB.sol/LibAMB.json +1 -0
  900. package/test/contracts/out/LibArbitrumL1.sol/LibArbitrumL1.json +1 -0
  901. package/test/contracts/out/LibArbitrumL2.sol/LibArbitrumL2.json +1 -0
  902. package/test/contracts/out/LibOptimism.sol/LibOptimism.json +1 -0
  903. package/test/contracts/out/Math.sol/Math.json +1 -0
  904. package/test/contracts/out/Math.t.sol/MathTest.json +1 -0
  905. package/test/contracts/out/MerkleProof.sol/MerkleProof.json +1 -0
  906. package/test/contracts/out/MinimalForwarder.sol/MinimalForwarder.json +1 -0
  907. package/test/contracts/out/MockMiladyAgentRegistry.sol/MockMiladyAgentRegistry.json +1 -0
  908. package/test/contracts/out/MockMiladyCollection.sol/MockMiladyCollection.json +1 -0
  909. package/test/contracts/out/Multicall.sol/Multicall.json +1 -0
  910. package/test/contracts/out/MulticallTest.sol/MulticallTest.json +1 -0
  911. package/test/contracts/out/MultipleInheritanceInitializableMocks.sol/SampleChild.json +1 -0
  912. package/test/contracts/out/MultipleInheritanceInitializableMocks.sol/SampleFather.json +1 -0
  913. package/test/contracts/out/MultipleInheritanceInitializableMocks.sol/SampleGramps.json +1 -0
  914. package/test/contracts/out/MultipleInheritanceInitializableMocks.sol/SampleHuman.json +1 -0
  915. package/test/contracts/out/MultipleInheritanceInitializableMocks.sol/SampleMother.json +1 -0
  916. package/test/contracts/out/MyGovernor.sol/MyGovernor.json +1 -0
  917. package/test/contracts/out/MyGovernor1.sol/MyGovernor1.json +1 -0
  918. package/test/contracts/out/MyGovernor2.sol/MyGovernor2.json +1 -0
  919. package/test/contracts/out/MyGovernor3.sol/MyGovernor3.json +1 -0
  920. package/test/contracts/out/MyToken.sol/MyToken.json +1 -0
  921. package/test/contracts/out/MyTokenTimestampBased.sol/MyTokenTimestampBased.json +1 -0
  922. package/test/contracts/out/MyTokenWrapped.sol/MyTokenWrapped.json +1 -0
  923. package/test/contracts/out/Ownable.sol/Ownable.json +1 -0
  924. package/test/contracts/out/Ownable2Step.sol/Ownable2Step.json +1 -0
  925. package/test/contracts/out/Pausable.sol/Pausable.json +1 -0
  926. package/test/contracts/out/PausableMock.sol/PausableMock.json +1 -0
  927. package/test/contracts/out/PaymentSplitter.sol/PaymentSplitter.json +1 -0
  928. package/test/contracts/out/Proxy.sol/Proxy.json +1 -0
  929. package/test/contracts/out/ProxyAdmin.sol/ProxyAdmin.json +1 -0
  930. package/test/contracts/out/PullPayment.sol/PullPayment.json +1 -0
  931. package/test/contracts/out/PullPaymentMock.sol/PullPaymentMock.json +1 -0
  932. package/test/contracts/out/ReentrancyAttack.sol/ReentrancyAttack.json +1 -0
  933. package/test/contracts/out/ReentrancyGuard.sol/ReentrancyGuard.json +1 -0
  934. package/test/contracts/out/ReentrancyMock.sol/ReentrancyMock.json +1 -0
  935. package/test/contracts/out/RefundEscrow.sol/RefundEscrow.json +1 -0
  936. package/test/contracts/out/RegressionImplementation.sol/Implementation1.json +1 -0
  937. package/test/contracts/out/RegressionImplementation.sol/Implementation2.json +1 -0
  938. package/test/contracts/out/RegressionImplementation.sol/Implementation3.json +1 -0
  939. package/test/contracts/out/RegressionImplementation.sol/Implementation4.json +1 -0
  940. package/test/contracts/out/SafeCast.sol/SafeCast.json +1 -0
  941. package/test/contracts/out/SafeERC20.sol/SafeERC20.json +1 -0
  942. package/test/contracts/out/SafeMath.sol/SafeMath.json +1 -0
  943. package/test/contracts/out/SafeMathMemoryCheck.sol/SafeMathMemoryCheck.json +1 -0
  944. package/test/contracts/out/Script.sol/Script.json +1 -0
  945. package/test/contracts/out/ShortStrings.sol/ShortStrings.json +1 -0
  946. package/test/contracts/out/ShortStrings.t.sol/ShortStringsTest.json +1 -0
  947. package/test/contracts/out/SignatureChecker.sol/SignatureChecker.json +1 -0
  948. package/test/contracts/out/SignedMath.sol/SignedMath.json +1 -0
  949. package/test/contracts/out/SignedSafeMath.sol/SignedSafeMath.json +1 -0
  950. package/test/contracts/out/SingleInheritanceInitializableMocks.sol/MigratableMockV1.json +1 -0
  951. package/test/contracts/out/SingleInheritanceInitializableMocks.sol/MigratableMockV2.json +1 -0
  952. package/test/contracts/out/SingleInheritanceInitializableMocks.sol/MigratableMockV3.json +1 -0
  953. package/test/contracts/out/StdAssertions.sol/StdAssertions.json +1 -0
  954. package/test/contracts/out/StdAssertions.t.sol/StdAssertionsTest.json +1 -0
  955. package/test/contracts/out/StdAssertions.t.sol/TestMockCall.json +1 -0
  956. package/test/contracts/out/StdAssertions.t.sol/TestTest.json +1 -0
  957. package/test/contracts/out/StdChains.sol/StdChains.json +1 -0
  958. package/test/contracts/out/StdChains.t.sol/StdChainsTest.json +1 -0
  959. package/test/contracts/out/StdCheats.sol/StdCheats.json +1 -0
  960. package/test/contracts/out/StdCheats.sol/StdCheatsSafe.json +1 -0
  961. package/test/contracts/out/StdCheats.t.sol/Bar.json +1 -0
  962. package/test/contracts/out/StdCheats.t.sol/BarERC1155.json +1 -0
  963. package/test/contracts/out/StdCheats.t.sol/BarERC721.json +1 -0
  964. package/test/contracts/out/StdCheats.t.sol/RevertingContract.json +1 -0
  965. package/test/contracts/out/StdCheats.t.sol/StdCheatsTest.json +1 -0
  966. package/test/contracts/out/StdError.sol/stdError.json +1 -0
  967. package/test/contracts/out/StdError.t.sol/ErrorsTest.json +1 -0
  968. package/test/contracts/out/StdError.t.sol/StdErrorsTest.json +1 -0
  969. package/test/contracts/out/StdInvariant.sol/StdInvariant.json +1 -0
  970. package/test/contracts/out/StdJson.sol/stdJson.json +1 -0
  971. package/test/contracts/out/StdMath.sol/stdMath.json +1 -0
  972. package/test/contracts/out/StdMath.t.sol/StdMathTest.json +1 -0
  973. package/test/contracts/out/StdStorage.sol/stdStorage.json +1 -0
  974. package/test/contracts/out/StdStorage.sol/stdStorageSafe.json +1 -0
  975. package/test/contracts/out/StdStorage.t.sol/StdStorageTest.json +1 -0
  976. package/test/contracts/out/StdStorage.t.sol/StorageTest.json +1 -0
  977. package/test/contracts/out/StdStyle.sol/StdStyle.json +1 -0
  978. package/test/contracts/out/StdStyle.t.sol/StdStyleTest.json +1 -0
  979. package/test/contracts/out/StdUtils.sol/StdUtils.json +1 -0
  980. package/test/contracts/out/StdUtils.t.sol/StdUtilsForkTest.json +1 -0
  981. package/test/contracts/out/StdUtils.t.sol/StdUtilsMock.json +1 -0
  982. package/test/contracts/out/StdUtils.t.sol/StdUtilsTest.json +1 -0
  983. package/test/contracts/out/StorageSlot.sol/StorageSlot.json +1 -0
  984. package/test/contracts/out/StorageSlotMock.sol/StorageSlotMock.json +1 -0
  985. package/test/contracts/out/Strings.sol/Strings.json +1 -0
  986. package/test/contracts/out/TimelockController.sol/TimelockController.json +1 -0
  987. package/test/contracts/out/TimelockReentrant.sol/TimelockReentrant.json +1 -0
  988. package/test/contracts/out/Timers.sol/Timers.json +1 -0
  989. package/test/contracts/out/TimersBlockNumberImpl.sol/TimersBlockNumberImpl.json +1 -0
  990. package/test/contracts/out/TimersTimestampImpl.sol/TimersTimestampImpl.json +1 -0
  991. package/test/contracts/out/TokenTimelock.sol/TokenTimelock.json +1 -0
  992. package/test/contracts/out/TransparentUpgradeableProxy.sol/ITransparentUpgradeableProxy.json +1 -0
  993. package/test/contracts/out/TransparentUpgradeableProxy.sol/TransparentUpgradeableProxy.json +1 -0
  994. package/test/contracts/out/UUPSLegacy.sol/UUPSUpgradeableLegacyMock.json +1 -0
  995. package/test/contracts/out/UUPSUpgradeable.sol/UUPSUpgradeable.json +1 -0
  996. package/test/contracts/out/UUPSUpgradeableMock.sol/NonUpgradeableMock.json +1 -0
  997. package/test/contracts/out/UUPSUpgradeableMock.sol/UUPSUpgradeableMock.json +1 -0
  998. package/test/contracts/out/UUPSUpgradeableMock.sol/UUPSUpgradeableUnsafeMock.json +1 -0
  999. package/test/contracts/out/UpgradeableBeacon.sol/UpgradeableBeacon.json +1 -0
  1000. package/test/contracts/out/VestingWallet.sol/VestingWallet.json +1 -0
  1001. package/test/contracts/out/Vm.sol/Vm.json +1 -0
  1002. package/test/contracts/out/Vm.sol/VmSafe.json +1 -0
  1003. package/test/contracts/out/Votes.sol/Votes.json +1 -0
  1004. package/test/contracts/out/VotesMock.sol/VotesMock.json +1 -0
  1005. package/test/contracts/out/VotesMock.sol/VotesTimestampMock.json +1 -0
  1006. package/test/contracts/out/VotesTimestamp.sol/ERC20VotesCompTimestampMock.json +1 -0
  1007. package/test/contracts/out/VotesTimestamp.sol/ERC20VotesTimestampMock.json +1 -0
  1008. package/test/contracts/out/VotesTimestamp.sol/ERC721VotesTimestampMock.json +1 -0
  1009. package/test/contracts/out/bridges.sol/BaseRelayMock.json +1 -0
  1010. package/test/contracts/out/bridges.sol/BridgeAMBMock.json +1 -0
  1011. package/test/contracts/out/bridges.sol/BridgeArbitrumL1Inbox.json +1 -0
  1012. package/test/contracts/out/bridges.sol/BridgeArbitrumL1Mock.json +1 -0
  1013. package/test/contracts/out/bridges.sol/BridgeArbitrumL1Outbox.json +1 -0
  1014. package/test/contracts/out/bridges.sol/BridgeArbitrumL2Mock.json +1 -0
  1015. package/test/contracts/out/bridges.sol/BridgeOptimismMock.json +1 -0
  1016. package/test/contracts/out/bridges.sol/BridgePolygonChildMock.json +1 -0
  1017. package/test/contracts/out/build-info/2be03bb8eb1ccda1.json +1 -0
  1018. package/test/contracts/out/console.sol/console.json +1 -0
  1019. package/test/contracts/out/console2.sol/console2.json +1 -0
  1020. package/test/contracts/out/demo.sol/DemoTest.json +1 -0
  1021. package/test/contracts/out/demo.sol/DemoTestWithSetUp.json +1 -0
  1022. package/test/contracts/out/draft-IERC1822.sol/IERC1822Proxiable.json +1 -0
  1023. package/test/contracts/out/interfaces/IERC1155.sol/IERC1155.json +1 -0
  1024. package/test/contracts/out/interfaces/IERC165.sol/IERC165.json +1 -0
  1025. package/test/contracts/out/interfaces/IERC20.sol/IERC20.json +1 -0
  1026. package/test/contracts/out/interfaces/IERC4626.sol/IERC4626.json +1 -0
  1027. package/test/contracts/out/interfaces/IERC721.sol/IERC721.json +1 -0
  1028. package/test/contracts/out/receivers.sol/CrossChainEnabledAMBMock.json +1 -0
  1029. package/test/contracts/out/receivers.sol/CrossChainEnabledArbitrumL1Mock.json +1 -0
  1030. package/test/contracts/out/receivers.sol/CrossChainEnabledArbitrumL2Mock.json +1 -0
  1031. package/test/contracts/out/receivers.sol/CrossChainEnabledOptimismMock.json +1 -0
  1032. package/test/contracts/out/receivers.sol/CrossChainEnabledPolygonChildMock.json +1 -0
  1033. package/test/contracts/out/receivers.sol/Receiver.json +1 -0
  1034. package/test/contracts/out/test.sol/DSTest.json +1 -0
  1035. package/test/contracts/out/test.sol/Test.json +1 -0
  1036. package/test/contracts/out/test.t.sol/DemoTest.json +1 -0
  1037. package/test/database-api.e2e.test.ts +666 -0
  1038. package/test/debug-anvil.ts +44 -0
  1039. package/test/deferred-restart.e2e.test.ts +368 -0
  1040. package/test/discord-connector.e2e.test.ts +463 -0
  1041. package/test/e2e-global-setup.ts +29 -0
  1042. package/test/e2e-validation.e2e.test.ts +1588 -0
  1043. package/test/health-endpoint.e2e.test.ts +95 -0
  1044. package/test/knowledge-e2e-flow.e2e.test.ts +134 -0
  1045. package/test/knowledge-live.e2e.test.ts +405 -0
  1046. package/test/mcp-config.e2e.test.ts +630 -0
  1047. package/test/native-modules.e2e.test.ts +470 -0
  1048. package/test/permissions-api.e2e.test.ts +637 -0
  1049. package/test/plugin-install.e2e.test.ts +645 -0
  1050. package/test/plugin-lifecycle.e2e.test.ts +617 -0
  1051. package/test/plugin-management.e2e.test.ts +308 -0
  1052. package/test/provider-switch.e2e.test.ts +322 -0
  1053. package/test/scripts/test-force.ts +139 -0
  1054. package/test/scripts/test-parallel.mjs +192 -0
  1055. package/test/scripts/validate-all-features.sh +557 -0
  1056. package/test/setup.ts +122 -0
  1057. package/test/signal-connector.e2e.test.ts +229 -0
  1058. package/test/skills-marketplace-api.e2e.test.ts +585 -0
  1059. package/test/skills-marketplace-services.e2e.test.ts +518 -0
  1060. package/test/skills-marketplace.e2e.test.ts +268 -0
  1061. package/test/stubs/coding-agent-module.ts +18 -0
  1062. package/test/stubs/electron-module.ts +17 -0
  1063. package/test/stubs/empty-module.mjs +4 -0
  1064. package/test/stubs/pi-ai-module.ts +12 -0
  1065. package/test/subscription-auth.e2e.test.ts +747 -0
  1066. package/test/terminal-execution.e2e.test.ts +134 -0
  1067. package/test/terminal-run-limits.e2e.test.ts +132 -0
  1068. package/test/test-env.ts +156 -0
  1069. package/test/trajectory-collection.e2e.test.ts +800 -0
  1070. package/test/trajectory-database.e2e.test.ts +209 -0
  1071. package/test/trajectory-embedding-filter.e2e.test.ts +317 -0
  1072. package/test/trajectory-restart-carryover.e2e.test.ts +306 -0
  1073. package/test/trigger-execution-flow.e2e.test.ts +132 -0
  1074. package/test/trigger-runtime.e2e.test.ts +247 -0
  1075. package/test/wallet-api.e2e.test.ts +1295 -0
  1076. package/test/wallet-live.e2e.test.ts +428 -0
  1077. package/vitest.e2e.config.ts +71 -0
@@ -0,0 +1,1568 @@
1
+ /**
2
+ * End-to-End Tests for Agent Orchestration — GitHub Issue #6 Follow-up
3
+ *
4
+ * Comprehensive E2E tests covering agent orchestration functionality:
5
+ *
6
+ * 1. Task creation and lifecycle (pending → running → completed/failed)
7
+ * 2. Subagent spawning and management
8
+ * 3. Message passing between parent and subagents
9
+ * 4. Task cancellation, pause, and resume
10
+ * 5. Concurrent task handling
11
+ * 6. Cleanup after subagent termination
12
+ * 7. Error handling and recovery
13
+ * 8. API integration for orchestrator endpoints
14
+ *
15
+ * NO MOCKS — all tests use real production code paths where possible.
16
+ */
17
+ import crypto from "node:crypto";
18
+ import fs from "node:fs";
19
+ import http from "node:http";
20
+ import os from "node:os";
21
+ import path from "node:path";
22
+ import { fileURLToPath } from "node:url";
23
+ import {
24
+ AgentRuntime,
25
+ createCharacter,
26
+ logger,
27
+ type Plugin,
28
+ type UUID,
29
+ } from "@elizaos/core";
30
+ import dotenv from "dotenv";
31
+ import { afterAll, beforeAll, describe, expect, it } from "vitest";
32
+ import { startApiServer } from "../src/api/server";
33
+ import {
34
+ extractPlugin,
35
+ isPackageImportResolvable,
36
+ type PluginModuleShape,
37
+ } from "../src/test-support/test-helpers";
38
+
39
+ // ---------------------------------------------------------------------------
40
+ // Environment
41
+ // ---------------------------------------------------------------------------
42
+
43
+ const testDir = path.dirname(fileURLToPath(import.meta.url));
44
+ const packageRoot = path.resolve(testDir, "..");
45
+
46
+ dotenv.config({ path: path.resolve(packageRoot, ".env") });
47
+
48
+ const hasOpenAI = Boolean(process.env.OPENAI_API_KEY);
49
+ const hasAnthropic = Boolean(process.env.ANTHROPIC_API_KEY);
50
+ const hasGroq = Boolean(process.env.GROQ_API_KEY);
51
+ const liveModelTestsEnabled = process.env.MILADY_LIVE_TEST === "1";
52
+ const hasModelProvider =
53
+ liveModelTestsEnabled && (hasOpenAI || hasAnthropic || hasGroq);
54
+
55
+ // ---------------------------------------------------------------------------
56
+ // Plugin loader
57
+ // ---------------------------------------------------------------------------
58
+
59
+ async function loadPlugin(name: string): Promise<Plugin | null> {
60
+ try {
61
+ if (!isPackageImportResolvable(name)) {
62
+ logger.warn(`[agent-orchestration-e2e] Plugin not resolvable: ${name}`);
63
+ return null;
64
+ }
65
+ const mod = (await import(name)) as PluginModuleShape;
66
+ return extractPlugin(mod);
67
+ } catch (err) {
68
+ const msg = err instanceof Error ? err.message : String(err);
69
+ logger.warn(`[agent-orchestration-e2e] Failed to load ${name}: ${msg}`);
70
+ return null;
71
+ }
72
+ }
73
+
74
+ // ---------------------------------------------------------------------------
75
+ // HTTP helper
76
+ // ---------------------------------------------------------------------------
77
+
78
+ function http$(
79
+ port: number,
80
+ method: string,
81
+ p: string,
82
+ body?: Record<string, unknown>,
83
+ timeoutMs: number = 30_000,
84
+ ): Promise<{ status: number; data: Record<string, unknown> }> {
85
+ return new Promise((resolve, reject) => {
86
+ const timer = setTimeout(
87
+ () => reject(new Error(`HTTP request timed out: ${method} ${p}`)),
88
+ timeoutMs,
89
+ );
90
+ const b = body ? JSON.stringify(body) : undefined;
91
+ const req = http.request(
92
+ {
93
+ hostname: "127.0.0.1",
94
+ port,
95
+ path: p,
96
+ method,
97
+ headers: {
98
+ "Content-Type": "application/json",
99
+ ...(b ? { "Content-Length": Buffer.byteLength(b) } : {}),
100
+ },
101
+ },
102
+ (res) => {
103
+ const ch: Buffer[] = [];
104
+ res.on("data", (c: Buffer) => ch.push(c));
105
+ res.on("end", () => {
106
+ clearTimeout(timer);
107
+ const raw = Buffer.concat(ch).toString("utf-8");
108
+ let data: Record<string, unknown> = {};
109
+ try {
110
+ data = JSON.parse(raw) as Record<string, unknown>;
111
+ } catch {
112
+ data = { _raw: raw };
113
+ }
114
+ resolve({ status: res.statusCode ?? 0, data });
115
+ });
116
+ },
117
+ );
118
+ req.on("error", (err) => {
119
+ clearTimeout(timer);
120
+ reject(err);
121
+ });
122
+ if (b) req.write(b);
123
+ req.end();
124
+ });
125
+ }
126
+
127
+ // ---------------------------------------------------------------------------
128
+ // Types for orchestrator service
129
+ // ---------------------------------------------------------------------------
130
+
131
+ type TaskStatus =
132
+ | "pending"
133
+ | "running"
134
+ | "completed"
135
+ | "failed"
136
+ | "paused"
137
+ | "cancelled";
138
+
139
+ interface OrchestratedTask {
140
+ id: string;
141
+ name: string;
142
+ description: string;
143
+ roomId?: UUID;
144
+ worldId?: UUID;
145
+ metadata: {
146
+ status: TaskStatus;
147
+ progress: number;
148
+ output: string[];
149
+ steps: Array<{
150
+ id: string;
151
+ description: string;
152
+ status: TaskStatus;
153
+ output?: string;
154
+ }>;
155
+ result?: {
156
+ success: boolean;
157
+ summary: string;
158
+ filesModified: string[];
159
+ filesCreated: string[];
160
+ error?: string;
161
+ };
162
+ error?: string;
163
+ createdAt: number;
164
+ startedAt?: number;
165
+ completedAt?: number;
166
+ providerId: string;
167
+ workingDirectory: string;
168
+ };
169
+ }
170
+
171
+ interface AgentOrchestratorService {
172
+ createTask(
173
+ name: string,
174
+ description: string,
175
+ roomId?: UUID,
176
+ providerId?: string,
177
+ requiredCapabilities?: string[],
178
+ ): Promise<OrchestratedTask>;
179
+ getTask(taskId: string): OrchestratedTask | undefined;
180
+ getTasks(): OrchestratedTask[];
181
+ getRecentTasks(limit?: number): OrchestratedTask[];
182
+ getTasksByStatus(status: TaskStatus): OrchestratedTask[];
183
+ updateTaskStatus(taskId: string, status: TaskStatus): boolean;
184
+ updateTaskProgress(taskId: string, progress: number): boolean;
185
+ appendOutput(taskId: string, output: string): boolean;
186
+ addStep(taskId: string, description: string): string | null;
187
+ updateStep(
188
+ taskId: string,
189
+ stepId: string,
190
+ status: TaskStatus,
191
+ output?: string,
192
+ ): boolean;
193
+ setTaskResult(
194
+ taskId: string,
195
+ result: OrchestratedTask["metadata"]["result"],
196
+ ): boolean;
197
+ cancelTask(taskId: string): boolean;
198
+ pauseTask(taskId: string): boolean;
199
+ resumeTask(taskId: string): boolean;
200
+ on(
201
+ eventType: string,
202
+ handler: (event: { type: string; taskId: string; data?: unknown }) => void,
203
+ ): () => void;
204
+ }
205
+
206
+ // ===================================================================
207
+ // 1. ORCHESTRATOR PLUGIN LOADING
208
+ // ===================================================================
209
+
210
+ describe("Agent Orchestrator Plugin Loading", () => {
211
+ // Note: In e2e tests, the orchestrator plugin is stubbed via vitest.e2e.config.ts
212
+ // These tests verify the stub exports work correctly for API integration
213
+
214
+ it("orchestrator module can be imported", async () => {
215
+ // The module is stubbed in e2e tests, but should still be importable
216
+ const mod = await import("@elizaos/plugin-agent-orchestrator");
217
+ expect(mod).toBeDefined();
218
+ });
219
+
220
+ it("dist bundle exports codingAgentPlugin", () => {
221
+ // Verify the orchestrator plugin dist exists and exports the main plugin
222
+ const distPath = path.resolve(
223
+ packageRoot,
224
+ "node_modules/@elizaos/plugin-agent-orchestrator/dist/index.js",
225
+ );
226
+ expect(fs.existsSync(distPath)).toBe(true);
227
+ const dist = fs.readFileSync(distPath, "utf-8");
228
+ expect(
229
+ dist.includes("agentOrchestratorPlugin") ||
230
+ dist.includes("codingAgentPlugin"),
231
+ ).toBe(true);
232
+ });
233
+
234
+ it("installed version matches package.json spec", async () => {
235
+ // The 2.0.0-alpha versions were a historical artifact from the elizaOS
236
+ // monorepo. The plugin was completely repurposed for agent orchestration
237
+ // and republished at 0.x under the `next` npm tag. We verify a valid
238
+ // semver is installed rather than pinning a minimum major version.
239
+ const pkgPath = path.resolve(
240
+ packageRoot,
241
+ "node_modules/@elizaos/plugin-agent-orchestrator/package.json",
242
+ );
243
+ const pkg = JSON.parse(fs.readFileSync(pkgPath, "utf-8")) as {
244
+ version: string;
245
+ };
246
+ expect(pkg.version).toMatch(/^\d+\.\d+\.\d+/);
247
+ });
248
+ });
249
+
250
+ // ===================================================================
251
+ // 2. TASK LIFECYCLE TESTS (with API server)
252
+ // ===================================================================
253
+
254
+ describe("Task Lifecycle via API", () => {
255
+ let server: { port: number; close: () => Promise<void> } | null = null;
256
+
257
+ beforeAll(async () => {
258
+ server = await startApiServer({ port: 0 });
259
+ // Start the agent to initialize plugins
260
+ await http$(server.port, "POST", "/api/agent/start");
261
+ }, 60_000);
262
+
263
+ afterAll(async () => {
264
+ if (server) {
265
+ await http$(server.port, "POST", "/api/agent/stop");
266
+ await server.close();
267
+ }
268
+ });
269
+
270
+ it("GET /api/coding-agents/tasks returns task list", async () => {
271
+ const { status, data } = await http$(
272
+ server?.port,
273
+ "GET",
274
+ "/api/coding-agents/tasks",
275
+ );
276
+ // Endpoint exists and returns valid response
277
+ expect([200, 404]).toContain(status);
278
+ if (status === 200) {
279
+ expect(Array.isArray(data.tasks) || data.tasks === undefined).toBe(true);
280
+ }
281
+ });
282
+
283
+ it("GET /api/coding-agents/status returns orchestrator status", async () => {
284
+ const { status, data } = await http$(
285
+ server?.port,
286
+ "GET",
287
+ "/api/coding-agents/status",
288
+ );
289
+ expect([200, 404]).toContain(status);
290
+ if (status === 200) {
291
+ expect(typeof data).toBe("object");
292
+ }
293
+ });
294
+
295
+ it("POST /api/coding-agents/tasks can create a task", async () => {
296
+ const { status, data } = await http$(
297
+ server?.port,
298
+ "POST",
299
+ "/api/coding-agents/tasks",
300
+ {
301
+ name: "E2E Test Task",
302
+ description: "A task created by the e2e test suite",
303
+ },
304
+ );
305
+ // May return 200/201 if successful, 404 if endpoint not found, or 400 for validation
306
+ expect([200, 201, 400, 404, 500]).toContain(status);
307
+ if (status === 200 || status === 201) {
308
+ expect(data.task || data.id || data.taskId).toBeDefined();
309
+ }
310
+ });
311
+
312
+ it("task status transitions: pending → running → completed", async () => {
313
+ // Create a task
314
+ const createRes = await http$(
315
+ server?.port,
316
+ "POST",
317
+ "/api/coding-agents/tasks",
318
+ {
319
+ name: "Lifecycle Test Task",
320
+ description: "Test task for lifecycle verification",
321
+ },
322
+ );
323
+
324
+ if (createRes.status !== 200 && createRes.status !== 201) {
325
+ // Skip if task creation not available
326
+ logger.info(
327
+ "[agent-orchestration-e2e] Skipping lifecycle test - task creation returned " +
328
+ createRes.status,
329
+ );
330
+ return;
331
+ }
332
+
333
+ const taskId =
334
+ (createRes.data.task as { id: string })?.id ||
335
+ (createRes.data.id as string) ||
336
+ (createRes.data.taskId as string);
337
+ expect(taskId).toBeDefined();
338
+
339
+ // Get initial status - should be pending
340
+ const getRes1 = await http$(
341
+ server?.port,
342
+ "GET",
343
+ `/api/coding-agents/tasks/${taskId}`,
344
+ );
345
+ if (getRes1.status === 200) {
346
+ const task = getRes1.data.task as OrchestratedTask | undefined;
347
+ if (task) {
348
+ expect(["pending", "running"]).toContain(task.metadata?.status);
349
+ }
350
+ }
351
+
352
+ // Update status to running
353
+ const updateRes = await http$(
354
+ server?.port,
355
+ "PATCH",
356
+ `/api/coding-agents/tasks/${taskId}`,
357
+ { status: "running" },
358
+ );
359
+ expect([200, 204, 404, 405]).toContain(updateRes.status);
360
+
361
+ // Cancel the task to clean up
362
+ await http$(
363
+ server?.port,
364
+ "POST",
365
+ `/api/coding-agents/tasks/${taskId}/cancel`,
366
+ );
367
+ }, 30_000);
368
+ });
369
+
370
+ // ===================================================================
371
+ // 3. TASK MANAGEMENT OPERATIONS
372
+ // ===================================================================
373
+
374
+ describe("Task Management Operations", () => {
375
+ let server: { port: number; close: () => Promise<void> } | null = null;
376
+ let _createdTaskId: string | null = null;
377
+
378
+ beforeAll(async () => {
379
+ server = await startApiServer({ port: 0 });
380
+ await http$(server.port, "POST", "/api/agent/start");
381
+ }, 60_000);
382
+
383
+ afterAll(async () => {
384
+ if (server) {
385
+ await http$(server.port, "POST", "/api/agent/stop");
386
+ await server.close();
387
+ }
388
+ });
389
+
390
+ it("can list all tasks", async () => {
391
+ const { status, data } = await http$(
392
+ server?.port,
393
+ "GET",
394
+ "/api/coding-agents/tasks",
395
+ );
396
+ if (status === 200) {
397
+ expect(Array.isArray(data.tasks)).toBe(true);
398
+ }
399
+ });
400
+
401
+ it("can filter tasks by status", async () => {
402
+ const { status, data } = await http$(
403
+ server?.port,
404
+ "GET",
405
+ "/api/coding-agents/tasks?status=pending",
406
+ );
407
+ if (status === 200 && Array.isArray(data.tasks)) {
408
+ for (const task of data.tasks as OrchestratedTask[]) {
409
+ expect(task.metadata?.status).toBe("pending");
410
+ }
411
+ }
412
+ });
413
+
414
+ it("can get recent tasks with limit", async () => {
415
+ const { status, data } = await http$(
416
+ server?.port,
417
+ "GET",
418
+ "/api/coding-agents/tasks?limit=5",
419
+ );
420
+ if (status === 200 && Array.isArray(data.tasks)) {
421
+ expect(data.tasks.length).toBeLessThanOrEqual(5);
422
+ }
423
+ });
424
+
425
+ it("task cancellation works correctly", async () => {
426
+ // Create a task first
427
+ const createRes = await http$(
428
+ server?.port,
429
+ "POST",
430
+ "/api/coding-agents/tasks",
431
+ {
432
+ name: "Task to Cancel",
433
+ description: "This task will be cancelled",
434
+ },
435
+ );
436
+
437
+ if (createRes.status !== 200 && createRes.status !== 201) {
438
+ return; // Skip if not available
439
+ }
440
+
441
+ const taskId =
442
+ (createRes.data.task as { id: string })?.id ||
443
+ (createRes.data.id as string);
444
+ _createdTaskId = taskId;
445
+
446
+ // Cancel the task
447
+ const cancelRes = await http$(
448
+ server?.port,
449
+ "POST",
450
+ `/api/coding-agents/tasks/${taskId}/cancel`,
451
+ );
452
+ expect([200, 204, 404, 405]).toContain(cancelRes.status);
453
+
454
+ // Verify cancelled status
455
+ if (cancelRes.status === 200 || cancelRes.status === 204) {
456
+ const getRes = await http$(
457
+ server?.port,
458
+ "GET",
459
+ `/api/coding-agents/tasks/${taskId}`,
460
+ );
461
+ if (getRes.status === 200) {
462
+ const task = getRes.data.task as OrchestratedTask | undefined;
463
+ if (task) {
464
+ expect(task.metadata?.status).toBe("cancelled");
465
+ }
466
+ }
467
+ }
468
+ });
469
+
470
+ it("task pause and resume works correctly", async () => {
471
+ // Create a task
472
+ const createRes = await http$(
473
+ server?.port,
474
+ "POST",
475
+ "/api/coding-agents/tasks",
476
+ {
477
+ name: "Task to Pause",
478
+ description: "This task will be paused and resumed",
479
+ },
480
+ );
481
+
482
+ if (createRes.status !== 200 && createRes.status !== 201) {
483
+ return;
484
+ }
485
+
486
+ const taskId =
487
+ (createRes.data.task as { id: string })?.id ||
488
+ (createRes.data.id as string);
489
+
490
+ // First set to running
491
+ await http$(server?.port, "PATCH", `/api/coding-agents/tasks/${taskId}`, {
492
+ status: "running",
493
+ });
494
+
495
+ // Pause the task
496
+ const pauseRes = await http$(
497
+ server?.port,
498
+ "POST",
499
+ `/api/coding-agents/tasks/${taskId}/pause`,
500
+ );
501
+ expect([200, 204, 404, 405]).toContain(pauseRes.status);
502
+
503
+ // Resume the task
504
+ const resumeRes = await http$(
505
+ server?.port,
506
+ "POST",
507
+ `/api/coding-agents/tasks/${taskId}/resume`,
508
+ );
509
+ expect([200, 204, 404, 405]).toContain(resumeRes.status);
510
+
511
+ // Clean up
512
+ await http$(
513
+ server?.port,
514
+ "POST",
515
+ `/api/coding-agents/tasks/${taskId}/cancel`,
516
+ );
517
+ });
518
+ });
519
+
520
+ // ===================================================================
521
+ // 4. SUBAGENT SPAWNING TESTS
522
+ // ===================================================================
523
+
524
+ describe("Subagent Spawning", () => {
525
+ let server: { port: number; close: () => Promise<void> } | null = null;
526
+
527
+ beforeAll(async () => {
528
+ server = await startApiServer({ port: 0 });
529
+ await http$(server.port, "POST", "/api/agent/start");
530
+ }, 60_000);
531
+
532
+ afterAll(async () => {
533
+ if (server) {
534
+ await http$(server.port, "POST", "/api/agent/stop");
535
+ await server.close();
536
+ }
537
+ });
538
+
539
+ it("GET /api/coding-agents/providers returns available providers", async () => {
540
+ const { status, data } = await http$(
541
+ server?.port,
542
+ "GET",
543
+ "/api/coding-agents/providers",
544
+ );
545
+ expect([200, 404]).toContain(status);
546
+ if (status === 200) {
547
+ expect(
548
+ Array.isArray(data.providers) || data.providers === undefined,
549
+ ).toBe(true);
550
+ }
551
+ });
552
+
553
+ it("GET /api/coding-agents/sessions returns active sessions", async () => {
554
+ const { status, data } = await http$(
555
+ server?.port,
556
+ "GET",
557
+ "/api/coding-agents/sessions",
558
+ );
559
+ expect([200, 404]).toContain(status);
560
+ if (status === 200) {
561
+ expect(Array.isArray(data.sessions) || data.sessions === undefined).toBe(
562
+ true,
563
+ );
564
+ }
565
+ });
566
+
567
+ it("can spawn a subagent session", async () => {
568
+ const { status, data } = await http$(
569
+ server?.port,
570
+ "POST",
571
+ "/api/coding-agents/sessions",
572
+ {
573
+ task: "E2E test subagent spawn",
574
+ workingDirectory: os.tmpdir(),
575
+ },
576
+ );
577
+ // May return various statuses depending on provider availability
578
+ expect([200, 201, 400, 404, 500, 503]).toContain(status);
579
+
580
+ if (status === 200 || status === 201) {
581
+ expect(data.roomId || data.sessionId || data.id).toBeDefined();
582
+
583
+ // Clean up the session if created
584
+ const sessionId = data.roomId || data.sessionId || data.id;
585
+ if (sessionId) {
586
+ await http$(
587
+ server?.port,
588
+ "DELETE",
589
+ `/api/coding-agents/sessions/${sessionId}`,
590
+ );
591
+ }
592
+ }
593
+ });
594
+
595
+ it("subagent status can be queried", async () => {
596
+ // First spawn a subagent
597
+ const spawnRes = await http$(
598
+ server?.port,
599
+ "POST",
600
+ "/api/coding-agents/sessions",
601
+ {
602
+ task: "Status check test",
603
+ workingDirectory: os.tmpdir(),
604
+ },
605
+ );
606
+
607
+ if (spawnRes.status !== 200 && spawnRes.status !== 201) {
608
+ return; // Skip if spawning not available
609
+ }
610
+
611
+ const sessionId =
612
+ spawnRes.data.roomId || spawnRes.data.sessionId || spawnRes.data.id;
613
+
614
+ // Query status
615
+ const statusRes = await http$(
616
+ server?.port,
617
+ "GET",
618
+ `/api/coding-agents/sessions/${sessionId}`,
619
+ );
620
+ expect([200, 404]).toContain(statusRes.status);
621
+
622
+ // Clean up
623
+ await http$(
624
+ server?.port,
625
+ "DELETE",
626
+ `/api/coding-agents/sessions/${sessionId}`,
627
+ );
628
+ });
629
+
630
+ it("subagent can be terminated", async () => {
631
+ // Spawn a subagent
632
+ const spawnRes = await http$(
633
+ server?.port,
634
+ "POST",
635
+ "/api/coding-agents/sessions",
636
+ {
637
+ task: "Termination test",
638
+ workingDirectory: os.tmpdir(),
639
+ },
640
+ );
641
+
642
+ if (spawnRes.status !== 200 && spawnRes.status !== 201) {
643
+ return;
644
+ }
645
+
646
+ const sessionId =
647
+ spawnRes.data.roomId || spawnRes.data.sessionId || spawnRes.data.id;
648
+
649
+ // Terminate
650
+ const deleteRes = await http$(
651
+ server?.port,
652
+ "DELETE",
653
+ `/api/coding-agents/sessions/${sessionId}`,
654
+ );
655
+ expect([200, 204, 404]).toContain(deleteRes.status);
656
+
657
+ // Verify it's gone
658
+ const verifyRes = await http$(
659
+ server?.port,
660
+ "GET",
661
+ `/api/coding-agents/sessions/${sessionId}`,
662
+ );
663
+ // Should be 404 or return ended status
664
+ expect([200, 404]).toContain(verifyRes.status);
665
+ if (verifyRes.status === 200) {
666
+ const session = verifyRes.data.session as { ended?: boolean } | undefined;
667
+ expect(session?.ended).toBe(true);
668
+ }
669
+ });
670
+ });
671
+
672
+ // ===================================================================
673
+ // 5. MESSAGE PASSING TESTS
674
+ // ===================================================================
675
+
676
+ describe("Message Passing Between Agents", () => {
677
+ let server: { port: number; close: () => Promise<void> } | null = null;
678
+
679
+ beforeAll(async () => {
680
+ server = await startApiServer({ port: 0 });
681
+ await http$(server.port, "POST", "/api/agent/start");
682
+ }, 60_000);
683
+
684
+ afterAll(async () => {
685
+ if (server) {
686
+ await http$(server.port, "POST", "/api/agent/stop");
687
+ await server.close();
688
+ }
689
+ });
690
+
691
+ it("can send message to a session", async () => {
692
+ // First spawn a session
693
+ const spawnRes = await http$(
694
+ server?.port,
695
+ "POST",
696
+ "/api/coding-agents/sessions",
697
+ {
698
+ task: "Message test session",
699
+ workingDirectory: os.tmpdir(),
700
+ },
701
+ );
702
+
703
+ if (spawnRes.status !== 200 && spawnRes.status !== 201) {
704
+ return;
705
+ }
706
+
707
+ const sessionId =
708
+ spawnRes.data.roomId || spawnRes.data.sessionId || spawnRes.data.id;
709
+
710
+ // Send a message
711
+ const msgRes = await http$(
712
+ server?.port,
713
+ "POST",
714
+ `/api/coding-agents/sessions/${sessionId}/messages`,
715
+ {
716
+ text: "Hello from e2e test",
717
+ },
718
+ );
719
+ expect([200, 201, 404, 405]).toContain(msgRes.status);
720
+
721
+ // Clean up
722
+ await http$(
723
+ server?.port,
724
+ "DELETE",
725
+ `/api/coding-agents/sessions/${sessionId}`,
726
+ );
727
+ });
728
+
729
+ it("can receive messages from a session", async () => {
730
+ // Spawn a session
731
+ const spawnRes = await http$(
732
+ server?.port,
733
+ "POST",
734
+ "/api/coding-agents/sessions",
735
+ {
736
+ task: "Message receive test",
737
+ workingDirectory: os.tmpdir(),
738
+ },
739
+ );
740
+
741
+ if (spawnRes.status !== 200 && spawnRes.status !== 201) {
742
+ return;
743
+ }
744
+
745
+ const sessionId =
746
+ spawnRes.data.roomId || spawnRes.data.sessionId || spawnRes.data.id;
747
+
748
+ // Get messages
749
+ const msgsRes = await http$(
750
+ server?.port,
751
+ "GET",
752
+ `/api/coding-agents/sessions/${sessionId}/messages`,
753
+ );
754
+ expect([200, 404, 405]).toContain(msgsRes.status);
755
+ if (msgsRes.status === 200) {
756
+ expect(
757
+ Array.isArray(msgsRes.data.messages) ||
758
+ msgsRes.data.messages === undefined,
759
+ ).toBe(true);
760
+ }
761
+
762
+ // Clean up
763
+ await http$(
764
+ server?.port,
765
+ "DELETE",
766
+ `/api/coding-agents/sessions/${sessionId}`,
767
+ );
768
+ });
769
+
770
+ it("can peek at session output", async () => {
771
+ // Spawn a session
772
+ const spawnRes = await http$(
773
+ server?.port,
774
+ "POST",
775
+ "/api/coding-agents/sessions",
776
+ {
777
+ task: "Peek test session",
778
+ workingDirectory: os.tmpdir(),
779
+ },
780
+ );
781
+
782
+ if (spawnRes.status !== 200 && spawnRes.status !== 201) {
783
+ return;
784
+ }
785
+
786
+ const sessionId =
787
+ spawnRes.data.roomId || spawnRes.data.sessionId || spawnRes.data.id;
788
+
789
+ // Peek at output
790
+ const peekRes = await http$(
791
+ server?.port,
792
+ "GET",
793
+ `/api/coding-agents/sessions/${sessionId}/peek`,
794
+ );
795
+ expect([200, 404, 405]).toContain(peekRes.status);
796
+
797
+ // Clean up
798
+ await http$(
799
+ server?.port,
800
+ "DELETE",
801
+ `/api/coding-agents/sessions/${sessionId}`,
802
+ );
803
+ });
804
+ });
805
+
806
+ // ===================================================================
807
+ // 6. CONCURRENT TASK HANDLING
808
+ // ===================================================================
809
+
810
+ describe("Concurrent Task Handling", () => {
811
+ let server: { port: number; close: () => Promise<void> } | null = null;
812
+
813
+ beforeAll(async () => {
814
+ server = await startApiServer({ port: 0 });
815
+ await http$(server.port, "POST", "/api/agent/start");
816
+ }, 60_000);
817
+
818
+ afterAll(async () => {
819
+ if (server) {
820
+ await http$(server.port, "POST", "/api/agent/stop");
821
+ await server.close();
822
+ }
823
+ });
824
+
825
+ it("can create multiple tasks concurrently", async () => {
826
+ const taskPromises = Array.from({ length: 5 }, (_, i) =>
827
+ http$(server?.port, "POST", "/api/coding-agents/tasks", {
828
+ name: `Concurrent Task ${i + 1}`,
829
+ description: `Task ${i + 1} for concurrent test`,
830
+ }),
831
+ );
832
+
833
+ const results = await Promise.allSettled(taskPromises);
834
+ const fulfilled = results.filter((r) => r.status === "fulfilled");
835
+
836
+ // All requests should complete (not deadlock)
837
+ expect(fulfilled.length).toBe(results.length);
838
+
839
+ // Count successful creations
840
+ const successCount = fulfilled.filter((r) => {
841
+ const result = r as PromiseFulfilledResult<{
842
+ status: number;
843
+ data: Record<string, unknown>;
844
+ }>;
845
+ return result.value.status === 200 || result.value.status === 201;
846
+ }).length;
847
+
848
+ logger.info(
849
+ `[agent-orchestration-e2e] Concurrent task creation: ${successCount}/${results.length} succeeded`,
850
+ );
851
+ });
852
+
853
+ it("task list remains consistent under concurrent access", async () => {
854
+ // Fire multiple list requests concurrently
855
+ const listPromises = Array.from({ length: 10 }, () =>
856
+ http$(server?.port, "GET", "/api/coding-agents/tasks"),
857
+ );
858
+
859
+ const results = await Promise.all(listPromises);
860
+
861
+ // All should return same count (no race conditions corrupting state)
862
+ const counts = results
863
+ .filter((r) => r.status === 200)
864
+ .map((r) => (r.data.tasks as unknown[])?.length ?? 0);
865
+
866
+ if (counts.length > 1) {
867
+ const unique = new Set(counts);
868
+ // Task count should be consistent across all reads
869
+ expect(unique.size).toBe(1);
870
+ }
871
+ });
872
+
873
+ it("concurrent status updates do not corrupt task state", async () => {
874
+ // Create a task
875
+ const createRes = await http$(
876
+ server?.port,
877
+ "POST",
878
+ "/api/coding-agents/tasks",
879
+ {
880
+ name: "Concurrent Update Test",
881
+ description: "Task for concurrent update testing",
882
+ },
883
+ );
884
+
885
+ if (createRes.status !== 200 && createRes.status !== 201) {
886
+ return;
887
+ }
888
+
889
+ const taskId =
890
+ (createRes.data.task as { id: string })?.id ||
891
+ (createRes.data.id as string);
892
+
893
+ // Fire concurrent progress updates
894
+ const updatePromises = Array.from({ length: 10 }, (_, i) =>
895
+ http$(server?.port, "PATCH", `/api/coding-agents/tasks/${taskId}`, {
896
+ progress: (i + 1) * 10,
897
+ }),
898
+ );
899
+
900
+ const results = await Promise.allSettled(updatePromises);
901
+ const fulfilled = results.filter((r) => r.status === "fulfilled");
902
+ expect(fulfilled.length).toBe(results.length);
903
+
904
+ // Verify task is not corrupted
905
+ const getRes = await http$(
906
+ server?.port,
907
+ "GET",
908
+ `/api/coding-agents/tasks/${taskId}`,
909
+ );
910
+ if (getRes.status === 200) {
911
+ const task = getRes.data.task as OrchestratedTask | undefined;
912
+ if (task) {
913
+ expect(typeof task.metadata?.progress).toBe("number");
914
+ expect(task.metadata?.progress).toBeGreaterThanOrEqual(0);
915
+ expect(task.metadata?.progress).toBeLessThanOrEqual(100);
916
+ }
917
+ }
918
+
919
+ // Clean up
920
+ await http$(
921
+ server?.port,
922
+ "POST",
923
+ `/api/coding-agents/tasks/${taskId}/cancel`,
924
+ );
925
+ });
926
+ });
927
+
928
+ // ===================================================================
929
+ // 7. ERROR HANDLING AND RECOVERY
930
+ // ===================================================================
931
+
932
+ describe("Error Handling and Recovery", () => {
933
+ let server: { port: number; close: () => Promise<void> } | null = null;
934
+
935
+ beforeAll(async () => {
936
+ server = await startApiServer({ port: 0 });
937
+ await http$(server.port, "POST", "/api/agent/start");
938
+ }, 60_000);
939
+
940
+ afterAll(async () => {
941
+ if (server) {
942
+ await http$(server.port, "POST", "/api/agent/stop");
943
+ await server.close();
944
+ }
945
+ });
946
+
947
+ it("handles invalid task ID gracefully", async () => {
948
+ const { status } = await http$(
949
+ server?.port,
950
+ "GET",
951
+ "/api/coding-agents/tasks/invalid-task-id-12345",
952
+ );
953
+ // Should return 404, not crash
954
+ expect([404, 400]).toContain(status);
955
+ });
956
+
957
+ it("handles invalid session ID gracefully", async () => {
958
+ const { status } = await http$(
959
+ server?.port,
960
+ "GET",
961
+ "/api/coding-agents/sessions/invalid-session-id-12345",
962
+ );
963
+ expect([404, 400]).toContain(status);
964
+ });
965
+
966
+ it("handles malformed task creation request", async () => {
967
+ const { status } = await http$(
968
+ server?.port,
969
+ "POST",
970
+ "/api/coding-agents/tasks",
971
+ {
972
+ // Missing required fields
973
+ invalid: "data",
974
+ },
975
+ );
976
+ // Should return 400 Bad Request, not 500
977
+ expect([400, 404, 422]).toContain(status);
978
+ });
979
+
980
+ it("handles task operations on non-existent task", async () => {
981
+ const fakeTaskId = crypto.randomUUID();
982
+
983
+ // Try to cancel non-existent task
984
+ const cancelRes = await http$(
985
+ server?.port,
986
+ "POST",
987
+ `/api/coding-agents/tasks/${fakeTaskId}/cancel`,
988
+ );
989
+ expect([404, 400, 405]).toContain(cancelRes.status);
990
+
991
+ // Try to pause non-existent task
992
+ const pauseRes = await http$(
993
+ server?.port,
994
+ "POST",
995
+ `/api/coding-agents/tasks/${fakeTaskId}/pause`,
996
+ );
997
+ expect([404, 400, 405]).toContain(pauseRes.status);
998
+ });
999
+
1000
+ it("handles session operations on non-existent session", async () => {
1001
+ const fakeSessionId = crypto.randomUUID();
1002
+
1003
+ // Try to send message to non-existent session
1004
+ const msgRes = await http$(
1005
+ server?.port,
1006
+ "POST",
1007
+ `/api/coding-agents/sessions/${fakeSessionId}/messages`,
1008
+ { text: "Hello" },
1009
+ );
1010
+ expect([404, 400, 405]).toContain(msgRes.status);
1011
+
1012
+ // Try to delete non-existent session
1013
+ const deleteRes = await http$(
1014
+ server?.port,
1015
+ "DELETE",
1016
+ `/api/coding-agents/sessions/${fakeSessionId}`,
1017
+ );
1018
+ expect([404, 400, 204]).toContain(deleteRes.status);
1019
+ });
1020
+
1021
+ it("recovers from failed task without corrupting state", async () => {
1022
+ // Create a task
1023
+ const createRes = await http$(
1024
+ server?.port,
1025
+ "POST",
1026
+ "/api/coding-agents/tasks",
1027
+ {
1028
+ name: "Task That Will Fail",
1029
+ description: "This task is designed to fail for testing",
1030
+ },
1031
+ );
1032
+
1033
+ if (createRes.status !== 200 && createRes.status !== 201) {
1034
+ return;
1035
+ }
1036
+
1037
+ const taskId =
1038
+ (createRes.data.task as { id: string })?.id ||
1039
+ (createRes.data.id as string);
1040
+
1041
+ // Mark as failed
1042
+ await http$(server?.port, "PATCH", `/api/coding-agents/tasks/${taskId}`, {
1043
+ status: "failed",
1044
+ error: "Intentional failure for e2e test",
1045
+ });
1046
+
1047
+ // Verify task list is still accessible
1048
+ const listRes = await http$(
1049
+ server?.port,
1050
+ "GET",
1051
+ "/api/coding-agents/tasks",
1052
+ );
1053
+ expect(listRes.status).toBe(200);
1054
+
1055
+ // Verify failed task is in the list
1056
+ if (listRes.status === 200 && Array.isArray(listRes.data.tasks)) {
1057
+ const failedTask = (listRes.data.tasks as OrchestratedTask[]).find(
1058
+ (t) => t.id === taskId,
1059
+ );
1060
+ if (failedTask) {
1061
+ expect(failedTask.metadata?.status).toBe("failed");
1062
+ }
1063
+ }
1064
+ });
1065
+ });
1066
+
1067
+ // ===================================================================
1068
+ // 8. TASK EVENT HANDLING
1069
+ // ===================================================================
1070
+
1071
+ describe("Task Event System", () => {
1072
+ let server: { port: number; close: () => Promise<void> } | null = null;
1073
+
1074
+ beforeAll(async () => {
1075
+ server = await startApiServer({ port: 0 });
1076
+ await http$(server.port, "POST", "/api/agent/start");
1077
+ }, 60_000);
1078
+
1079
+ afterAll(async () => {
1080
+ if (server) {
1081
+ await http$(server.port, "POST", "/api/agent/stop");
1082
+ await server.close();
1083
+ }
1084
+ });
1085
+
1086
+ it("task output can be appended and retrieved", async () => {
1087
+ // Create a task
1088
+ const createRes = await http$(
1089
+ server?.port,
1090
+ "POST",
1091
+ "/api/coding-agents/tasks",
1092
+ {
1093
+ name: "Output Test Task",
1094
+ description: "Task for testing output append",
1095
+ },
1096
+ );
1097
+
1098
+ if (createRes.status !== 200 && createRes.status !== 201) {
1099
+ return;
1100
+ }
1101
+
1102
+ const taskId =
1103
+ (createRes.data.task as { id: string })?.id ||
1104
+ (createRes.data.id as string);
1105
+
1106
+ // Append output
1107
+ const appendRes = await http$(
1108
+ server?.port,
1109
+ "POST",
1110
+ `/api/coding-agents/tasks/${taskId}/output`,
1111
+ {
1112
+ output: "Line 1 of output",
1113
+ },
1114
+ );
1115
+ expect([200, 201, 404, 405]).toContain(appendRes.status);
1116
+
1117
+ // Append more output
1118
+ await http$(
1119
+ server?.port,
1120
+ "POST",
1121
+ `/api/coding-agents/tasks/${taskId}/output`,
1122
+ {
1123
+ output: "Line 2 of output",
1124
+ },
1125
+ );
1126
+
1127
+ // Get task and verify output
1128
+ const getRes = await http$(
1129
+ server?.port,
1130
+ "GET",
1131
+ `/api/coding-agents/tasks/${taskId}`,
1132
+ );
1133
+ if (getRes.status === 200) {
1134
+ const task = getRes.data.task as OrchestratedTask | undefined;
1135
+ if (task && Array.isArray(task.metadata?.output)) {
1136
+ expect(task.metadata.output.length).toBeGreaterThanOrEqual(0);
1137
+ }
1138
+ }
1139
+
1140
+ // Clean up
1141
+ await http$(
1142
+ server?.port,
1143
+ "POST",
1144
+ `/api/coding-agents/tasks/${taskId}/cancel`,
1145
+ );
1146
+ });
1147
+
1148
+ it("task steps can be added and updated", async () => {
1149
+ // Create a task
1150
+ const createRes = await http$(
1151
+ server?.port,
1152
+ "POST",
1153
+ "/api/coding-agents/tasks",
1154
+ {
1155
+ name: "Steps Test Task",
1156
+ description: "Task for testing step management",
1157
+ },
1158
+ );
1159
+
1160
+ if (createRes.status !== 200 && createRes.status !== 201) {
1161
+ return;
1162
+ }
1163
+
1164
+ const taskId =
1165
+ (createRes.data.task as { id: string })?.id ||
1166
+ (createRes.data.id as string);
1167
+
1168
+ // Add a step
1169
+ const addStepRes = await http$(
1170
+ server?.port,
1171
+ "POST",
1172
+ `/api/coding-agents/tasks/${taskId}/steps`,
1173
+ {
1174
+ description: "Step 1: Initialize",
1175
+ },
1176
+ );
1177
+ expect([200, 201, 404, 405]).toContain(addStepRes.status);
1178
+
1179
+ const stepId =
1180
+ (addStepRes.data.stepId as string) ||
1181
+ (addStepRes.data.step as { id: string })?.id;
1182
+
1183
+ // Update step status
1184
+ if (stepId) {
1185
+ const updateStepRes = await http$(
1186
+ server?.port,
1187
+ "PATCH",
1188
+ `/api/coding-agents/tasks/${taskId}/steps/${stepId}`,
1189
+ {
1190
+ status: "completed",
1191
+ output: "Step completed successfully",
1192
+ },
1193
+ );
1194
+ expect([200, 204, 404, 405]).toContain(updateStepRes.status);
1195
+ }
1196
+
1197
+ // Clean up
1198
+ await http$(
1199
+ server?.port,
1200
+ "POST",
1201
+ `/api/coding-agents/tasks/${taskId}/cancel`,
1202
+ );
1203
+ });
1204
+
1205
+ it("task result can be set", async () => {
1206
+ // Create a task
1207
+ const createRes = await http$(
1208
+ server?.port,
1209
+ "POST",
1210
+ "/api/coding-agents/tasks",
1211
+ {
1212
+ name: "Result Test Task",
1213
+ description: "Task for testing result setting",
1214
+ },
1215
+ );
1216
+
1217
+ if (createRes.status !== 200 && createRes.status !== 201) {
1218
+ return;
1219
+ }
1220
+
1221
+ const taskId =
1222
+ (createRes.data.task as { id: string })?.id ||
1223
+ (createRes.data.id as string);
1224
+
1225
+ // Set result
1226
+ const resultRes = await http$(
1227
+ server?.port,
1228
+ "POST",
1229
+ `/api/coding-agents/tasks/${taskId}/result`,
1230
+ {
1231
+ success: true,
1232
+ summary: "Task completed successfully in e2e test",
1233
+ filesModified: ["test.ts"],
1234
+ filesCreated: ["new-file.ts"],
1235
+ },
1236
+ );
1237
+ expect([200, 201, 404, 405]).toContain(resultRes.status);
1238
+
1239
+ // Verify task is completed
1240
+ const getRes = await http$(
1241
+ server?.port,
1242
+ "GET",
1243
+ `/api/coding-agents/tasks/${taskId}`,
1244
+ );
1245
+ if (getRes.status === 200) {
1246
+ const task = getRes.data.task as OrchestratedTask | undefined;
1247
+ if (task?.metadata?.result) {
1248
+ expect(task.metadata.result.success).toBe(true);
1249
+ }
1250
+ }
1251
+ });
1252
+ });
1253
+
1254
+ // ===================================================================
1255
+ // 9. CLEANUP AND RESOURCE MANAGEMENT
1256
+ // ===================================================================
1257
+
1258
+ describe("Cleanup and Resource Management", () => {
1259
+ let server: { port: number; close: () => Promise<void> } | null = null;
1260
+
1261
+ beforeAll(async () => {
1262
+ server = await startApiServer({ port: 0 });
1263
+ await http$(server.port, "POST", "/api/agent/start");
1264
+ }, 60_000);
1265
+
1266
+ afterAll(async () => {
1267
+ if (server) {
1268
+ await http$(server.port, "POST", "/api/agent/stop");
1269
+ await server.close();
1270
+ }
1271
+ });
1272
+
1273
+ it("completed tasks are properly tracked", async () => {
1274
+ // Create and complete a task
1275
+ const createRes = await http$(
1276
+ server?.port,
1277
+ "POST",
1278
+ "/api/coding-agents/tasks",
1279
+ {
1280
+ name: "Completion Tracking Task",
1281
+ description: "Task to verify completion tracking",
1282
+ },
1283
+ );
1284
+
1285
+ if (createRes.status !== 200 && createRes.status !== 201) {
1286
+ return;
1287
+ }
1288
+
1289
+ const taskId =
1290
+ (createRes.data.task as { id: string })?.id ||
1291
+ (createRes.data.id as string);
1292
+
1293
+ // Complete the task
1294
+ await http$(server?.port, "PATCH", `/api/coding-agents/tasks/${taskId}`, {
1295
+ status: "completed",
1296
+ });
1297
+
1298
+ // Verify it's in completed tasks
1299
+ const completedRes = await http$(
1300
+ server?.port,
1301
+ "GET",
1302
+ "/api/coding-agents/tasks?status=completed",
1303
+ );
1304
+ if (completedRes.status === 200 && Array.isArray(completedRes.data.tasks)) {
1305
+ const found = (completedRes.data.tasks as OrchestratedTask[]).find(
1306
+ (t) => t.id === taskId,
1307
+ );
1308
+ expect(found).toBeDefined();
1309
+ }
1310
+ });
1311
+
1312
+ it("terminated sessions are cleaned up", async () => {
1313
+ // Spawn multiple sessions
1314
+ const spawnPromises = Array.from({ length: 3 }, (_, i) =>
1315
+ http$(server?.port, "POST", "/api/coding-agents/sessions", {
1316
+ task: `Cleanup test session ${i + 1}`,
1317
+ workingDirectory: os.tmpdir(),
1318
+ }),
1319
+ );
1320
+
1321
+ const spawnResults = await Promise.allSettled(spawnPromises);
1322
+ const sessionIds: string[] = [];
1323
+
1324
+ for (const result of spawnResults) {
1325
+ if (result.status === "fulfilled") {
1326
+ const { status, data } = result.value;
1327
+ if (status === 200 || status === 201) {
1328
+ const id = data.roomId || data.sessionId || data.id;
1329
+ if (id) sessionIds.push(id as string);
1330
+ }
1331
+ }
1332
+ }
1333
+
1334
+ // Terminate all sessions
1335
+ await Promise.all(
1336
+ sessionIds.map((id) =>
1337
+ http$(server?.port, "DELETE", `/api/coding-agents/sessions/${id}`),
1338
+ ),
1339
+ );
1340
+
1341
+ // Verify sessions are cleaned up
1342
+ const listRes = await http$(
1343
+ server?.port,
1344
+ "GET",
1345
+ "/api/coding-agents/sessions",
1346
+ );
1347
+ if (listRes.status === 200 && Array.isArray(listRes.data.sessions)) {
1348
+ const activeSessions = (
1349
+ listRes.data.sessions as Array<{ id: string; ended?: boolean }>
1350
+ ).filter((s) => sessionIds.includes(s.id) && !s.ended);
1351
+ expect(activeSessions.length).toBe(0);
1352
+ }
1353
+ });
1354
+
1355
+ it("server remains healthy after multiple spawn/terminate cycles", async () => {
1356
+ // Run 5 spawn/terminate cycles
1357
+ for (let cycle = 0; cycle < 5; cycle++) {
1358
+ const spawnRes = await http$(
1359
+ server?.port,
1360
+ "POST",
1361
+ "/api/coding-agents/sessions",
1362
+ {
1363
+ task: `Cycle ${cycle + 1} session`,
1364
+ workingDirectory: os.tmpdir(),
1365
+ },
1366
+ );
1367
+
1368
+ if (spawnRes.status === 200 || spawnRes.status === 201) {
1369
+ const sessionId =
1370
+ spawnRes.data.roomId || spawnRes.data.sessionId || spawnRes.data.id;
1371
+ if (sessionId) {
1372
+ await http$(
1373
+ server?.port,
1374
+ "DELETE",
1375
+ `/api/coding-agents/sessions/${sessionId}`,
1376
+ );
1377
+ }
1378
+ }
1379
+ }
1380
+
1381
+ // Verify server is still healthy
1382
+ const statusRes = await http$(server?.port, "GET", "/api/status");
1383
+ expect(statusRes.status).toBe(200);
1384
+ expect(statusRes.data.state).toBe("paused");
1385
+ });
1386
+ });
1387
+
1388
+ // ===================================================================
1389
+ // 10. INTEGRATION WITH RUNTIME (requires model provider)
1390
+ // ===================================================================
1391
+
1392
+ describe.skipIf(!hasModelProvider)(
1393
+ "Runtime Integration with Orchestrator",
1394
+ () => {
1395
+ let runtime: AgentRuntime | null = null;
1396
+ let server: { port: number; close: () => Promise<void> } | null = null;
1397
+
1398
+ const pgliteDir = fs.mkdtempSync(
1399
+ path.join(os.tmpdir(), "milady-e2e-orchestrator-pglite-"),
1400
+ );
1401
+
1402
+ beforeAll(async () => {
1403
+ process.env.LOG_LEVEL = process.env.MILADY_E2E_LOG_LEVEL ?? "error";
1404
+ process.env.PGLITE_DATA_DIR = pgliteDir;
1405
+
1406
+ const secrets: Record<string, string> = {};
1407
+ if (hasOpenAI) secrets.OPENAI_API_KEY = process.env.OPENAI_API_KEY!;
1408
+ if (hasAnthropic)
1409
+ secrets.ANTHROPIC_API_KEY = process.env.ANTHROPIC_API_KEY!;
1410
+ if (hasGroq) secrets.GROQ_API_KEY = process.env.GROQ_API_KEY!;
1411
+
1412
+ const character = createCharacter({
1413
+ name: "OrchestratorTestAgent",
1414
+ bio: "An E2E test agent for orchestration.",
1415
+ secrets,
1416
+ });
1417
+
1418
+ const plugins: Plugin[] = [];
1419
+
1420
+ // Load core plugins
1421
+ const sqlPlugin = await loadPlugin("@elizaos/plugin-sql");
1422
+ const embeddingPlugin = await loadPlugin(
1423
+ "@elizaos/plugin-local-embedding",
1424
+ );
1425
+ const orchestratorPlugin = await loadPlugin(
1426
+ "@elizaos/plugin-agent-orchestrator",
1427
+ );
1428
+
1429
+ if (sqlPlugin) plugins.push(sqlPlugin);
1430
+ if (embeddingPlugin) plugins.push(embeddingPlugin);
1431
+ if (orchestratorPlugin) plugins.push(orchestratorPlugin);
1432
+
1433
+ // Load model provider
1434
+ if (hasOpenAI) {
1435
+ const p = await loadPlugin("@elizaos/plugin-openai");
1436
+ if (p) plugins.push(p);
1437
+ } else if (hasAnthropic) {
1438
+ const p = await loadPlugin("@elizaos/plugin-anthropic");
1439
+ if (p) plugins.push(p);
1440
+ } else if (hasGroq) {
1441
+ const p = await loadPlugin("@elizaos/plugin-groq");
1442
+ if (p) plugins.push(p);
1443
+ }
1444
+
1445
+ runtime = new AgentRuntime({
1446
+ character,
1447
+ plugins,
1448
+ logLevel: "error",
1449
+ });
1450
+
1451
+ await runtime.initialize();
1452
+ server = await startApiServer({ port: 0, runtime });
1453
+ }, 180_000);
1454
+
1455
+ afterAll(async () => {
1456
+ if (server) {
1457
+ try {
1458
+ await server.close();
1459
+ } catch {
1460
+ /* ignore */
1461
+ }
1462
+ }
1463
+ if (runtime) {
1464
+ try {
1465
+ await runtime.stop();
1466
+ } catch {
1467
+ /* ignore */
1468
+ }
1469
+ }
1470
+ try {
1471
+ fs.rmSync(pgliteDir, { recursive: true, force: true });
1472
+ } catch {
1473
+ /* ignore */
1474
+ }
1475
+ }, 30_000);
1476
+
1477
+ it("orchestrator service is available on runtime", () => {
1478
+ const _service = runtime?.getService("CODE_TASK");
1479
+ // Service may or may not be available depending on plugin configuration
1480
+ // This test verifies no crash during service lookup
1481
+ expect(true).toBe(true);
1482
+ });
1483
+
1484
+ it("can create and track task through runtime", async () => {
1485
+ const service = runtime?.getService(
1486
+ "CODE_TASK",
1487
+ ) as AgentOrchestratorService | null;
1488
+ if (!service?.createTask) {
1489
+ logger.info(
1490
+ "[agent-orchestration-e2e] Skipping runtime task test - service not available",
1491
+ );
1492
+ return;
1493
+ }
1494
+
1495
+ const task = await service.createTask(
1496
+ "Runtime Integration Task",
1497
+ "Created directly through runtime service",
1498
+ );
1499
+
1500
+ expect(task).toBeDefined();
1501
+ expect(task.id).toBeDefined();
1502
+ expect(task.name).toBe("Runtime Integration Task");
1503
+ expect(task.metadata?.status).toBe("pending");
1504
+
1505
+ // Clean up
1506
+ service.cancelTask(task.id);
1507
+ });
1508
+
1509
+ it("task events are emitted correctly", async () => {
1510
+ const service = runtime?.getService(
1511
+ "CODE_TASK",
1512
+ ) as AgentOrchestratorService | null;
1513
+ if (!service?.createTask || !service?.on) {
1514
+ return;
1515
+ }
1516
+
1517
+ const events: Array<{ type: string; taskId: string }> = [];
1518
+ const unsubscribe = service.on("task:created", (event) => {
1519
+ events.push(event);
1520
+ });
1521
+
1522
+ const task = await service.createTask(
1523
+ "Event Test Task",
1524
+ "Task for event testing",
1525
+ );
1526
+
1527
+ // Give event a moment to propagate
1528
+ await new Promise((resolve) => setTimeout(resolve, 100));
1529
+
1530
+ expect(events.length).toBeGreaterThanOrEqual(0);
1531
+
1532
+ // Clean up
1533
+ unsubscribe();
1534
+ service.cancelTask(task.id);
1535
+ });
1536
+
1537
+ it("API endpoints reflect runtime task state", async () => {
1538
+ const service = runtime?.getService(
1539
+ "CODE_TASK",
1540
+ ) as AgentOrchestratorService | null;
1541
+ if (!service?.createTask) {
1542
+ return;
1543
+ }
1544
+
1545
+ // Create task via service
1546
+ const task = await service.createTask(
1547
+ "API Reflection Task",
1548
+ "Task created via service",
1549
+ );
1550
+
1551
+ // Verify via API
1552
+ const { status, data } = await http$(
1553
+ server?.port,
1554
+ "GET",
1555
+ `/api/coding-agents/tasks/${task.id}`,
1556
+ );
1557
+
1558
+ if (status === 200) {
1559
+ const apiTask = data.task as OrchestratedTask | undefined;
1560
+ expect(apiTask?.id).toBe(task.id);
1561
+ expect(apiTask?.name).toBe(task.name);
1562
+ }
1563
+
1564
+ // Clean up
1565
+ service.cancelTask(task.id);
1566
+ });
1567
+ },
1568
+ );