@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,1515 @@
1
+ /**
2
+ * Comprehensive E2E tests for the Milady agent runtime.
3
+ *
4
+ * NO MOCKS. Single test file (PGlite constraint). All suites share one
5
+ * fully-initialized runtime with PRODUCTION defaults:
6
+ * - checkShouldRespond: true (production default — DMs bypass via alwaysRespondChannels)
7
+ * - enableAutonomy: true
8
+ * - All core plugins loaded
9
+ *
10
+ * Slow tests are fine — we test autonomy thinking for real, multi-turn
11
+ * memory for real, and startEliza() via a real subprocess.
12
+ */
13
+ import crypto from "node:crypto";
14
+ import fs from "node:fs";
15
+ import http from "node:http";
16
+ import os from "node:os";
17
+ import path from "node:path";
18
+ import { fileURLToPath } from "node:url";
19
+ import {
20
+ AgentRuntime,
21
+ ChannelType,
22
+ createCharacter,
23
+ createMessageMemory,
24
+ logger,
25
+ type Plugin,
26
+ type Service,
27
+ stringToUuid,
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 { ensureAgentWorkspace } from "../src/providers/workspace";
34
+ import { configureLocalEmbeddingPlugin } from "../src/runtime/eliza";
35
+ import {
36
+ extractPlugin,
37
+ type PluginModuleShape,
38
+ } from "../src/test-support/test-helpers";
39
+
40
+ // ---------------------------------------------------------------------------
41
+ // Environment
42
+ // ---------------------------------------------------------------------------
43
+
44
+ const testDir = path.dirname(fileURLToPath(import.meta.url));
45
+ const packageRoot = path.resolve(testDir, "..");
46
+ dotenv.config({ path: path.resolve(packageRoot, ".env") });
47
+ dotenv.config({ path: path.resolve(packageRoot, "..", "eliza", ".env") });
48
+
49
+ const hasOpenAI = Boolean(process.env.OPENAI_API_KEY);
50
+ const hasAnthropic = Boolean(process.env.ANTHROPIC_API_KEY);
51
+ const hasGroq = Boolean(process.env.GROQ_API_KEY);
52
+ const liveModelTestsEnabled = process.env.MILADY_LIVE_TEST === "1";
53
+ // This suite exercises the heaviest live-runtime bootstrap path and relies on
54
+ // real provider availability. Keep it opt-in so default repo-wide E2E runs
55
+ // remain deterministic; runtime integration coverage still exists elsewhere.
56
+ const runAgentRuntimeE2E = process.env.MILADY_RUN_AGENT_RUNTIME_E2E === "1";
57
+ const hasModelProvider =
58
+ liveModelTestsEnabled &&
59
+ runAgentRuntimeE2E &&
60
+ (hasOpenAI || hasAnthropic || hasGroq);
61
+
62
+ // ---------------------------------------------------------------------------
63
+ // Plugin helpers — tracks failures
64
+ // ---------------------------------------------------------------------------
65
+
66
+ const pluginLoadResults: { name: string; loaded: boolean; error?: string }[] =
67
+ [];
68
+
69
+ async function loadPlugin(name: string): Promise<Plugin | null> {
70
+ try {
71
+ const p = extractPlugin(
72
+ (await import(name)) as PluginModuleShape,
73
+ ) as Plugin | null;
74
+ pluginLoadResults.push({
75
+ name,
76
+ loaded: p !== null,
77
+ error: p ? undefined : "no valid Plugin export",
78
+ });
79
+ return p;
80
+ } catch (err) {
81
+ const msg = err instanceof Error ? err.message : String(err);
82
+ pluginLoadResults.push({ name, loaded: false, error: msg });
83
+ logger.warn(`[e2e] FAILED to load plugin ${name}: ${msg}`);
84
+ return null;
85
+ }
86
+ }
87
+
88
+ // ---------------------------------------------------------------------------
89
+ // HTTP helper
90
+ // ---------------------------------------------------------------------------
91
+
92
+ function http$(
93
+ port: number,
94
+ method: string,
95
+ p: string,
96
+ body?: Record<string, unknown>,
97
+ options?: { timeoutMs?: number },
98
+ ): Promise<{ status: number; data: Record<string, unknown> }> {
99
+ return new Promise((resolve, reject) => {
100
+ const b = body ? JSON.stringify(body) : undefined;
101
+ const timeoutMs = options?.timeoutMs ?? 60_000;
102
+ const req = http.request(
103
+ {
104
+ hostname: "127.0.0.1",
105
+ port,
106
+ path: p,
107
+ method,
108
+ headers: {
109
+ "Content-Type": "application/json",
110
+ ...(b ? { "Content-Length": Buffer.byteLength(b) } : {}),
111
+ },
112
+ },
113
+ (res) => {
114
+ const ch: Buffer[] = [];
115
+ res.on("data", (c: Buffer) => ch.push(c));
116
+ res.on("end", () => {
117
+ const raw = Buffer.concat(ch).toString("utf-8");
118
+ let data: Record<string, unknown> = {};
119
+ try {
120
+ data = JSON.parse(raw) as Record<string, unknown>;
121
+ } catch {
122
+ data = { _raw: raw };
123
+ }
124
+ resolve({ status: res.statusCode ?? 0, data });
125
+ });
126
+ },
127
+ );
128
+ req.setTimeout(timeoutMs, () => {
129
+ req.destroy(new Error(`Request timed out after ${timeoutMs}ms`));
130
+ });
131
+ req.on("error", reject);
132
+ if (b) req.write(b);
133
+ req.end();
134
+ });
135
+ }
136
+
137
+ function withTimeout<T>(
138
+ promise: Promise<T>,
139
+ ms: number,
140
+ label: string,
141
+ ): Promise<T> {
142
+ let timeoutHandle: ReturnType<typeof setTimeout> | null = null;
143
+ const timeoutPromise = new Promise<never>((_, reject) => {
144
+ timeoutHandle = setTimeout(() => {
145
+ reject(new Error(`${label} timed out after ${ms}ms`));
146
+ }, ms);
147
+ });
148
+ return Promise.race([promise, timeoutPromise]).finally(() => {
149
+ if (timeoutHandle) {
150
+ clearTimeout(timeoutHandle);
151
+ }
152
+ });
153
+ }
154
+
155
+ function sleep(ms: number): Promise<void> {
156
+ return new Promise((resolve) => {
157
+ setTimeout(resolve, ms);
158
+ });
159
+ }
160
+
161
+ const modelProviderUnavailablePattern =
162
+ /exceeded your current quota|insufficient[_\s-]?quota|billing details|credit balance|rate limit|status code: 429|too many requests|invalid api key|unauthorized|authentication/i;
163
+
164
+ let cachedModelProviderUnavailableReason: string | null = null;
165
+
166
+ function errorMessage(err: unknown): string {
167
+ return err instanceof Error ? err.message : String(err);
168
+ }
169
+
170
+ function isModelProviderUnavailableError(message: string): boolean {
171
+ return modelProviderUnavailablePattern.test(message);
172
+ }
173
+
174
+ async function getGeneratedText(result: unknown): Promise<string> {
175
+ if (typeof result === "string") return result.trim();
176
+ if (!result || typeof result !== "object") {
177
+ return String(result ?? "").trim();
178
+ }
179
+ const textValue = (result as { text?: unknown }).text;
180
+ if (
181
+ textValue &&
182
+ typeof textValue === "object" &&
183
+ typeof (textValue as PromiseLike<unknown>).then === "function"
184
+ ) {
185
+ return String(await (textValue as PromiseLike<unknown>)).trim();
186
+ }
187
+ return String(textValue ?? "").trim();
188
+ }
189
+
190
+ async function shouldSkipDueModelProviderUnavailable(
191
+ runtime: AgentRuntime,
192
+ testName: string,
193
+ ): Promise<boolean> {
194
+ if (cachedModelProviderUnavailableReason) {
195
+ logger.warn(
196
+ `[e2e] Skipping "${testName}" due to provider limit: ${cachedModelProviderUnavailableReason}`,
197
+ );
198
+ return true;
199
+ }
200
+
201
+ for (let attempt = 1; attempt <= 2; attempt += 1) {
202
+ try {
203
+ const probe = await runtime.generateText("Reply with exactly: ok", {
204
+ maxTokens: 32,
205
+ });
206
+ const text = await getGeneratedText(probe);
207
+ if (text.length > 0) return false;
208
+ } catch (err) {
209
+ const message = errorMessage(err);
210
+ if (isModelProviderUnavailableError(message)) {
211
+ cachedModelProviderUnavailableReason = message;
212
+ logger.warn(
213
+ `[e2e] Skipping "${testName}" due to provider limit: ${message}`,
214
+ );
215
+ return true;
216
+ }
217
+ }
218
+ await sleep(250 * attempt);
219
+ }
220
+
221
+ return false;
222
+ }
223
+
224
+ function readSerializedProperty(
225
+ value: unknown,
226
+ key: string,
227
+ ): unknown | undefined {
228
+ if (!value || typeof value !== "object") return undefined;
229
+ const direct = (value as Record<string, unknown>)[key];
230
+ if (direct !== undefined) return direct;
231
+ const properties = (value as Record<string, unknown>).properties;
232
+ if (
233
+ !properties ||
234
+ typeof properties !== "object" ||
235
+ Array.isArray(properties)
236
+ )
237
+ return undefined;
238
+ return (properties as Record<string, unknown>)[key];
239
+ }
240
+
241
+ function readSerializedArray(value: unknown): Array<Record<string, unknown>> {
242
+ if (Array.isArray(value)) return value as Array<Record<string, unknown>>;
243
+ if (!value || typeof value !== "object") return [];
244
+ const items = (value as Record<string, unknown>).items;
245
+ if (Array.isArray(items)) return items as Array<Record<string, unknown>>;
246
+ return [];
247
+ }
248
+
249
+ async function postChatWithRetries(
250
+ port: number,
251
+ attempts = 3,
252
+ ): Promise<{ status: number; data: Record<string, unknown> }> {
253
+ const errors: string[] = [];
254
+ for (let attempt = 1; attempt <= attempts; attempt += 1) {
255
+ try {
256
+ const response = await http$(
257
+ port,
258
+ "POST",
259
+ "/api/chat",
260
+ { text: "What is 1+1? Number only.", mode: "simple" },
261
+ { timeoutMs: 45_000 },
262
+ );
263
+ const text = response.data.text;
264
+ if (
265
+ response.status === 200 &&
266
+ typeof text === "string" &&
267
+ text.trim().length > 0
268
+ ) {
269
+ return response;
270
+ }
271
+ errors.push(
272
+ `attempt ${attempt}: status=${response.status}, textType=${typeof text}, textLength=${
273
+ typeof text === "string" ? text.length : 0
274
+ }`,
275
+ );
276
+ } catch (err) {
277
+ errors.push(
278
+ `attempt ${attempt}: ${err instanceof Error ? err.message : String(err)}`,
279
+ );
280
+ }
281
+ if (attempt < attempts) {
282
+ await sleep(1_000);
283
+ }
284
+ }
285
+ throw new Error(
286
+ `POST /api/chat failed after ${attempts} attempts: ${errors.join(" | ")}`,
287
+ );
288
+ }
289
+
290
+ async function postChatPromptWithRetries(
291
+ port: number,
292
+ prompt: string,
293
+ attempts = 4,
294
+ timeoutMs = 90_000,
295
+ ): Promise<{ status: number; data: Record<string, unknown> }> {
296
+ const errors: string[] = [];
297
+ for (let attempt = 1; attempt <= attempts; attempt += 1) {
298
+ try {
299
+ const response = await http$(
300
+ port,
301
+ "POST",
302
+ "/api/chat",
303
+ { text: prompt, mode: "simple" },
304
+ { timeoutMs },
305
+ );
306
+ const text = response.data.text;
307
+ if (
308
+ response.status === 200 &&
309
+ typeof text === "string" &&
310
+ text.trim().length > 0
311
+ ) {
312
+ return response;
313
+ }
314
+ errors.push(
315
+ `attempt ${attempt}: status=${response.status}, textType=${typeof text}, textLength=${
316
+ typeof text === "string" ? text.length : 0
317
+ }`,
318
+ );
319
+ } catch (err) {
320
+ errors.push(
321
+ `attempt ${attempt}: ${err instanceof Error ? err.message : String(err)}`,
322
+ );
323
+ }
324
+ if (attempt < attempts) {
325
+ await sleep(1_000);
326
+ }
327
+ }
328
+ throw new Error(
329
+ `POST /api/chat(prompt) failed after ${attempts} attempts: ${errors.join(" | ")}`,
330
+ );
331
+ }
332
+
333
+ async function handleMessageAndCollectText(
334
+ runtime: AgentRuntime,
335
+ message: ReturnType<typeof createMessageMemory>,
336
+ options?: { timeoutMs?: number },
337
+ ): Promise<string> {
338
+ let responseText = "";
339
+ const result = await withTimeout(
340
+ Promise.resolve(
341
+ runtime.messageService?.handleMessage(
342
+ runtime,
343
+ message,
344
+ async (content: { text?: string }) => {
345
+ if (content.text) responseText += content.text;
346
+ return [];
347
+ },
348
+ ),
349
+ ),
350
+ options?.timeoutMs ?? 90_000,
351
+ "handleMessage",
352
+ );
353
+ if (!responseText && result?.responseContent?.text) {
354
+ responseText = result.responseContent.text;
355
+ }
356
+ return responseText;
357
+ }
358
+
359
+ // ---------------------------------------------------------------------------
360
+ // Typed interface for AutonomyService (avoids any/unknown)
361
+ // ---------------------------------------------------------------------------
362
+
363
+ interface AutonomyServiceLike extends Service {
364
+ performAutonomousThink(): Promise<void>;
365
+ setLoopInterval(ms: number): void;
366
+ }
367
+
368
+ // ---------------------------------------------------------------------------
369
+ // Shared state
370
+ // ---------------------------------------------------------------------------
371
+
372
+ describe("Agent Runtime E2E", () => {
373
+ let runtime: AgentRuntime;
374
+ let initialized = false;
375
+ let server: { port: number; close: () => Promise<void> } | null = null;
376
+
377
+ const roomId = stringToUuid("test-e2e-room");
378
+ const userId = crypto.randomUUID() as UUID;
379
+ const worldId = stringToUuid("test-e2e-world");
380
+
381
+ const pgliteDir = fs.mkdtempSync(
382
+ path.join(os.tmpdir(), "milady-e2e-pglite-"),
383
+ );
384
+ const workspaceDir = fs.mkdtempSync(
385
+ path.join(os.tmpdir(), "milady-e2e-workspace-"),
386
+ );
387
+
388
+ const corePluginNames = [
389
+ "@elizaos/plugin-trajectory-logger",
390
+ "@elizaos/plugin-agent-skills",
391
+ // NOTE: @elizaos/plugin-commands is excluded — commented out as "not yet ready" in core-plugins.ts
392
+ "@elizaos/plugin-personality",
393
+ "@elizaos/plugin-experience",
394
+ "@elizaos/plugin-todo",
395
+ // NOTE: @elizaos/plugin-form is excluded because its package.json has
396
+ // an incorrect main/module/exports entry that prevents resolution.
397
+ ];
398
+
399
+ // ─── Setup ──────────────────────────────────────────────────────────────
400
+
401
+ beforeAll(async () => {
402
+ if (!hasModelProvider) return;
403
+ process.env.LOG_LEVEL = process.env.MILADY_E2E_LOG_LEVEL ?? "error";
404
+
405
+ const secrets: Record<string, string> = {};
406
+ if (hasOpenAI)
407
+ secrets.OPENAI_API_KEY = process.env.OPENAI_API_KEY as string;
408
+ if (hasAnthropic)
409
+ secrets.ANTHROPIC_API_KEY = process.env.ANTHROPIC_API_KEY as string;
410
+ if (hasGroq) secrets.GROQ_API_KEY = process.env.GROQ_API_KEY as string;
411
+
412
+ const character = createCharacter({
413
+ name: "TestAgent",
414
+ bio: "A test agent for comprehensive E2E verification.",
415
+ secrets,
416
+ });
417
+
418
+ const sqlPlugin = await loadPlugin("@elizaos/plugin-sql");
419
+ const localEmbeddingPlugin = await loadPlugin(
420
+ "@elizaos/plugin-local-embedding",
421
+ );
422
+
423
+ const plugins: Plugin[] = [];
424
+ for (const n of corePluginNames) {
425
+ const p = await loadPlugin(n);
426
+ if (p) plugins.push(p);
427
+ }
428
+ if (hasOpenAI) {
429
+ const p = await loadPlugin("@elizaos/plugin-openai");
430
+ if (p) plugins.push(p);
431
+ }
432
+ if (hasAnthropic) {
433
+ const p = await loadPlugin("@elizaos/plugin-anthropic");
434
+ if (p) plugins.push(p);
435
+ }
436
+ if (hasGroq) {
437
+ const p = await loadPlugin("@elizaos/plugin-groq");
438
+ if (p) plugins.push(p);
439
+ }
440
+
441
+ const createInitializedRuntime = async (): Promise<AgentRuntime> => {
442
+ // PRODUCTION DEFAULTS: checkShouldRespond defaults to true.
443
+ // DMs bypass shouldRespond via alwaysRespondChannels in message.ts.
444
+ const instance = new AgentRuntime({
445
+ character,
446
+ plugins,
447
+ logLevel: "error",
448
+ enableAutonomy: true,
449
+ // checkShouldRespond is NOT set — defaults to true (production behavior)
450
+ });
451
+
452
+ if (sqlPlugin) {
453
+ await instance.registerPlugin(sqlPlugin);
454
+ if (instance.adapter && !(await instance.adapter.isReady())) {
455
+ await instance.adapter.init();
456
+ }
457
+ }
458
+ if (localEmbeddingPlugin) {
459
+ configureLocalEmbeddingPlugin(localEmbeddingPlugin);
460
+ await instance.registerPlugin(localEmbeddingPlugin);
461
+ } else {
462
+ logger.warn(
463
+ "[e2e] @elizaos/plugin-local-embedding failed to load; runtime may use remote embeddings",
464
+ );
465
+ }
466
+
467
+ await instance.initialize();
468
+ const autonomySvc = instance.getService<AutonomyServiceLike>("AUTONOMY");
469
+ if (!autonomySvc) {
470
+ const serviceTypes = Array.from(instance.services.keys()).join(", ");
471
+ throw new Error(
472
+ `AUTONOMY service unavailable after initialize; services=${serviceTypes || "(none)"}`,
473
+ );
474
+ }
475
+
476
+ autonomySvc.setLoopInterval(5 * 60_000);
477
+ return instance;
478
+ };
479
+
480
+ let lastInitError: unknown = null;
481
+ for (let attempt = 1; attempt <= 2; attempt += 1) {
482
+ const attemptPgliteDir = path.join(pgliteDir, `attempt-${attempt}`);
483
+ fs.rmSync(attemptPgliteDir, { recursive: true, force: true });
484
+ fs.mkdirSync(attemptPgliteDir, { recursive: true });
485
+ process.env.PGLITE_DATA_DIR = attemptPgliteDir;
486
+
487
+ try {
488
+ runtime = await createInitializedRuntime();
489
+ initialized = true;
490
+ lastInitError = null;
491
+ break;
492
+ } catch (err) {
493
+ lastInitError = err;
494
+ logger.warn(
495
+ `[e2e] Runtime initialization attempt ${attempt} failed: ${errorMessage(err)}`,
496
+ );
497
+ if (runtime) {
498
+ try {
499
+ runtime.enableAutonomy = false;
500
+ await withTimeout(runtime.stop(), 60_000, "runtime.stop() retry");
501
+ } catch (stopErr) {
502
+ logger.warn(
503
+ `[e2e] Runtime cleanup after failed init attempt ${attempt}: ${errorMessage(stopErr)}`,
504
+ );
505
+ }
506
+ }
507
+ if (attempt < 2) {
508
+ await sleep(1_000 * attempt);
509
+ }
510
+ }
511
+ }
512
+
513
+ if (!initialized) {
514
+ throw lastInitError instanceof Error
515
+ ? lastInitError
516
+ : new Error(errorMessage(lastInitError));
517
+ }
518
+
519
+ try {
520
+ await runtime.ensureConnection({
521
+ entityId: userId,
522
+ roomId,
523
+ worldId,
524
+ userName: "TestUser",
525
+ source: "test",
526
+ channelId: "test-e2e-channel",
527
+ type: ChannelType.DM,
528
+ });
529
+ } catch (err) {
530
+ logger.warn(
531
+ `[e2e] ensureConnection failed, retrying: ${err instanceof Error ? err.message : err}`,
532
+ );
533
+ await runtime.ensureConnection({
534
+ entityId: userId,
535
+ roomId: crypto.randomUUID() as UUID,
536
+ worldId: crypto.randomUUID() as UUID,
537
+ userName: "TestUser",
538
+ source: "test",
539
+ channelId: "test-e2e-channel",
540
+ type: ChannelType.DM,
541
+ });
542
+ }
543
+
544
+ server = await startApiServer({ port: 0, runtime });
545
+ logger.info(
546
+ `[e2e] Setup complete — ${runtime.plugins.length} plugins, API on :${server.port}`,
547
+ );
548
+ }, 180_000);
549
+
550
+ afterAll(async () => {
551
+ if (server) {
552
+ try {
553
+ await withTimeout(server.close(), 30_000, "server.close()");
554
+ } catch (err) {
555
+ logger.warn(
556
+ `[e2e] Server close error: ${err instanceof Error ? err.message : err}`,
557
+ );
558
+ }
559
+ }
560
+ if (runtime) {
561
+ try {
562
+ runtime.enableAutonomy = false;
563
+ await withTimeout(runtime.stop(), 90_000, "runtime.stop()");
564
+ } catch (err) {
565
+ logger.warn(
566
+ `[e2e] Runtime stop error: ${err instanceof Error ? err.message : err}`,
567
+ );
568
+ }
569
+ }
570
+ try {
571
+ fs.rmSync(pgliteDir, { recursive: true, force: true });
572
+ } catch (err) {
573
+ logger.warn(
574
+ `[e2e] PGlite cleanup: ${err instanceof Error ? err.message : err}`,
575
+ );
576
+ }
577
+ try {
578
+ fs.rmSync(workspaceDir, { recursive: true, force: true });
579
+ } catch (err) {
580
+ logger.warn(
581
+ `[e2e] Workspace cleanup: ${err instanceof Error ? err.message : err}`,
582
+ );
583
+ }
584
+ }, 150_000);
585
+
586
+ // ===================================================================
587
+ // 1. Startup
588
+ // ===================================================================
589
+
590
+ describe("startup", () => {
591
+ it.skipIf(!hasModelProvider)("initializes successfully", () => {
592
+ expect(initialized).toBe(true);
593
+ expect(runtime.character.name).toBe("TestAgent");
594
+ });
595
+
596
+ it.skipIf(!hasModelProvider)("every core plugin loaded", () => {
597
+ const coreResults = pluginLoadResults.filter((r) =>
598
+ corePluginNames.includes(r.name),
599
+ );
600
+ for (const result of coreResults) {
601
+ expect(
602
+ result.loaded,
603
+ `Core plugin ${result.name} failed: ${result.error}`,
604
+ ).toBe(true);
605
+ }
606
+ });
607
+
608
+ it.skipIf(!hasModelProvider)(
609
+ "loaded at least 8 plugins (6 core + bootstrap + 1 provider)",
610
+ () => {
611
+ expect(runtime.plugins.length).toBeGreaterThanOrEqual(8);
612
+ },
613
+ );
614
+
615
+ it.skipIf(!hasModelProvider)("messageService is non-null", () => {
616
+ expect(runtime.messageService).not.toBeNull();
617
+ });
618
+
619
+ it.skipIf(!hasModelProvider)(
620
+ "checkShouldRespond is enabled (production default)",
621
+ () => {
622
+ expect(runtime.isCheckShouldRespondEnabled()).toBe(true);
623
+ logger.info(
624
+ "[e2e] Confirmed: checkShouldRespond is TRUE (production default)",
625
+ );
626
+ },
627
+ );
628
+
629
+ it.skipIf(!hasModelProvider)("AUTONOMY service type is registered", () => {
630
+ const serviceTypes = Array.from(runtime.services.keys());
631
+ logger.info(`[e2e] Service types: ${serviceTypes.join(", ")}`);
632
+ const hasAutonomy = serviceTypes.some((t) =>
633
+ t.toUpperCase().includes("AUTONOMY"),
634
+ );
635
+ expect(
636
+ hasAutonomy,
637
+ `No AUTONOMY service found in: ${serviceTypes.join(", ")}`,
638
+ ).toBe(true);
639
+ });
640
+ });
641
+
642
+ // ===================================================================
643
+ // 2. shouldRespond — DMs auto-respond even with checkShouldRespond=true
644
+ // ===================================================================
645
+
646
+ describe("shouldRespond (production mode)", () => {
647
+ it.skipIf(!hasModelProvider)(
648
+ "DM messages get responses with checkShouldRespond=true",
649
+ async () => {
650
+ // checkShouldRespond is TRUE. DMs should STILL get responses because
651
+ // ChannelType.DM is in the alwaysRespondChannels list in message.ts.
652
+ expect(runtime.isCheckShouldRespondEnabled()).toBe(true);
653
+
654
+ const msg = createMessageMemory({
655
+ id: crypto.randomUUID() as UUID,
656
+ entityId: userId,
657
+ roomId,
658
+ content: {
659
+ text: "Can you hear me?",
660
+ source: "test",
661
+ channelType: ChannelType.DM, // DM = always respond
662
+ },
663
+ });
664
+ const resp = await handleMessageAndCollectText(runtime, msg);
665
+
666
+ if (resp.length === 0) {
667
+ if (
668
+ await shouldSkipDueModelProviderUnavailable(
669
+ runtime,
670
+ "DM messages get responses with checkShouldRespond=true",
671
+ )
672
+ ) {
673
+ return;
674
+ }
675
+ }
676
+
677
+ expect(
678
+ resp.length,
679
+ "DM should always get a response even with checkShouldRespond=true",
680
+ ).toBeGreaterThan(0);
681
+ logger.info(`[e2e] shouldRespond DM test: "${resp}"`);
682
+ },
683
+ 120_000,
684
+ );
685
+ });
686
+
687
+ // ===================================================================
688
+ // 3. Messaging + multi-turn memory
689
+ // ===================================================================
690
+
691
+ describe("messaging", () => {
692
+ it.skipIf(!hasModelProvider)(
693
+ "generateText returns non-empty text",
694
+ async () => {
695
+ let text = "";
696
+ try {
697
+ const result = await runtime.generateText(
698
+ "What is 2 + 2? Answer only the number.",
699
+ { maxTokens: 256 },
700
+ );
701
+ text = await getGeneratedText(result);
702
+ } catch (err) {
703
+ const message = errorMessage(err);
704
+ if (isModelProviderUnavailableError(message)) {
705
+ cachedModelProviderUnavailableReason = message;
706
+ logger.warn(
707
+ `[e2e] Skipping "generateText returns non-empty text" due to provider limit: ${message}`,
708
+ );
709
+ return;
710
+ }
711
+ throw err;
712
+ }
713
+ if (text.length === 0) {
714
+ if (
715
+ await shouldSkipDueModelProviderUnavailable(
716
+ runtime,
717
+ "generateText returns non-empty text",
718
+ )
719
+ ) {
720
+ return;
721
+ }
722
+ }
723
+ expect(text.length).toBeGreaterThan(0);
724
+ },
725
+ 60_000,
726
+ );
727
+
728
+ it.skipIf(!hasModelProvider)(
729
+ "handleMessage returns non-empty text",
730
+ async () => {
731
+ const conversationRoomId = crypto.randomUUID() as UUID;
732
+ await runtime.ensureConnection({
733
+ entityId: userId,
734
+ roomId: conversationRoomId,
735
+ worldId,
736
+ userName: "TestUser",
737
+ source: "test",
738
+ channelId: conversationRoomId,
739
+ type: ChannelType.DM,
740
+ });
741
+ const msg = createMessageMemory({
742
+ id: crypto.randomUUID() as UUID,
743
+ entityId: userId,
744
+ roomId: conversationRoomId,
745
+ content: {
746
+ text: "Say hello in one word.",
747
+ source: "test",
748
+ channelType: ChannelType.DM,
749
+ },
750
+ });
751
+ const resp = await handleMessageAndCollectText(runtime, msg, {
752
+ timeoutMs: 90_000,
753
+ });
754
+ if (resp.length === 0) {
755
+ if (
756
+ await shouldSkipDueModelProviderUnavailable(
757
+ runtime,
758
+ "handleMessage returns non-empty text",
759
+ )
760
+ ) {
761
+ return;
762
+ }
763
+ }
764
+ expect(resp.length).toBeGreaterThan(0);
765
+ },
766
+ 120_000,
767
+ );
768
+
769
+ it.skipIf(!hasModelProvider)(
770
+ "multi-turn: agent remembers context",
771
+ async () => {
772
+ const conversationRoomId = crypto.randomUUID() as UUID;
773
+ await runtime.ensureConnection({
774
+ entityId: userId,
775
+ roomId: conversationRoomId,
776
+ worldId,
777
+ userName: "TestUser",
778
+ source: "test",
779
+ channelId: conversationRoomId,
780
+ type: ChannelType.DM,
781
+ });
782
+ const msg1 = createMessageMemory({
783
+ id: crypto.randomUUID() as UUID,
784
+ entityId: userId,
785
+ roomId: conversationRoomId,
786
+ content: {
787
+ text: "Remember exactly this secret word for this conversation: pineapple. Reply only with remembered.",
788
+ source: "test",
789
+ channelType: ChannelType.DM,
790
+ },
791
+ });
792
+ const t1 = await handleMessageAndCollectText(runtime, msg1, {
793
+ timeoutMs: 90_000,
794
+ });
795
+ if (t1.length === 0) {
796
+ if (
797
+ await shouldSkipDueModelProviderUnavailable(
798
+ runtime,
799
+ "multi-turn: agent remembers context",
800
+ )
801
+ ) {
802
+ return;
803
+ }
804
+ }
805
+ expect(t1.length, "Turn 1 must produce a response").toBeGreaterThan(0);
806
+
807
+ const msg2 = createMessageMemory({
808
+ id: crypto.randomUUID() as UUID,
809
+ entityId: userId,
810
+ roomId: conversationRoomId,
811
+ content: {
812
+ text: "What exact secret word did I tell you earlier in this conversation? Reply with only the word.",
813
+ source: "test",
814
+ channelType: ChannelType.DM,
815
+ },
816
+ });
817
+ const t2 = await handleMessageAndCollectText(runtime, msg2, {
818
+ timeoutMs: 90_000,
819
+ });
820
+ if (t2.length === 0) {
821
+ if (
822
+ await shouldSkipDueModelProviderUnavailable(
823
+ runtime,
824
+ "multi-turn: agent remembers context",
825
+ )
826
+ ) {
827
+ return;
828
+ }
829
+ }
830
+
831
+ logger.info(`[e2e] multi-turn: "${t2}"`);
832
+ if (t2.toLowerCase().includes("pineapple")) {
833
+ return;
834
+ }
835
+
836
+ const retryPrompt = createMessageMemory({
837
+ id: crypto.randomUUID() as UUID,
838
+ entityId: userId,
839
+ roomId: conversationRoomId,
840
+ content: {
841
+ text: "Repeat the exact secret word from earlier. Reply with only that single word.",
842
+ source: "test",
843
+ channelType: ChannelType.DM,
844
+ },
845
+ });
846
+ const retryText = await handleMessageAndCollectText(runtime, retryPrompt, {
847
+ timeoutMs: 90_000,
848
+ });
849
+ logger.info(`[e2e] multi-turn retry: "${retryText}"`);
850
+ expect(retryText.toLowerCase()).toContain("pineapple");
851
+ },
852
+ 180_000,
853
+ );
854
+ });
855
+
856
+ // ===================================================================
857
+ // 4. Autonomy — REAL think cycle
858
+ // ===================================================================
859
+
860
+ describe("autonomy (real thinking)", () => {
861
+ it.skipIf(!hasModelProvider)("autonomy flag is enabled", () => {
862
+ expect(runtime.enableAutonomy).toBe(true);
863
+ });
864
+
865
+ it.skipIf(!hasModelProvider)(
866
+ "performAutonomousThink() completes a real think cycle",
867
+ async () => {
868
+ // Get the actual AutonomyService and call performAutonomousThink() directly.
869
+ // This uses the full pipeline: creates autonomous message → model generates
870
+ // response → response stored as memory. No mocks.
871
+ const svc = runtime.getService<AutonomyServiceLike>("AUTONOMY");
872
+ expect(svc, "AutonomyService must be registered").toBeDefined();
873
+
874
+ logger.info("[e2e] Starting real autonomy think cycle...");
875
+ await svc?.performAutonomousThink();
876
+ logger.info("[e2e] Autonomy think cycle completed successfully");
877
+ // If we got here without throwing, the full autonomous pipeline worked:
878
+ // prompt generation → model call → response processing → memory storage
879
+ },
880
+ 180_000,
881
+ );
882
+
883
+ it.skipIf(!hasModelProvider)(
884
+ "autonomy REST endpoint reflects enabled state",
885
+ async () => {
886
+ const get1 = await http$(server?.port, "GET", "/api/agent/autonomy");
887
+ expect(get1.data.enabled).toBe(true);
888
+
889
+ await http$(server?.port, "POST", "/api/agent/autonomy", {
890
+ enabled: false,
891
+ });
892
+ const get2 = await http$(server?.port, "GET", "/api/agent/autonomy");
893
+ expect(get2.data.enabled).toBe(false);
894
+
895
+ await http$(server?.port, "POST", "/api/agent/autonomy", {
896
+ enabled: true,
897
+ });
898
+ const get3 = await http$(server?.port, "GET", "/api/agent/autonomy");
899
+ expect(get3.data.enabled).toBe(true);
900
+ },
901
+ );
902
+ });
903
+
904
+ // ===================================================================
905
+ // 5. REST API
906
+ // ===================================================================
907
+
908
+ describe("REST API", () => {
909
+ it.skipIf(!hasModelProvider)("GET /api/status", async () => {
910
+ const { status, data } = await http$(server?.port, "GET", "/api/status");
911
+ expect(status).toBe(200);
912
+ expect(data.state).toBe("running");
913
+ expect(typeof data.startedAt).toBe("number");
914
+ });
915
+
916
+ it.skipIf(!hasModelProvider)(
917
+ "POST /api/chat returns real response",
918
+ async () => {
919
+ let chat: { status: number; data: Record<string, unknown> };
920
+ try {
921
+ chat = await postChatWithRetries(server?.port);
922
+ } catch (err) {
923
+ if (
924
+ await shouldSkipDueModelProviderUnavailable(
925
+ runtime,
926
+ "POST /api/chat returns real response",
927
+ )
928
+ ) {
929
+ return;
930
+ }
931
+ throw err;
932
+ }
933
+ const { status, data } = chat;
934
+ expect(status).toBe(200);
935
+ if (String(data.text ?? "").length === 0) {
936
+ if (
937
+ await shouldSkipDueModelProviderUnavailable(
938
+ runtime,
939
+ "POST /api/chat returns real response",
940
+ )
941
+ ) {
942
+ return;
943
+ }
944
+ }
945
+ expect((data.text as string).length).toBeGreaterThan(0);
946
+ },
947
+ 180_000,
948
+ );
949
+
950
+ it.skipIf(!hasModelProvider)(
951
+ "todo CRUD works through workbench endpoints",
952
+ async () => {
953
+ const todoName = `REST Todo ${Date.now()}`;
954
+ const create = await http$(
955
+ server?.port,
956
+ "POST",
957
+ "/api/workbench/todos",
958
+ {
959
+ name: todoName,
960
+ description: "Created from agent-runtime REST e2e",
961
+ priority: 2,
962
+ isUrgent: false,
963
+ type: "one-off",
964
+ },
965
+ );
966
+ expect(create.status).toBe(201);
967
+ const todo = create.data.todo as Record<string, unknown>;
968
+ const todoId = String(todo.id ?? "");
969
+ expect(todoId.length).toBeGreaterThan(0);
970
+
971
+ const list = await http$(server?.port, "GET", "/api/workbench/todos");
972
+ expect(list.status).toBe(200);
973
+ const todos = list.data.todos as Array<Record<string, unknown>>;
974
+ expect(todos.some((item) => item.id === todoId)).toBe(true);
975
+
976
+ const update = await http$(
977
+ server?.port,
978
+ "PUT",
979
+ `/api/workbench/todos/${encodeURIComponent(todoId)}`,
980
+ { priority: 1, isUrgent: true },
981
+ );
982
+ expect(update.status).toBe(200);
983
+ expect((update.data.todo as Record<string, unknown>).priority).toBe(1);
984
+ expect((update.data.todo as Record<string, unknown>).isUrgent).toBe(
985
+ true,
986
+ );
987
+
988
+ const complete = await http$(
989
+ server?.port,
990
+ "POST",
991
+ `/api/workbench/todos/${encodeURIComponent(todoId)}/complete`,
992
+ { isCompleted: true },
993
+ );
994
+ expect(complete.status).toBe(200);
995
+ expect(complete.data.ok).toBe(true);
996
+
997
+ const get = await http$(
998
+ server?.port,
999
+ "GET",
1000
+ `/api/workbench/todos/${encodeURIComponent(todoId)}`,
1001
+ );
1002
+ expect(get.status).toBe(200);
1003
+ expect((get.data.todo as Record<string, unknown>).isCompleted).toBe(
1004
+ true,
1005
+ );
1006
+
1007
+ const del = await http$(
1008
+ server?.port,
1009
+ "DELETE",
1010
+ `/api/workbench/todos/${encodeURIComponent(todoId)}`,
1011
+ );
1012
+ expect(del.status).toBe(200);
1013
+ expect(del.data.ok).toBe(true);
1014
+ },
1015
+ 120_000,
1016
+ );
1017
+
1018
+ it.skipIf(!hasModelProvider)(
1019
+ "POST /api/chat rejects empty text",
1020
+ async () => {
1021
+ expect(
1022
+ (await http$(server?.port, "POST", "/api/chat", { text: "" })).status,
1023
+ ).toBe(400);
1024
+ },
1025
+ );
1026
+
1027
+ it.skipIf(!hasModelProvider)(
1028
+ "GET /api/onboarding/options has non-empty arrays",
1029
+ async () => {
1030
+ const { data } = await http$(
1031
+ server?.port,
1032
+ "GET",
1033
+ "/api/onboarding/options",
1034
+ );
1035
+ expect((data.names as string[]).length).toBeGreaterThan(0);
1036
+ expect((data.styles as unknown[]).length).toBeGreaterThan(0);
1037
+ expect((data.providers as unknown[]).length).toBeGreaterThan(0);
1038
+ },
1039
+ );
1040
+
1041
+ it.skipIf(!hasModelProvider)(
1042
+ "POST /api/onboarding writes agent name",
1043
+ async () => {
1044
+ const { data } = await http$(server?.port, "POST", "/api/onboarding", {
1045
+ name: "OnboardTest",
1046
+ });
1047
+ expect(data.ok).toBe(true);
1048
+ expect(
1049
+ (await http$(server?.port, "GET", "/api/status")).data.agentName,
1050
+ ).toBe("OnboardTest");
1051
+ },
1052
+ );
1053
+
1054
+ it.skipIf(!hasModelProvider)("PUT /api/config round-trips", async () => {
1055
+ const original = (await http$(server?.port, "GET", "/api/config")).data;
1056
+ await http$(server?.port, "PUT", "/api/config", {
1057
+ features: { temp_cfg: { enabled: true, name: "TempCfg" } },
1058
+ });
1059
+ const { data } = await http$(server?.port, "GET", "/api/config");
1060
+ expect(
1061
+ (data as Record<string, Record<string, Record<string, string>>>)
1062
+ .features?.temp_cfg?.name,
1063
+ ).toBe("TempCfg");
1064
+ await http$(server?.port, "PUT", "/api/config", original); // restore
1065
+ });
1066
+
1067
+ it.skipIf(!hasModelProvider)(
1068
+ "GET /api/logs has entries with timestamp/level/message",
1069
+ async () => {
1070
+ const entries = (await http$(server?.port, "GET", "/api/logs")).data
1071
+ .entries as Array<Record<string, unknown>>;
1072
+ expect(entries.length).toBeGreaterThan(0);
1073
+ expect(typeof entries[0].timestamp).toBe("number");
1074
+ expect(typeof entries[0].level).toBe("string");
1075
+ expect(typeof entries[0].message).toBe("string");
1076
+ },
1077
+ );
1078
+
1079
+ it.skipIf(!hasModelProvider)(
1080
+ "PUT /api/plugins/:id returns 404 for nonexistent",
1081
+ async () => {
1082
+ expect(
1083
+ (
1084
+ await http$(server?.port, "PUT", "/api/plugins/fake-plugin", {
1085
+ enabled: true,
1086
+ })
1087
+ ).status,
1088
+ ).toBe(404);
1089
+ },
1090
+ );
1091
+
1092
+ it.skipIf(!hasModelProvider)(
1093
+ "pause → resume verifies state change",
1094
+ async () => {
1095
+ await http$(server?.port, "POST", "/api/agent/pause");
1096
+ expect(
1097
+ (await http$(server?.port, "GET", "/api/status")).data.state,
1098
+ ).toBe("paused");
1099
+ await http$(server?.port, "POST", "/api/agent/resume");
1100
+ expect(
1101
+ (await http$(server?.port, "GET", "/api/status")).data.state,
1102
+ ).toBe("running");
1103
+ },
1104
+ );
1105
+
1106
+ it.skipIf(!hasModelProvider)("404 for unknown route", async () => {
1107
+ expect(
1108
+ (await http$(server?.port, "GET", "/api/nonexistent")).status,
1109
+ ).toBe(404);
1110
+ });
1111
+ });
1112
+
1113
+ // ===================================================================
1114
+ // 6. Error paths
1115
+ // ===================================================================
1116
+
1117
+ describe("error paths", () => {
1118
+ it.skipIf(!hasModelProvider)("non-JSON body → 400", async () => {
1119
+ const { status } = await new Promise<{ status: number }>(
1120
+ (resolve, reject) => {
1121
+ const req = http.request(
1122
+ {
1123
+ hostname: "127.0.0.1",
1124
+ port: server?.port,
1125
+ path: "/api/chat",
1126
+ method: "POST",
1127
+ headers: {
1128
+ "Content-Type": "application/json",
1129
+ "Content-Length": 11,
1130
+ },
1131
+ },
1132
+ (res) => {
1133
+ res.resume();
1134
+ resolve({ status: res.statusCode ?? 0 });
1135
+ },
1136
+ );
1137
+ req.on("error", reject);
1138
+ req.write("not-json!!!");
1139
+ req.end();
1140
+ },
1141
+ );
1142
+ expect(status).toBe(400);
1143
+ });
1144
+
1145
+ it.skipIf(!hasModelProvider)("generateText empty → throws", async () => {
1146
+ await expect(
1147
+ runtime.generateText("", { maxTokens: 10 }),
1148
+ ).rejects.toThrow();
1149
+ });
1150
+
1151
+ it.skipIf(!hasModelProvider)(
1152
+ "generateText whitespace → throws",
1153
+ async () => {
1154
+ await expect(
1155
+ runtime.generateText(" ", { maxTokens: 10 }),
1156
+ ).rejects.toThrow();
1157
+ },
1158
+ );
1159
+ });
1160
+
1161
+ // ===================================================================
1162
+ // 7. Concurrent requests
1163
+ // ===================================================================
1164
+
1165
+ describe("concurrent", () => {
1166
+ it.skipIf(!hasModelProvider)(
1167
+ "5 parallel status + 3 parallel chat",
1168
+ async () => {
1169
+ const prompts = [
1170
+ "What is 2 + 2? Number only.",
1171
+ "What is 3 + 3? Number only.",
1172
+ "What is 4 + 4? Number only.",
1173
+ ];
1174
+ const [statuses, chats] = await Promise.all([
1175
+ Promise.all(
1176
+ Array.from({ length: 5 }, () =>
1177
+ http$(server?.port, "GET", "/api/status", undefined, {
1178
+ timeoutMs: 30_000,
1179
+ }),
1180
+ ),
1181
+ ),
1182
+ Promise.all(
1183
+ prompts.map((prompt) =>
1184
+ postChatPromptWithRetries(
1185
+ server?.port ?? 0,
1186
+ prompt,
1187
+ 3,
1188
+ 90_000,
1189
+ ),
1190
+ ),
1191
+ ),
1192
+ ]);
1193
+ for (const r of statuses) expect(r.status).toBe(200);
1194
+ for (const r of chats) {
1195
+ expect(r.status).toBe(200);
1196
+ if (String(r.data.text ?? "").length === 0) {
1197
+ if (
1198
+ await shouldSkipDueModelProviderUnavailable(
1199
+ runtime,
1200
+ "5 parallel status + 3 parallel chat",
1201
+ )
1202
+ ) {
1203
+ return;
1204
+ }
1205
+ }
1206
+ expect((r.data.text as string).length).toBeGreaterThan(0);
1207
+ }
1208
+ },
1209
+ 90_000,
1210
+ );
1211
+ });
1212
+
1213
+ // ===================================================================
1214
+ // 8. Workspace
1215
+ // ===================================================================
1216
+
1217
+ describe("workspace", () => {
1218
+ it.skipIf(!hasModelProvider)(
1219
+ "creates directory and is idempotent",
1220
+ async () => {
1221
+ const d = path.join(workspaceDir, "ws-test");
1222
+ expect(fs.existsSync(d)).toBe(false);
1223
+ await ensureAgentWorkspace({ dir: d });
1224
+ expect(fs.existsSync(d)).toBe(true);
1225
+ await ensureAgentWorkspace({ dir: d }); // no throw
1226
+ },
1227
+ );
1228
+ });
1229
+
1230
+ // ===================================================================
1231
+ // 9. Triggers — REAL LLM execution through trigger dispatch
1232
+ // ===================================================================
1233
+
1234
+ describe("triggers (real LLM execution)", () => {
1235
+ it.skipIf(!hasModelProvider)(
1236
+ "creates trigger, executes it, LLM processes instruction, run history records success",
1237
+ async () => {
1238
+ // Register the trigger worker on the real runtime (same as milady-plugin.ts does).
1239
+ const { registerTriggerTaskWorker } = await import(
1240
+ "../src/triggers/runtime"
1241
+ );
1242
+ registerTriggerTaskWorker(runtime);
1243
+
1244
+ // 1. Create a trigger via the real REST API
1245
+ const createRes = await http$(server?.port, "POST", "/api/triggers", {
1246
+ displayName: "Live LLM Trigger",
1247
+ instructions:
1248
+ "You have been triggered by the test suite. Acknowledge this trigger by responding with a brief status report.",
1249
+ triggerType: "interval",
1250
+ intervalMs: 3_600_000,
1251
+ wakeMode: "inject_now",
1252
+ createdBy: "e2e-test",
1253
+ });
1254
+
1255
+ expect(createRes.status).toBe(201);
1256
+ const triggerId = (createRes.data.trigger as Record<string, string>)
1257
+ ?.id;
1258
+ expect(triggerId).toBeDefined();
1259
+ expect(triggerId.length).toBeGreaterThan(0);
1260
+ logger.info(`[e2e] Created trigger: ${triggerId}`);
1261
+
1262
+ // 2. List triggers — confirm it exists
1263
+ const listRes = await http$(server?.port, "GET", "/api/triggers");
1264
+ expect(listRes.status).toBe(200);
1265
+ const triggers = listRes.data.triggers as Array<
1266
+ Record<string, unknown>
1267
+ >;
1268
+ expect(triggers.length).toBeGreaterThanOrEqual(1);
1269
+ const found = triggers.find((t) => t.id === triggerId);
1270
+ expect(found).toBeDefined();
1271
+ expect(found?.enabled).toBe(true);
1272
+ expect(found?.triggerType).toBe("interval");
1273
+
1274
+ // 3. Execute the trigger — this dispatches into the REAL autonomy
1275
+ // service which calls the REAL LLM through performAutonomousThink()
1276
+ logger.info("[e2e] Executing trigger (real LLM dispatch)...");
1277
+ const execRes = await http$(
1278
+ server?.port,
1279
+ "POST",
1280
+ `/api/triggers/${encodeURIComponent(triggerId)}/execute`,
1281
+ undefined,
1282
+ { timeoutMs: 120_000 },
1283
+ );
1284
+
1285
+ if (
1286
+ execRes.status !== 200 ||
1287
+ (execRes.data.result as Record<string, unknown>)?.status !== "success"
1288
+ ) {
1289
+ if (
1290
+ await shouldSkipDueModelProviderUnavailable(
1291
+ runtime,
1292
+ "creates trigger, executes it, LLM processes instruction, run history records success",
1293
+ )
1294
+ ) {
1295
+ return;
1296
+ }
1297
+ }
1298
+
1299
+ expect(execRes.status).toBe(200);
1300
+ const execResult = execRes.data.result as Record<string, unknown>;
1301
+ expect(execResult.status).toBe("success");
1302
+ expect(execResult.taskDeleted).toBe(false);
1303
+ logger.info(`[e2e] Trigger execution: status=${execResult.status}`);
1304
+
1305
+ // 4. Verify run history was recorded
1306
+ const runsRes = await http$(
1307
+ server?.port,
1308
+ "GET",
1309
+ `/api/triggers/${encodeURIComponent(triggerId)}/runs`,
1310
+ );
1311
+ expect(runsRes.status).toBe(200);
1312
+ const runs = runsRes.data.runs as Array<Record<string, unknown>>;
1313
+ expect(runs.length).toBe(1);
1314
+ expect(runs[0].status).toBe("success");
1315
+ expect(runs[0].source).toBe("manual");
1316
+ expect(typeof runs[0].latencyMs).toBe("number");
1317
+ logger.info(`[e2e] Run recorded: latency=${runs[0].latencyMs}ms`);
1318
+
1319
+ // 5. Verify the trigger summary was updated after execution
1320
+ const getRes = await http$(
1321
+ server?.port,
1322
+ "GET",
1323
+ `/api/triggers/${encodeURIComponent(triggerId)}`,
1324
+ );
1325
+ expect(getRes.status).toBe(200);
1326
+ const updatedTrigger = getRes.data.trigger as Record<string, unknown>;
1327
+ expect(updatedTrigger.runCount).toBe(1);
1328
+ expect(updatedTrigger.lastStatus).toBe("success");
1329
+ expect(typeof updatedTrigger.lastRunAtIso).toBe("string");
1330
+
1331
+ // 6. Verify health endpoint reflects the execution
1332
+ const healthRes = await http$(
1333
+ server?.port,
1334
+ "GET",
1335
+ "/api/triggers/health",
1336
+ );
1337
+ expect(healthRes.status).toBe(200);
1338
+ expect(
1339
+ Number(healthRes.data.activeTriggers ?? 0),
1340
+ ).toBeGreaterThanOrEqual(1);
1341
+ expect(
1342
+ Number(healthRes.data.totalExecutions ?? 0),
1343
+ ).toBeGreaterThanOrEqual(1);
1344
+ expect(Number(healthRes.data.totalFailures ?? 0)).toBe(0);
1345
+
1346
+ // 7. Disable and re-enable the trigger
1347
+ const disableRes = await http$(
1348
+ server?.port,
1349
+ "PUT",
1350
+ `/api/triggers/${encodeURIComponent(triggerId)}`,
1351
+ { enabled: false },
1352
+ );
1353
+ expect(disableRes.status).toBe(200);
1354
+ expect(
1355
+ (disableRes.data.trigger as Record<string, boolean>)?.enabled,
1356
+ ).toBe(false);
1357
+
1358
+ const enableRes = await http$(
1359
+ server?.port,
1360
+ "PUT",
1361
+ `/api/triggers/${encodeURIComponent(triggerId)}`,
1362
+ { enabled: true },
1363
+ );
1364
+ expect(enableRes.status).toBe(200);
1365
+ expect(
1366
+ (enableRes.data.trigger as Record<string, boolean>)?.enabled,
1367
+ ).toBe(true);
1368
+
1369
+ // 8. Delete the trigger
1370
+ const deleteRes = await http$(
1371
+ server?.port,
1372
+ "DELETE",
1373
+ `/api/triggers/${encodeURIComponent(triggerId)}`,
1374
+ );
1375
+ expect(deleteRes.status).toBe(200);
1376
+
1377
+ // Confirm it's gone
1378
+ const listAfterDelete = await http$(
1379
+ server?.port,
1380
+ "GET",
1381
+ "/api/triggers",
1382
+ );
1383
+ const remainingTriggers = listAfterDelete.data.triggers as Array<
1384
+ Record<string, unknown>
1385
+ >;
1386
+ const stillExists = remainingTriggers.find((t) => t.id === triggerId);
1387
+ expect(stillExists).toBeUndefined();
1388
+
1389
+ logger.info("[e2e] Trigger lifecycle test complete (real LLM)");
1390
+ },
1391
+ 240_000,
1392
+ );
1393
+ });
1394
+
1395
+ // ===================================================================
1396
+ // 10. Todos — real LLM action access and chat-created todo verification
1397
+ // ===================================================================
1398
+
1399
+ describe("todos (real LLM + actions)", () => {
1400
+ it.skipIf(!hasModelProvider)(
1401
+ "runtime exposes todo actions",
1402
+ async () => {
1403
+ const runtimeDebug = await http$(server?.port, "GET", "/api/runtime");
1404
+ expect(runtimeDebug.status).toBe(200);
1405
+ let actions = readSerializedArray(
1406
+ (runtimeDebug.data.order as Record<string, unknown>)?.actions,
1407
+ );
1408
+ if (actions.length === 0) {
1409
+ actions = readSerializedArray(
1410
+ (runtimeDebug.data.sections as Record<string, unknown>)?.actions,
1411
+ );
1412
+ }
1413
+ expect(actions.length).toBeGreaterThan(0);
1414
+ const actionNames = actions
1415
+ .map((action) => readSerializedProperty(action, "name"))
1416
+ .map((name) => (typeof name === "string" ? name : null))
1417
+ .filter((name): name is string => name !== null);
1418
+
1419
+ const actionAliases: string[][] = [
1420
+ ["CREATE_TODO", "CREATE_TASK"],
1421
+ ["COMPLETE_TODO", "COMPLETE_TASK"],
1422
+ ["UPDATE_TODO", "UPDATE_TASK"],
1423
+ ["CANCEL_TODO", "CANCEL_TASK"],
1424
+ ];
1425
+ for (const aliases of actionAliases) {
1426
+ expect(actionNames.some((name) => aliases.includes(name))).toBe(true);
1427
+ }
1428
+ },
1429
+ 120_000,
1430
+ );
1431
+
1432
+ it.skipIf(!hasModelProvider)(
1433
+ "chat can create a todo via action and workbench API reflects it",
1434
+ async () => {
1435
+ const todoName = `LLM Todo ${Date.now()}`;
1436
+ const prompt = [
1437
+ "Create a one-off todo task right now.",
1438
+ `Name: ${todoName}`,
1439
+ "Description: created by the live e2e chat test.",
1440
+ "Priority: 2",
1441
+ "Urgent: false",
1442
+ "Then confirm creation in one short sentence.",
1443
+ ].join(" ");
1444
+
1445
+ let chatRes: { status: number; data: Record<string, unknown> };
1446
+ try {
1447
+ chatRes = await postChatPromptWithRetries(server?.port, prompt, 5);
1448
+ } catch (err) {
1449
+ if (
1450
+ await shouldSkipDueModelProviderUnavailable(
1451
+ runtime,
1452
+ "chat can create a todo via action and workbench API reflects it",
1453
+ )
1454
+ ) {
1455
+ return;
1456
+ }
1457
+ throw err;
1458
+ }
1459
+ expect(chatRes.status).toBe(200);
1460
+ const responseText = String(chatRes.data.text ?? "");
1461
+ if (responseText.length === 0) {
1462
+ if (
1463
+ await shouldSkipDueModelProviderUnavailable(
1464
+ runtime,
1465
+ "chat can create a todo via action and workbench API reflects it",
1466
+ )
1467
+ ) {
1468
+ return;
1469
+ }
1470
+ }
1471
+ expect(responseText.length).toBeGreaterThan(0);
1472
+
1473
+ let found = false;
1474
+ for (let attempt = 1; attempt <= 6; attempt += 1) {
1475
+ const todosRes = await http$(
1476
+ server?.port,
1477
+ "GET",
1478
+ "/api/workbench/todos",
1479
+ );
1480
+ expect(todosRes.status).toBe(200);
1481
+ const todos = (todosRes.data.todos ?? []) as Array<
1482
+ Record<string, unknown>
1483
+ >;
1484
+ found = todos.some((todo) => todo.name === todoName);
1485
+ if (found) break;
1486
+ await sleep(1_000);
1487
+ }
1488
+
1489
+ if (!found) {
1490
+ if (
1491
+ await shouldSkipDueModelProviderUnavailable(
1492
+ runtime,
1493
+ "chat can create a todo via action and workbench API reflects it",
1494
+ )
1495
+ ) {
1496
+ return;
1497
+ }
1498
+ }
1499
+ expect(found).toBe(true);
1500
+ },
1501
+ 240_000,
1502
+ );
1503
+ });
1504
+
1505
+ // ===================================================================
1506
+ // 11. startEliza() — real subprocess test
1507
+ // ===================================================================
1508
+
1509
+ describe("startEliza subprocess", () => {
1510
+ it.skip(
1511
+ "startEliza() boots, prints chat prompt, and exits cleanly (interactive subprocess currently hangs under Vitest; headless startup is covered above)",
1512
+ () => {},
1513
+ );
1514
+ });
1515
+ });