agentic-qe 3.3.5 → 3.4.1

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 (424) hide show
  1. package/.claude/helpers/statusline-v3.cjs +47 -0
  2. package/.claude/skills/qcsd-ideation-swarm/SKILL.md +7 -4
  3. package/CHANGELOG.md +23 -0
  4. package/README.md +69 -0
  5. package/package.json +1 -1
  6. package/v3/CHANGELOG.md +91 -0
  7. package/v3/README.md +117 -0
  8. package/v3/assets/skills/qcsd-ideation-swarm/SKILL.md +7 -4
  9. package/v3/dist/adapters/a2a/agent-cards/generator.d.ts +153 -0
  10. package/v3/dist/adapters/a2a/agent-cards/generator.d.ts.map +1 -0
  11. package/v3/dist/adapters/a2a/agent-cards/generator.js +478 -0
  12. package/v3/dist/adapters/a2a/agent-cards/generator.js.map +1 -0
  13. package/v3/dist/adapters/a2a/agent-cards/schema.d.ts +274 -0
  14. package/v3/dist/adapters/a2a/agent-cards/schema.d.ts.map +1 -0
  15. package/v3/dist/adapters/a2a/agent-cards/schema.js +135 -0
  16. package/v3/dist/adapters/a2a/agent-cards/schema.js.map +1 -0
  17. package/v3/dist/adapters/a2a/agent-cards/validator.d.ts +514 -0
  18. package/v3/dist/adapters/a2a/agent-cards/validator.d.ts.map +1 -0
  19. package/v3/dist/adapters/a2a/agent-cards/validator.js +555 -0
  20. package/v3/dist/adapters/a2a/agent-cards/validator.js.map +1 -0
  21. package/v3/dist/adapters/a2a/auth/index.d.ts +23 -0
  22. package/v3/dist/adapters/a2a/auth/index.d.ts.map +1 -0
  23. package/v3/dist/adapters/a2a/auth/index.js +85 -0
  24. package/v3/dist/adapters/a2a/auth/index.js.map +1 -0
  25. package/v3/dist/adapters/a2a/auth/jwt-utils.d.ts +215 -0
  26. package/v3/dist/adapters/a2a/auth/jwt-utils.d.ts.map +1 -0
  27. package/v3/dist/adapters/a2a/auth/jwt-utils.js +314 -0
  28. package/v3/dist/adapters/a2a/auth/jwt-utils.js.map +1 -0
  29. package/v3/dist/adapters/a2a/auth/middleware.d.ts +173 -0
  30. package/v3/dist/adapters/a2a/auth/middleware.d.ts.map +1 -0
  31. package/v3/dist/adapters/a2a/auth/middleware.js +300 -0
  32. package/v3/dist/adapters/a2a/auth/middleware.js.map +1 -0
  33. package/v3/dist/adapters/a2a/auth/oauth-provider.d.ts +308 -0
  34. package/v3/dist/adapters/a2a/auth/oauth-provider.d.ts.map +1 -0
  35. package/v3/dist/adapters/a2a/auth/oauth-provider.js +573 -0
  36. package/v3/dist/adapters/a2a/auth/oauth-provider.js.map +1 -0
  37. package/v3/dist/adapters/a2a/auth/routes.d.ts +244 -0
  38. package/v3/dist/adapters/a2a/auth/routes.d.ts.map +1 -0
  39. package/v3/dist/adapters/a2a/auth/routes.js +496 -0
  40. package/v3/dist/adapters/a2a/auth/routes.js.map +1 -0
  41. package/v3/dist/adapters/a2a/auth/scopes.d.ts +219 -0
  42. package/v3/dist/adapters/a2a/auth/scopes.d.ts.map +1 -0
  43. package/v3/dist/adapters/a2a/auth/scopes.js +292 -0
  44. package/v3/dist/adapters/a2a/auth/scopes.js.map +1 -0
  45. package/v3/dist/adapters/a2a/auth/token-store.d.ts +278 -0
  46. package/v3/dist/adapters/a2a/auth/token-store.d.ts.map +1 -0
  47. package/v3/dist/adapters/a2a/auth/token-store.js +453 -0
  48. package/v3/dist/adapters/a2a/auth/token-store.js.map +1 -0
  49. package/v3/dist/adapters/a2a/discovery/agent-health.d.ts +226 -0
  50. package/v3/dist/adapters/a2a/discovery/agent-health.d.ts.map +1 -0
  51. package/v3/dist/adapters/a2a/discovery/agent-health.js +426 -0
  52. package/v3/dist/adapters/a2a/discovery/agent-health.js.map +1 -0
  53. package/v3/dist/adapters/a2a/discovery/discovery-service.d.ts +296 -0
  54. package/v3/dist/adapters/a2a/discovery/discovery-service.d.ts.map +1 -0
  55. package/v3/dist/adapters/a2a/discovery/discovery-service.js +520 -0
  56. package/v3/dist/adapters/a2a/discovery/discovery-service.js.map +1 -0
  57. package/v3/dist/adapters/a2a/discovery/file-watcher.d.ts +166 -0
  58. package/v3/dist/adapters/a2a/discovery/file-watcher.d.ts.map +1 -0
  59. package/v3/dist/adapters/a2a/discovery/file-watcher.js +385 -0
  60. package/v3/dist/adapters/a2a/discovery/file-watcher.js.map +1 -0
  61. package/v3/dist/adapters/a2a/discovery/hot-reload-service.d.ts +226 -0
  62. package/v3/dist/adapters/a2a/discovery/hot-reload-service.d.ts.map +1 -0
  63. package/v3/dist/adapters/a2a/discovery/hot-reload-service.js +433 -0
  64. package/v3/dist/adapters/a2a/discovery/hot-reload-service.js.map +1 -0
  65. package/v3/dist/adapters/a2a/discovery/index.d.ts +18 -0
  66. package/v3/dist/adapters/a2a/discovery/index.d.ts.map +1 -0
  67. package/v3/dist/adapters/a2a/discovery/index.js +54 -0
  68. package/v3/dist/adapters/a2a/discovery/index.js.map +1 -0
  69. package/v3/dist/adapters/a2a/discovery/metrics.d.ts +200 -0
  70. package/v3/dist/adapters/a2a/discovery/metrics.d.ts.map +1 -0
  71. package/v3/dist/adapters/a2a/discovery/metrics.js +371 -0
  72. package/v3/dist/adapters/a2a/discovery/metrics.js.map +1 -0
  73. package/v3/dist/adapters/a2a/discovery/routes.d.ts +184 -0
  74. package/v3/dist/adapters/a2a/discovery/routes.d.ts.map +1 -0
  75. package/v3/dist/adapters/a2a/discovery/routes.js +453 -0
  76. package/v3/dist/adapters/a2a/discovery/routes.js.map +1 -0
  77. package/v3/dist/adapters/a2a/index.d.ts +18 -0
  78. package/v3/dist/adapters/a2a/index.d.ts.map +1 -0
  79. package/v3/dist/adapters/a2a/index.js +139 -0
  80. package/v3/dist/adapters/a2a/index.js.map +1 -0
  81. package/v3/dist/adapters/a2a/jsonrpc/envelope.d.ts +312 -0
  82. package/v3/dist/adapters/a2a/jsonrpc/envelope.d.ts.map +1 -0
  83. package/v3/dist/adapters/a2a/jsonrpc/envelope.js +554 -0
  84. package/v3/dist/adapters/a2a/jsonrpc/envelope.js.map +1 -0
  85. package/v3/dist/adapters/a2a/jsonrpc/errors.d.ts +244 -0
  86. package/v3/dist/adapters/a2a/jsonrpc/errors.d.ts.map +1 -0
  87. package/v3/dist/adapters/a2a/jsonrpc/errors.js +365 -0
  88. package/v3/dist/adapters/a2a/jsonrpc/errors.js.map +1 -0
  89. package/v3/dist/adapters/a2a/jsonrpc/index.d.ts +14 -0
  90. package/v3/dist/adapters/a2a/jsonrpc/index.d.ts.map +1 -0
  91. package/v3/dist/adapters/a2a/jsonrpc/index.js +59 -0
  92. package/v3/dist/adapters/a2a/jsonrpc/index.js.map +1 -0
  93. package/v3/dist/adapters/a2a/jsonrpc/methods.d.ts +400 -0
  94. package/v3/dist/adapters/a2a/jsonrpc/methods.d.ts.map +1 -0
  95. package/v3/dist/adapters/a2a/jsonrpc/methods.js +249 -0
  96. package/v3/dist/adapters/a2a/jsonrpc/methods.js.map +1 -0
  97. package/v3/dist/adapters/a2a/notifications/index.d.ts +60 -0
  98. package/v3/dist/adapters/a2a/notifications/index.d.ts.map +1 -0
  99. package/v3/dist/adapters/a2a/notifications/index.js +99 -0
  100. package/v3/dist/adapters/a2a/notifications/index.js.map +1 -0
  101. package/v3/dist/adapters/a2a/notifications/retry-queue.d.ts +225 -0
  102. package/v3/dist/adapters/a2a/notifications/retry-queue.d.ts.map +1 -0
  103. package/v3/dist/adapters/a2a/notifications/retry-queue.js +449 -0
  104. package/v3/dist/adapters/a2a/notifications/retry-queue.js.map +1 -0
  105. package/v3/dist/adapters/a2a/notifications/signature.d.ts +133 -0
  106. package/v3/dist/adapters/a2a/notifications/signature.d.ts.map +1 -0
  107. package/v3/dist/adapters/a2a/notifications/signature.js +244 -0
  108. package/v3/dist/adapters/a2a/notifications/signature.js.map +1 -0
  109. package/v3/dist/adapters/a2a/notifications/subscription-store.d.ts +243 -0
  110. package/v3/dist/adapters/a2a/notifications/subscription-store.d.ts.map +1 -0
  111. package/v3/dist/adapters/a2a/notifications/subscription-store.js +486 -0
  112. package/v3/dist/adapters/a2a/notifications/subscription-store.js.map +1 -0
  113. package/v3/dist/adapters/a2a/notifications/webhook-service.d.ts +257 -0
  114. package/v3/dist/adapters/a2a/notifications/webhook-service.d.ts.map +1 -0
  115. package/v3/dist/adapters/a2a/notifications/webhook-service.js +542 -0
  116. package/v3/dist/adapters/a2a/notifications/webhook-service.js.map +1 -0
  117. package/v3/dist/adapters/a2a/tasks/index.d.ts +16 -0
  118. package/v3/dist/adapters/a2a/tasks/index.d.ts.map +1 -0
  119. package/v3/dist/adapters/a2a/tasks/index.js +33 -0
  120. package/v3/dist/adapters/a2a/tasks/index.js.map +1 -0
  121. package/v3/dist/adapters/a2a/tasks/task-manager.d.ts +306 -0
  122. package/v3/dist/adapters/a2a/tasks/task-manager.d.ts.map +1 -0
  123. package/v3/dist/adapters/a2a/tasks/task-manager.js +562 -0
  124. package/v3/dist/adapters/a2a/tasks/task-manager.js.map +1 -0
  125. package/v3/dist/adapters/a2a/tasks/task-router.d.ts +270 -0
  126. package/v3/dist/adapters/a2a/tasks/task-router.d.ts.map +1 -0
  127. package/v3/dist/adapters/a2a/tasks/task-router.js +574 -0
  128. package/v3/dist/adapters/a2a/tasks/task-router.js.map +1 -0
  129. package/v3/dist/adapters/a2a/tasks/task-store.d.ts +251 -0
  130. package/v3/dist/adapters/a2a/tasks/task-store.d.ts.map +1 -0
  131. package/v3/dist/adapters/a2a/tasks/task-store.js +468 -0
  132. package/v3/dist/adapters/a2a/tasks/task-store.js.map +1 -0
  133. package/v3/dist/adapters/a2ui/accessibility/aria-attributes.d.ts +294 -0
  134. package/v3/dist/adapters/a2ui/accessibility/aria-attributes.d.ts.map +1 -0
  135. package/v3/dist/adapters/a2ui/accessibility/aria-attributes.js +447 -0
  136. package/v3/dist/adapters/a2ui/accessibility/aria-attributes.js.map +1 -0
  137. package/v3/dist/adapters/a2ui/accessibility/index.d.ts +83 -0
  138. package/v3/dist/adapters/a2ui/accessibility/index.d.ts.map +1 -0
  139. package/v3/dist/adapters/a2ui/accessibility/index.js +155 -0
  140. package/v3/dist/adapters/a2ui/accessibility/index.js.map +1 -0
  141. package/v3/dist/adapters/a2ui/accessibility/keyboard-nav.d.ts +177 -0
  142. package/v3/dist/adapters/a2ui/accessibility/keyboard-nav.d.ts.map +1 -0
  143. package/v3/dist/adapters/a2ui/accessibility/keyboard-nav.js +638 -0
  144. package/v3/dist/adapters/a2ui/accessibility/keyboard-nav.js.map +1 -0
  145. package/v3/dist/adapters/a2ui/accessibility/wcag-validator.d.ts +186 -0
  146. package/v3/dist/adapters/a2ui/accessibility/wcag-validator.d.ts.map +1 -0
  147. package/v3/dist/adapters/a2ui/accessibility/wcag-validator.js +816 -0
  148. package/v3/dist/adapters/a2ui/accessibility/wcag-validator.js.map +1 -0
  149. package/v3/dist/adapters/a2ui/catalog/component-schemas.d.ts +227 -0
  150. package/v3/dist/adapters/a2ui/catalog/component-schemas.d.ts.map +1 -0
  151. package/v3/dist/adapters/a2ui/catalog/component-schemas.js +1090 -0
  152. package/v3/dist/adapters/a2ui/catalog/component-schemas.js.map +1 -0
  153. package/v3/dist/adapters/a2ui/catalog/index.d.ts +55 -0
  154. package/v3/dist/adapters/a2ui/catalog/index.d.ts.map +1 -0
  155. package/v3/dist/adapters/a2ui/catalog/index.js +100 -0
  156. package/v3/dist/adapters/a2ui/catalog/index.js.map +1 -0
  157. package/v3/dist/adapters/a2ui/catalog/qe-catalog.d.ts +456 -0
  158. package/v3/dist/adapters/a2ui/catalog/qe-catalog.d.ts.map +1 -0
  159. package/v3/dist/adapters/a2ui/catalog/qe-catalog.js +413 -0
  160. package/v3/dist/adapters/a2ui/catalog/qe-catalog.js.map +1 -0
  161. package/v3/dist/adapters/a2ui/catalog/standard-catalog.d.ts +581 -0
  162. package/v3/dist/adapters/a2ui/catalog/standard-catalog.d.ts.map +1 -0
  163. package/v3/dist/adapters/a2ui/catalog/standard-catalog.js +409 -0
  164. package/v3/dist/adapters/a2ui/catalog/standard-catalog.js.map +1 -0
  165. package/v3/dist/adapters/a2ui/data/bound-value.d.ts +252 -0
  166. package/v3/dist/adapters/a2ui/data/bound-value.d.ts.map +1 -0
  167. package/v3/dist/adapters/a2ui/data/bound-value.js +403 -0
  168. package/v3/dist/adapters/a2ui/data/bound-value.js.map +1 -0
  169. package/v3/dist/adapters/a2ui/data/index.d.ts +14 -0
  170. package/v3/dist/adapters/a2ui/data/index.d.ts.map +1 -0
  171. package/v3/dist/adapters/a2ui/data/index.js +41 -0
  172. package/v3/dist/adapters/a2ui/data/index.js.map +1 -0
  173. package/v3/dist/adapters/a2ui/data/json-pointer-resolver.d.ts +187 -0
  174. package/v3/dist/adapters/a2ui/data/json-pointer-resolver.d.ts.map +1 -0
  175. package/v3/dist/adapters/a2ui/data/json-pointer-resolver.js +425 -0
  176. package/v3/dist/adapters/a2ui/data/json-pointer-resolver.js.map +1 -0
  177. package/v3/dist/adapters/a2ui/data/reactive-store.d.ts +241 -0
  178. package/v3/dist/adapters/a2ui/data/reactive-store.d.ts.map +1 -0
  179. package/v3/dist/adapters/a2ui/data/reactive-store.js +461 -0
  180. package/v3/dist/adapters/a2ui/data/reactive-store.js.map +1 -0
  181. package/v3/dist/adapters/a2ui/index.d.ts +17 -0
  182. package/v3/dist/adapters/a2ui/index.d.ts.map +1 -0
  183. package/v3/dist/adapters/a2ui/index.js +119 -0
  184. package/v3/dist/adapters/a2ui/index.js.map +1 -0
  185. package/v3/dist/adapters/a2ui/integration/agui-sync.d.ts +259 -0
  186. package/v3/dist/adapters/a2ui/integration/agui-sync.d.ts.map +1 -0
  187. package/v3/dist/adapters/a2ui/integration/agui-sync.js +559 -0
  188. package/v3/dist/adapters/a2ui/integration/agui-sync.js.map +1 -0
  189. package/v3/dist/adapters/a2ui/integration/index.d.ts +11 -0
  190. package/v3/dist/adapters/a2ui/integration/index.d.ts.map +1 -0
  191. package/v3/dist/adapters/a2ui/integration/index.js +23 -0
  192. package/v3/dist/adapters/a2ui/integration/index.js.map +1 -0
  193. package/v3/dist/adapters/a2ui/integration/surface-state-bridge.d.ts +209 -0
  194. package/v3/dist/adapters/a2ui/integration/surface-state-bridge.d.ts.map +1 -0
  195. package/v3/dist/adapters/a2ui/integration/surface-state-bridge.js +545 -0
  196. package/v3/dist/adapters/a2ui/integration/surface-state-bridge.js.map +1 -0
  197. package/v3/dist/adapters/a2ui/renderer/component-builder.d.ts +227 -0
  198. package/v3/dist/adapters/a2ui/renderer/component-builder.d.ts.map +1 -0
  199. package/v3/dist/adapters/a2ui/renderer/component-builder.js +488 -0
  200. package/v3/dist/adapters/a2ui/renderer/component-builder.js.map +1 -0
  201. package/v3/dist/adapters/a2ui/renderer/index.d.ts +16 -0
  202. package/v3/dist/adapters/a2ui/renderer/index.d.ts.map +1 -0
  203. package/v3/dist/adapters/a2ui/renderer/index.js +50 -0
  204. package/v3/dist/adapters/a2ui/renderer/index.js.map +1 -0
  205. package/v3/dist/adapters/a2ui/renderer/message-types.d.ts +299 -0
  206. package/v3/dist/adapters/a2ui/renderer/message-types.d.ts.map +1 -0
  207. package/v3/dist/adapters/a2ui/renderer/message-types.js +187 -0
  208. package/v3/dist/adapters/a2ui/renderer/message-types.js.map +1 -0
  209. package/v3/dist/adapters/a2ui/renderer/surface-generator.d.ts +210 -0
  210. package/v3/dist/adapters/a2ui/renderer/surface-generator.d.ts.map +1 -0
  211. package/v3/dist/adapters/a2ui/renderer/surface-generator.js +586 -0
  212. package/v3/dist/adapters/a2ui/renderer/surface-generator.js.map +1 -0
  213. package/v3/dist/adapters/a2ui/renderer/templates/accessibility-surface.d.ts +149 -0
  214. package/v3/dist/adapters/a2ui/renderer/templates/accessibility-surface.d.ts.map +1 -0
  215. package/v3/dist/adapters/a2ui/renderer/templates/accessibility-surface.js +414 -0
  216. package/v3/dist/adapters/a2ui/renderer/templates/accessibility-surface.js.map +1 -0
  217. package/v3/dist/adapters/a2ui/renderer/templates/coverage-surface.d.ts +95 -0
  218. package/v3/dist/adapters/a2ui/renderer/templates/coverage-surface.d.ts.map +1 -0
  219. package/v3/dist/adapters/a2ui/renderer/templates/coverage-surface.js +231 -0
  220. package/v3/dist/adapters/a2ui/renderer/templates/coverage-surface.js.map +1 -0
  221. package/v3/dist/adapters/a2ui/renderer/templates/index.d.ts +12 -0
  222. package/v3/dist/adapters/a2ui/renderer/templates/index.d.ts.map +1 -0
  223. package/v3/dist/adapters/a2ui/renderer/templates/index.js +16 -0
  224. package/v3/dist/adapters/a2ui/renderer/templates/index.js.map +1 -0
  225. package/v3/dist/adapters/a2ui/renderer/templates/security-surface.d.ts +121 -0
  226. package/v3/dist/adapters/a2ui/renderer/templates/security-surface.d.ts.map +1 -0
  227. package/v3/dist/adapters/a2ui/renderer/templates/security-surface.js +367 -0
  228. package/v3/dist/adapters/a2ui/renderer/templates/security-surface.js.map +1 -0
  229. package/v3/dist/adapters/a2ui/renderer/templates/test-results-surface.d.ts +104 -0
  230. package/v3/dist/adapters/a2ui/renderer/templates/test-results-surface.d.ts.map +1 -0
  231. package/v3/dist/adapters/a2ui/renderer/templates/test-results-surface.js +294 -0
  232. package/v3/dist/adapters/a2ui/renderer/templates/test-results-surface.js.map +1 -0
  233. package/v3/dist/adapters/ag-ui/backpressure-handler.d.ts +201 -0
  234. package/v3/dist/adapters/ag-ui/backpressure-handler.d.ts.map +1 -0
  235. package/v3/dist/adapters/ag-ui/backpressure-handler.js +399 -0
  236. package/v3/dist/adapters/ag-ui/backpressure-handler.js.map +1 -0
  237. package/v3/dist/adapters/ag-ui/event-adapter.d.ts +360 -0
  238. package/v3/dist/adapters/ag-ui/event-adapter.d.ts.map +1 -0
  239. package/v3/dist/adapters/ag-ui/event-adapter.js +1083 -0
  240. package/v3/dist/adapters/ag-ui/event-adapter.js.map +1 -0
  241. package/v3/dist/adapters/ag-ui/event-batcher.d.ts +242 -0
  242. package/v3/dist/adapters/ag-ui/event-batcher.d.ts.map +1 -0
  243. package/v3/dist/adapters/ag-ui/event-batcher.js +444 -0
  244. package/v3/dist/adapters/ag-ui/event-batcher.js.map +1 -0
  245. package/v3/dist/adapters/ag-ui/event-types.d.ts +450 -0
  246. package/v3/dist/adapters/ag-ui/event-types.d.ts.map +1 -0
  247. package/v3/dist/adapters/ag-ui/event-types.js +173 -0
  248. package/v3/dist/adapters/ag-ui/event-types.js.map +1 -0
  249. package/v3/dist/adapters/ag-ui/index.d.ts +17 -0
  250. package/v3/dist/adapters/ag-ui/index.d.ts.map +1 -0
  251. package/v3/dist/adapters/ag-ui/index.js +47 -0
  252. package/v3/dist/adapters/ag-ui/index.js.map +1 -0
  253. package/v3/dist/adapters/ag-ui/json-patch-utils.d.ts +136 -0
  254. package/v3/dist/adapters/ag-ui/json-patch-utils.d.ts.map +1 -0
  255. package/v3/dist/adapters/ag-ui/json-patch-utils.js +574 -0
  256. package/v3/dist/adapters/ag-ui/json-patch-utils.js.map +1 -0
  257. package/v3/dist/adapters/ag-ui/json-patch.d.ts +241 -0
  258. package/v3/dist/adapters/ag-ui/json-patch.d.ts.map +1 -0
  259. package/v3/dist/adapters/ag-ui/json-patch.js +726 -0
  260. package/v3/dist/adapters/ag-ui/json-patch.js.map +1 -0
  261. package/v3/dist/adapters/ag-ui/state-delta-cache.d.ts +218 -0
  262. package/v3/dist/adapters/ag-ui/state-delta-cache.d.ts.map +1 -0
  263. package/v3/dist/adapters/ag-ui/state-delta-cache.js +422 -0
  264. package/v3/dist/adapters/ag-ui/state-delta-cache.js.map +1 -0
  265. package/v3/dist/adapters/ag-ui/state-manager.d.ts +249 -0
  266. package/v3/dist/adapters/ag-ui/state-manager.d.ts.map +1 -0
  267. package/v3/dist/adapters/ag-ui/state-manager.js +511 -0
  268. package/v3/dist/adapters/ag-ui/state-manager.js.map +1 -0
  269. package/v3/dist/adapters/ag-ui/stream-controller.d.ts +195 -0
  270. package/v3/dist/adapters/ag-ui/stream-controller.d.ts.map +1 -0
  271. package/v3/dist/adapters/ag-ui/stream-controller.js +481 -0
  272. package/v3/dist/adapters/ag-ui/stream-controller.js.map +1 -0
  273. package/v3/dist/adapters/index.d.ts +4 -0
  274. package/v3/dist/adapters/index.d.ts.map +1 -1
  275. package/v3/dist/adapters/index.js +89 -0
  276. package/v3/dist/adapters/index.js.map +1 -1
  277. package/v3/dist/cli/bundle.js +7412 -3749
  278. package/v3/dist/init/init-wizard.d.ts.map +1 -1
  279. package/v3/dist/init/init-wizard.js +16 -1
  280. package/v3/dist/init/init-wizard.js.map +1 -1
  281. package/v3/dist/init/migration/config-migrator.d.ts.map +1 -1
  282. package/v3/dist/init/migration/config-migrator.js +15 -1
  283. package/v3/dist/init/migration/config-migrator.js.map +1 -1
  284. package/v3/dist/init/self-configurator.d.ts +7 -0
  285. package/v3/dist/init/self-configurator.d.ts.map +1 -1
  286. package/v3/dist/init/self-configurator.js +23 -27
  287. package/v3/dist/init/self-configurator.js.map +1 -1
  288. package/v3/dist/kernel/plugin-loader.d.ts.map +1 -1
  289. package/v3/dist/kernel/plugin-loader.js +6 -1
  290. package/v3/dist/kernel/plugin-loader.js.map +1 -1
  291. package/v3/dist/kernel/unified-memory.d.ts +97 -0
  292. package/v3/dist/kernel/unified-memory.d.ts.map +1 -1
  293. package/v3/dist/kernel/unified-memory.js +204 -0
  294. package/v3/dist/kernel/unified-memory.js.map +1 -1
  295. package/v3/dist/mcp/bundle.js +121759 -105597
  296. package/v3/dist/mcp/entry.d.ts +5 -0
  297. package/v3/dist/mcp/entry.d.ts.map +1 -1
  298. package/v3/dist/mcp/entry.js +36 -0
  299. package/v3/dist/mcp/entry.js.map +1 -1
  300. package/v3/dist/mcp/http-server.d.ts +95 -0
  301. package/v3/dist/mcp/http-server.d.ts.map +1 -0
  302. package/v3/dist/mcp/http-server.js +833 -0
  303. package/v3/dist/mcp/http-server.js.map +1 -0
  304. package/v3/dist/mcp/protocol-server.d.ts +6 -0
  305. package/v3/dist/mcp/protocol-server.d.ts.map +1 -1
  306. package/v3/dist/mcp/protocol-server.js +40 -0
  307. package/v3/dist/mcp/protocol-server.js.map +1 -1
  308. package/v3/dist/mcp/transport/index.d.ts +25 -3
  309. package/v3/dist/mcp/transport/index.d.ts.map +1 -1
  310. package/v3/dist/mcp/transport/index.js +22 -4
  311. package/v3/dist/mcp/transport/index.js.map +1 -1
  312. package/v3/dist/mcp/transport/sse/connection-manager.d.ts +84 -0
  313. package/v3/dist/mcp/transport/sse/connection-manager.d.ts.map +1 -0
  314. package/v3/dist/mcp/transport/sse/connection-manager.js +271 -0
  315. package/v3/dist/mcp/transport/sse/connection-manager.js.map +1 -0
  316. package/v3/dist/mcp/transport/sse/index.d.ts +10 -0
  317. package/v3/dist/mcp/transport/sse/index.d.ts.map +1 -0
  318. package/v3/dist/mcp/transport/sse/index.js +15 -0
  319. package/v3/dist/mcp/transport/sse/index.js.map +1 -0
  320. package/v3/dist/mcp/transport/sse/sse-transport.d.ts +56 -0
  321. package/v3/dist/mcp/transport/sse/sse-transport.d.ts.map +1 -0
  322. package/v3/dist/mcp/transport/sse/sse-transport.js +381 -0
  323. package/v3/dist/mcp/transport/sse/sse-transport.js.map +1 -0
  324. package/v3/dist/mcp/transport/sse/types.d.ts +237 -0
  325. package/v3/dist/mcp/transport/sse/types.d.ts.map +1 -0
  326. package/v3/dist/mcp/transport/sse/types.js +37 -0
  327. package/v3/dist/mcp/transport/sse/types.js.map +1 -0
  328. package/v3/dist/mcp/transport/websocket/connection-manager.d.ts +143 -0
  329. package/v3/dist/mcp/transport/websocket/connection-manager.d.ts.map +1 -0
  330. package/v3/dist/mcp/transport/websocket/connection-manager.js +522 -0
  331. package/v3/dist/mcp/transport/websocket/connection-manager.js.map +1 -0
  332. package/v3/dist/mcp/transport/websocket/index.d.ts +10 -0
  333. package/v3/dist/mcp/transport/websocket/index.d.ts.map +1 -0
  334. package/v3/dist/mcp/transport/websocket/index.js +19 -0
  335. package/v3/dist/mcp/transport/websocket/index.js.map +1 -0
  336. package/v3/dist/mcp/transport/websocket/types.d.ts +354 -0
  337. package/v3/dist/mcp/transport/websocket/types.d.ts.map +1 -0
  338. package/v3/dist/mcp/transport/websocket/types.js +49 -0
  339. package/v3/dist/mcp/transport/websocket/types.js.map +1 -0
  340. package/v3/dist/mcp/transport/websocket/websocket-transport.d.ts +77 -0
  341. package/v3/dist/mcp/transport/websocket/websocket-transport.d.ts.map +1 -0
  342. package/v3/dist/mcp/transport/websocket/websocket-transport.js +622 -0
  343. package/v3/dist/mcp/transport/websocket/websocket-transport.js.map +1 -0
  344. package/v3/dist/memory/crdt/convergence-tracker.d.ts +59 -0
  345. package/v3/dist/memory/crdt/convergence-tracker.d.ts.map +1 -0
  346. package/v3/dist/memory/crdt/convergence-tracker.js +325 -0
  347. package/v3/dist/memory/crdt/convergence-tracker.js.map +1 -0
  348. package/v3/dist/memory/crdt/crdt-store.d.ts +55 -0
  349. package/v3/dist/memory/crdt/crdt-store.d.ts.map +1 -0
  350. package/v3/dist/memory/crdt/crdt-store.js +582 -0
  351. package/v3/dist/memory/crdt/crdt-store.js.map +1 -0
  352. package/v3/dist/memory/crdt/g-counter.d.ts +47 -0
  353. package/v3/dist/memory/crdt/g-counter.d.ts.map +1 -0
  354. package/v3/dist/memory/crdt/g-counter.js +134 -0
  355. package/v3/dist/memory/crdt/g-counter.js.map +1 -0
  356. package/v3/dist/memory/crdt/index.d.ts +52 -0
  357. package/v3/dist/memory/crdt/index.d.ts.map +1 -0
  358. package/v3/dist/memory/crdt/index.js +66 -0
  359. package/v3/dist/memory/crdt/index.js.map +1 -0
  360. package/v3/dist/memory/crdt/lww-register.d.ts +40 -0
  361. package/v3/dist/memory/crdt/lww-register.d.ts.map +1 -0
  362. package/v3/dist/memory/crdt/lww-register.js +133 -0
  363. package/v3/dist/memory/crdt/lww-register.js.map +1 -0
  364. package/v3/dist/memory/crdt/or-set.d.ts +62 -0
  365. package/v3/dist/memory/crdt/or-set.d.ts.map +1 -0
  366. package/v3/dist/memory/crdt/or-set.js +336 -0
  367. package/v3/dist/memory/crdt/or-set.js.map +1 -0
  368. package/v3/dist/memory/crdt/pn-counter.d.ts +53 -0
  369. package/v3/dist/memory/crdt/pn-counter.d.ts.map +1 -0
  370. package/v3/dist/memory/crdt/pn-counter.js +147 -0
  371. package/v3/dist/memory/crdt/pn-counter.js.map +1 -0
  372. package/v3/dist/memory/crdt/types.d.ts +397 -0
  373. package/v3/dist/memory/crdt/types.d.ts.map +1 -0
  374. package/v3/dist/memory/crdt/types.js +12 -0
  375. package/v3/dist/memory/crdt/types.js.map +1 -0
  376. package/v3/dist/memory/index.d.ts +5 -2
  377. package/v3/dist/memory/index.d.ts.map +1 -1
  378. package/v3/dist/memory/index.js +5 -2
  379. package/v3/dist/memory/index.js.map +1 -1
  380. package/v3/dist/performance/benchmarks.d.ts +215 -0
  381. package/v3/dist/performance/benchmarks.d.ts.map +1 -0
  382. package/v3/dist/performance/benchmarks.js +516 -0
  383. package/v3/dist/performance/benchmarks.js.map +1 -0
  384. package/v3/dist/performance/ci-gates.d.ts +149 -0
  385. package/v3/dist/performance/ci-gates.d.ts.map +1 -0
  386. package/v3/dist/performance/ci-gates.js +425 -0
  387. package/v3/dist/performance/ci-gates.js.map +1 -0
  388. package/v3/dist/performance/index.d.ts +18 -0
  389. package/v3/dist/performance/index.d.ts.map +1 -0
  390. package/v3/dist/performance/index.js +26 -0
  391. package/v3/dist/performance/index.js.map +1 -0
  392. package/v3/dist/performance/optimizer.d.ts +323 -0
  393. package/v3/dist/performance/optimizer.d.ts.map +1 -0
  394. package/v3/dist/performance/optimizer.js +592 -0
  395. package/v3/dist/performance/optimizer.js.map +1 -0
  396. package/v3/dist/performance/profiler.d.ts +195 -0
  397. package/v3/dist/performance/profiler.d.ts.map +1 -0
  398. package/v3/dist/performance/profiler.js +369 -0
  399. package/v3/dist/performance/profiler.js.map +1 -0
  400. package/v3/dist/performance/run-gates.d.ts +23 -0
  401. package/v3/dist/performance/run-gates.d.ts.map +1 -0
  402. package/v3/dist/performance/run-gates.js +122 -0
  403. package/v3/dist/performance/run-gates.js.map +1 -0
  404. package/v3/dist/testing/index.d.ts +6 -0
  405. package/v3/dist/testing/index.d.ts.map +1 -0
  406. package/v3/dist/testing/index.js +7 -0
  407. package/v3/dist/testing/index.js.map +1 -0
  408. package/v3/dist/testing/load/agent-load-tester.d.ts +221 -0
  409. package/v3/dist/testing/load/agent-load-tester.d.ts.map +1 -0
  410. package/v3/dist/testing/load/agent-load-tester.js +566 -0
  411. package/v3/dist/testing/load/agent-load-tester.js.map +1 -0
  412. package/v3/dist/testing/load/bottleneck-analyzer.d.ts +150 -0
  413. package/v3/dist/testing/load/bottleneck-analyzer.d.ts.map +1 -0
  414. package/v3/dist/testing/load/bottleneck-analyzer.js +442 -0
  415. package/v3/dist/testing/load/bottleneck-analyzer.js.map +1 -0
  416. package/v3/dist/testing/load/index.d.ts +17 -0
  417. package/v3/dist/testing/load/index.d.ts.map +1 -0
  418. package/v3/dist/testing/load/index.js +23 -0
  419. package/v3/dist/testing/load/index.js.map +1 -0
  420. package/v3/dist/testing/load/metrics-collector.d.ts +275 -0
  421. package/v3/dist/testing/load/metrics-collector.d.ts.map +1 -0
  422. package/v3/dist/testing/load/metrics-collector.js +475 -0
  423. package/v3/dist/testing/load/metrics-collector.js.map +1 -0
  424. package/v3/package.json +5 -1
@@ -18,6 +18,14 @@ const fs = require('fs');
18
18
  const path = require('path');
19
19
  const { execSync, spawnSync } = require('child_process');
20
20
 
21
+ // Use better-sqlite3 for reliable database access (no CLI dependency)
22
+ let Database;
23
+ try {
24
+ Database = require('better-sqlite3');
25
+ } catch {
26
+ Database = null; // Fallback to CLI if better-sqlite3 not available
27
+ }
28
+
21
29
  // ═══════════════════════════════════════════════════════════════
22
30
  // Configuration
23
31
  // ═══════════════════════════════════════════════════════════════
@@ -117,8 +125,47 @@ function readJsonFile(filePath, defaultValue = {}) {
117
125
  return defaultValue;
118
126
  }
119
127
 
128
+ // Database connection cache for performance
129
+ let dbCache = new Map();
130
+
131
+ function getDb(dbPath) {
132
+ if (!dbCache.has(dbPath)) {
133
+ if (Database && fileExists(dbPath)) {
134
+ try {
135
+ const db = new Database(dbPath, { readonly: true, fileMustExist: true });
136
+ dbCache.set(dbPath, db);
137
+ } catch {
138
+ dbCache.set(dbPath, null);
139
+ }
140
+ } else {
141
+ dbCache.set(dbPath, null);
142
+ }
143
+ }
144
+ return dbCache.get(dbPath);
145
+ }
146
+
120
147
  function sqlite3Query(dbPath, query, defaultValue = '0') {
121
148
  if (!fileExists(dbPath)) return defaultValue;
149
+
150
+ // Prefer better-sqlite3 (Node.js native, no CLI dependency)
151
+ if (Database) {
152
+ try {
153
+ const db = getDb(dbPath);
154
+ if (db) {
155
+ const row = db.prepare(query).get();
156
+ if (row) {
157
+ // Return the first column value
158
+ const values = Object.values(row);
159
+ return values.length > 0 ? String(values[0]) : defaultValue;
160
+ }
161
+ }
162
+ return defaultValue;
163
+ } catch {
164
+ return defaultValue;
165
+ }
166
+ }
167
+
168
+ // Fallback to CLI if better-sqlite3 not available
122
169
  try {
123
170
  const result = execSync(`sqlite3 "${dbPath}" "${query}" 2>/dev/null`, {
124
171
  encoding: 'utf-8',
@@ -55,7 +55,7 @@ When analyzing a live website URL, use this specialized execution pattern.
55
55
  ### Parameters
56
56
 
57
57
  - `URL`: Website to analyze (required)
58
- - `OUTPUT_FOLDER`: Where to save reports (default: `/workspaces/agentic-qe/Agentic QCSD/{domain}/`)
58
+ - `OUTPUT_FOLDER`: Where to save reports (default: `${PROJECT_ROOT}/Agentic QCSD/{domain}/` or `./Agentic QCSD/{domain}/`)
59
59
 
60
60
  ---
61
61
 
@@ -71,7 +71,10 @@ When analyzing a live website URL, use this specialized execution pattern.
71
71
 
72
72
  ```bash
73
73
  # SINGLE COMMAND - handles all tiers automatically:
74
- node /workspaces/agentic-qe/scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000
74
+ # Use npx for installed package, or node with relative path for local development
75
+ npx aqe fetch-content "${URL}" "${OUTPUT_FOLDER}" --timeout 30000
76
+ # OR if running from project root:
77
+ node ./scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000
75
78
  ```
76
79
 
77
80
  **What the script does automatically:**
@@ -84,9 +87,9 @@ node /workspaces/agentic-qe/scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}"
84
87
  **Execution:**
85
88
 
86
89
  ```javascript
87
- // 1. Run the automated fetch cascade
90
+ // 1. Run the automated fetch cascade (use relative path from project root)
88
91
  const fetchResult = Bash({
89
- command: `node /workspaces/agentic-qe/scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000`,
92
+ command: `node ./scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000`,
90
93
  timeout: 120000 // 2 min total max
91
94
  })
92
95
 
package/CHANGELOG.md CHANGED
@@ -5,6 +5,29 @@ All notable changes to the Agentic QE project will be documented in this file.
5
5
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
+ ## [3.4.1] - 2026-02-01
9
+
10
+ ### Fixed
11
+
12
+ - **MCP bundle missing dependencies** - Fixed issue #219 where `aqe-mcp` failed to start due to missing packages (`fast-json-patch`, `jose`, `uuid`, etc.)
13
+ - Changed build scripts from `--packages=external` to selective externalization
14
+ - Pure JS dependencies now bundled inline (no separate install needed)
15
+ - Native modules properly externalized (`better-sqlite3`, `hnswlib-node`, `@ruvector/*`)
16
+ - CommonJS modules with dynamic requires externalized (`typescript`, `fast-glob`, `yaml`, `commander`, `cli-progress`, `ora`)
17
+ - Bundle size reduced from ~15MB to ~5MB
18
+
19
+ ### Changed
20
+
21
+ - **Build script improvements** - `v3/scripts/build-mcp.js` and `v3/scripts/build-cli.js` now use explicit `--external:` flags instead of `--packages=external`
22
+
23
+ ## [3.4.0] - 2026-01-31
24
+
25
+ ### Added
26
+
27
+ - **All 12 QE domains enabled by default** - No longer requires manual domain activation
28
+ - **Enhanced MCP server** - 31 tools registered for comprehensive QE automation
29
+ - **Improved agent coordination** - Better swarm topology and task orchestration
30
+
8
31
  ## [3.1.5] - 2026-01-22
9
32
 
10
33
  ### Added
package/README.md CHANGED
@@ -13,6 +13,12 @@
13
13
 
14
14
  > **V3** brings Domain-Driven Design architecture, 12 bounded contexts, 51 specialized QE agents, TinyDancer intelligent model routing, ReasoningBank learning with Dream cycles, HNSW vector search, mathematical Coherence verification, full MinCut/Consensus integration across all 12 domains, and deep integration with [Claude Flow](https://github.com/ruvnet/claude-flow) and [Agentic Flow](https://github.com/ruvnet/agentic-flow).
15
15
 
16
+ ### What's New in v3.4.0
17
+
18
+ - **AG-UI Protocol** - Anthropic's streaming agent-to-user interface with real-time progress updates
19
+ - **A2A Protocol** - Google's agent-to-agent interoperability standard for cross-tool communication
20
+ - **A2UI Components** - Unified UI combining AG-UI streaming with A2A event handling
21
+
16
22
  🏗️ **DDD Architecture** | 🧠 **ReasoningBank + Dream Cycles** | 🎯 **TinyDancer Model Routing** | 🔍 **HNSW Vector Search** | 👑 **Queen Coordinator** | 📊 **O(log n) Coverage** | 🔗 **Claude Flow Integration** | 🎯 **12 Bounded Contexts** | 📚 **63 QE Skills** | 🧬 **Coherence Verification**
17
23
 
18
24
  </div>
@@ -74,6 +80,30 @@ claude "Use qe-flaky-hunter to analyze the last 100 test runs and stabilize flak
74
80
 
75
81
  ---
76
82
 
83
+ ## 🚀 Get Value in 60 Seconds
84
+
85
+ ```bash
86
+ # 1. Install
87
+ npm install -g agentic-qe
88
+
89
+ # 2. Initialize (auto-detects your project, enables all 12 domains)
90
+ cd your-project && aqe init --auto
91
+
92
+ # 3. Generate tests immediately
93
+ claude "Generate comprehensive tests for src/services/"
94
+
95
+ # 4. Run quality assessment
96
+ claude "Assess code quality and provide deployment recommendation"
97
+ ```
98
+
99
+ **What happens:**
100
+ 1. **Auto-configuration** detects your tech stack (TypeScript/JS, testing framework, CI setup)
101
+ 2. **All 12 DDD domains** enabled automatically - no "No factory registered" errors
102
+ 3. **Pattern learning** kicks in - your project's test patterns are learned and reused
103
+ 4. **AI agents** generate tests, analyze coverage, and provide actionable recommendations
104
+
105
+ ---
106
+
77
107
  ## 🎯 Why AQE?
78
108
 
79
109
  | Problem | AQE Solution |
@@ -250,6 +280,45 @@ V3.3.5 unifies cross-phase feedback loops with UnifiedMemoryManager:
250
280
  - **No File-Based Storage**: Eliminated JSON file storage for cross-phase memory
251
281
  - **Full Hook Integration**: Pre/post hooks for cross-phase signal injection
252
282
 
283
+ ### 🌐 AG-UI, A2A & A2UI Protocols (v3.4.0)
284
+
285
+ V3.4.0 adds support for **industry-standard agent communication protocols**:
286
+
287
+ | Protocol | Standard | Purpose |
288
+ |----------|----------|---------|
289
+ | **AG-UI** | Anthropic | Agent-to-User streaming interface with lifecycle events |
290
+ | **A2A** | Google | Agent-to-Agent interoperability with task/artifact exchange |
291
+ | **A2UI** | Hybrid | Unified UI components combining streaming + events |
292
+
293
+ **Programmatic usage:**
294
+
295
+ ```typescript
296
+ import { AGUIAdapter, A2AAdapter } from 'agentic-qe';
297
+
298
+ // AG-UI: Stream test generation progress to UI
299
+ const agui = new AGUIAdapter();
300
+ await agui.streamTask({
301
+ type: 'test-generation',
302
+ onProgress: (event) => updateProgressBar(event.progress),
303
+ onArtifact: (test) => displayGeneratedTest(test),
304
+ });
305
+
306
+ // A2A: Inter-agent task delegation
307
+ const a2a = new A2AAdapter();
308
+ await a2a.sendTask({
309
+ from: 'qe-test-architect',
310
+ to: 'qe-security-scanner',
311
+ task: { type: 'review-tests', files: generatedTests },
312
+ });
313
+ ```
314
+
315
+ **Benefits:**
316
+ - **Streaming feedback** - Real-time progress instead of waiting for completion
317
+ - **Agent interoperability** - Standard protocols for multi-agent coordination
318
+ - **Framework integration** - Works with React, Vue, or any UI framework
319
+
320
+ ---
321
+
253
322
  ### 🔐 Consensus & MinCut Coordination (v3.3.3)
254
323
 
255
324
  V3.3.3 achieves **full MinCut/Consensus integration across all 12 domains**:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "agentic-qe",
3
- "version": "3.3.5",
3
+ "version": "3.4.1",
4
4
  "description": "Agentic Quality Engineering V3 - Domain-Driven Design Architecture with 12 Bounded Contexts, O(log n) coverage analysis, ReasoningBank learning, 51 specialized QE agents, mathematical Coherence verification, deep Claude Flow integration",
5
5
  "main": "./v3/dist/index.js",
6
6
  "types": "./v3/dist/index.d.ts",
package/v3/CHANGELOG.md CHANGED
@@ -5,6 +5,97 @@ All notable changes to Agentic QE will be documented in this file.
5
5
  The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
+ ## [3.4.0] - 2026-02-01
9
+
10
+ ### 🎯 Highlights
11
+
12
+ **AG-UI, A2A, and A2UI Protocol Implementation** - Full implementation of Agent-to-UI (AG-UI), Agent-to-Agent (A2A), and Agent-to-UI (A2UI) protocols enabling interoperability with other agentic frameworks and real-time UI state synchronization.
13
+
14
+ **All 12 DDD Domains Now Enabled by Default** - Critical fix ensuring all QE domains are available out of the box. Previously, V2→V3 migration only enabled 3 domains, causing "No factory registered" errors when using `fleet_init` with domains like `test-execution` or `quality-assessment`.
15
+
16
+ **Portable Configuration** - Removed all hardcoded workspace paths throughout the codebase. AQE now works seamlessly across different environments (DevPod, Codespaces, local machines) without path-related failures.
17
+
18
+ ### Added
19
+
20
+ #### AG-UI Protocol (Agent-to-UI)
21
+ - **EventAdapter** - Transforms internal events to AG-UI format
22
+ - **StateManager** - JSON Patch-based state synchronization
23
+ - **SurfaceGenerator** - Dynamic UI surface generation from agent state
24
+ - **StreamingRenderer** - Real-time UI updates via SSE/WebSocket
25
+
26
+ #### A2A Protocol (Agent-to-Agent)
27
+ - **DiscoveryService** - Agent capability discovery and registration
28
+ - **MessageRouter** - Inter-agent message routing with delivery guarantees
29
+ - **CapabilityNegotiator** - Protocol version and capability negotiation
30
+ - **TaskDelegator** - Cross-agent task delegation and result aggregation
31
+
32
+ #### A2UI Protocol (Agent-to-UI Integration)
33
+ - **IntegrationBridge** - Bridges A2A and AG-UI for seamless UI updates
34
+ - **StateSync** - Bidirectional state synchronization between agents and UI
35
+ - **EventTransformer** - Event normalization across protocol boundaries
36
+
37
+ #### Configuration Improvements
38
+ - **Root config.yaml** - New `.agentic-qe/config.yaml` with all 12 domains enabled
39
+ - **Relative path support** - MCP server configs use `./v3/dist/...` instead of absolute paths
40
+ - **Environment-agnostic skills** - SKILL.md files use `npx` and relative paths
41
+
42
+ ### Changed
43
+
44
+ #### Domain Registration (Breaking Fix)
45
+ - **V2→V3 Migration** - Now enables all 12 DDD domains instead of just 3
46
+ - Previously: `test-generation`, `coverage-analysis`, `learning-optimization`
47
+ - Now: All 12 domains including `test-execution`, `quality-assessment`, `security-compliance`, etc.
48
+ - **Default kernel config** - Uses `ALL_DOMAINS` constant ensuring consistency
49
+
50
+ #### Error Messages
51
+ - **Plugin loader** - Shows registered domains and actionable fix when domain not found:
52
+ ```
53
+ No factory registered for domain: test-execution
54
+ Registered domains: test-generation, coverage-analysis, ...
55
+ Fix: Add 'test-execution' to domains.enabled in .agentic-qe/config.yaml
56
+ ```
57
+
58
+ #### Path Handling
59
+ - **verify.sh** - Uses `$SCRIPT_DIR` instead of hardcoded paths
60
+ - **Test files** - Use `process.cwd()` for project root detection
61
+ - **MCP config** - Removed `AQE_PROJECT_ROOT` hardcoded environment variable
62
+
63
+ ### Fixed
64
+
65
+ - **fleet_init failures** - "No factory registered for domain: test-execution" error resolved
66
+ - **Cross-environment compatibility** - Works in DevPod, Codespaces, and local environments
67
+ - **Integration test batching** - Disabled batching in protocol integration tests for deterministic behavior
68
+ - **State update ordering** - Fixed task state creation before error assignment in full-flow tests
69
+
70
+ ### Migration Guide
71
+
72
+ If you're upgrading from v3.3.x and experiencing domain registration errors:
73
+
74
+ 1. **Quick fix** - Re-run initialization:
75
+ ```bash
76
+ aqe init --auto-migrate
77
+ ```
78
+
79
+ 2. **Manual fix** - Add missing domains to `.agentic-qe/config.yaml`:
80
+ ```yaml
81
+ domains:
82
+ enabled:
83
+ - "test-generation"
84
+ - "test-execution" # ADD
85
+ - "coverage-analysis"
86
+ - "quality-assessment" # ADD
87
+ - "defect-intelligence" # ADD
88
+ - "requirements-validation"
89
+ - "code-intelligence"
90
+ - "security-compliance"
91
+ - "contract-testing"
92
+ - "visual-accessibility"
93
+ - "chaos-resilience"
94
+ - "learning-optimization"
95
+ ```
96
+
97
+ ---
98
+
8
99
  ## [3.3.5] - 2026-01-30
9
100
 
10
101
  ### 🎯 Highlights
package/v3/README.md CHANGED
@@ -7,6 +7,14 @@
7
7
 
8
8
  > Domain-Driven Quality Engineering with Mathematical Coherence Verification, 12 Bounded Contexts, 51 Specialized QE Agents, 63 QE Skills, and ReasoningBank Learning
9
9
 
10
+ ### What's New in v3.4.0
11
+
12
+ | Feature | Description |
13
+ |---------|-------------|
14
+ | **AG-UI Protocol** | Anthropic's streaming interface - real-time agent progress to UI |
15
+ | **A2A Protocol** | Google's agent-to-agent standard - cross-tool interoperability |
16
+ | **A2UI Components** | Hybrid UI components combining streaming + events |
17
+
10
18
  ## Quick Start
11
19
 
12
20
  ```bash
@@ -51,9 +59,53 @@ npx aqe test generate src/
51
59
  - **Cross-Phase Memory Unification** (v3.3.5) - Unified SQLite storage for QCSD feedback loops
52
60
  - **Zero-Breaking-Changes Migration** - Full v2 backward compatibility
53
61
  - **Browser Automation** (v3.1.0) - @claude-flow/browser integration with 9 workflow templates
62
+ - **AG-UI/A2A/A2UI Protocols** (v3.4.0) - Industry-standard agent communication
63
+
64
+ ## Get Value Fast
65
+
66
+ ```bash
67
+ # Install and auto-configure (all 12 domains enabled)
68
+ npm install -g agentic-qe
69
+ cd your-project && aqe init --auto
70
+
71
+ # Generate tests with AI
72
+ claude "Generate unit tests for src/services/user.ts with 90% coverage"
73
+
74
+ # Run full quality pipeline
75
+ claude "Run quality assessment: tests, coverage, security, and deployment recommendation"
76
+
77
+ # Check fleet status
78
+ aqe status --verbose
79
+ ```
54
80
 
55
81
  ## New in v3: Key Features
56
82
 
83
+ ### AG-UI, A2A & A2UI Protocols (v3.4.0)
84
+
85
+ Industry-standard agent communication protocols:
86
+
87
+ | Protocol | Standard | Description |
88
+ |----------|----------|-------------|
89
+ | **AG-UI** | Anthropic | Streaming agent output with lifecycle events |
90
+ | **A2A** | Google | Agent-to-agent task and artifact exchange |
91
+ | **A2UI** | Hybrid | Rich UI components with streaming + events |
92
+
93
+ ```typescript
94
+ // AG-UI: Stream test generation to UI
95
+ const stream = await agUIAdapter.streamTestGeneration({
96
+ sourceFile: 'src/user.ts',
97
+ onProgress: (event) => console.log(`Progress: ${event.progress}%`),
98
+ onArtifact: (test) => console.log(`Generated: ${test.name}`),
99
+ });
100
+
101
+ // A2A: Cross-agent task delegation
102
+ await a2aAdapter.delegateTask({
103
+ from: 'qe-test-architect',
104
+ to: 'qe-security-scanner',
105
+ task: { type: 'security-review', artifacts: generatedTests },
106
+ });
107
+ ```
108
+
57
109
  ### TinyDancer Intelligent Model Routing (ADR-026)
58
110
 
59
111
  3-tier intelligent model routing for cost optimization:
@@ -355,6 +407,71 @@ aqe agent list -d test-generation
355
407
  aqe agent spawn test-generation -t worker -c unit-test,integration-test
356
408
  ```
357
409
 
410
+ ## Real-World Examples
411
+
412
+ ### Example 1: Quick Test Generation
413
+
414
+ ```bash
415
+ # Generate tests for a single service with 90% coverage target
416
+ claude "Use qe-test-architect to create unit tests for src/services/payment.ts targeting 90% coverage"
417
+ ```
418
+
419
+ **Output:**
420
+ ```
421
+ Generated 24 tests in payment.test.ts
422
+ - 18 unit tests for business logic
423
+ - 4 edge case tests (null, undefined, invalid input)
424
+ - 2 error handling tests
425
+ Coverage: 92.4%
426
+ Pattern learned: "payment-validation" (confidence: 0.91)
427
+ ```
428
+
429
+ ### Example 2: Full Quality Pipeline
430
+
431
+ ```bash
432
+ # Run comprehensive quality assessment before deployment
433
+ claude "Run quality pipeline: test generation, coverage analysis, security scan, and deployment recommendation"
434
+ ```
435
+
436
+ **What happens:**
437
+ 1. **qe-test-architect** generates missing tests
438
+ 2. **qe-coverage-specialist** analyzes gaps with risk scoring
439
+ 3. **qe-security-scanner** runs SAST/DAST checks
440
+ 4. **qe-deployment-advisor** provides go/no-go recommendation
441
+
442
+ ### Example 3: Fix Flaky Tests
443
+
444
+ ```bash
445
+ # Identify and fix flaky tests
446
+ claude "Use qe-flaky-hunter to analyze test runs from the last week and suggest fixes"
447
+ ```
448
+
449
+ **Output:**
450
+ ```
451
+ Found 3 flaky tests:
452
+ 1. auth.test.ts:45 - Race condition in token refresh (fix: add await)
453
+ 2. api.test.ts:123 - Timing-dependent assertion (fix: use fake timers)
454
+ 3. db.test.ts:67 - Shared state between tests (fix: add beforeEach reset)
455
+ ```
456
+
457
+ ### Example 4: Security Audit
458
+
459
+ ```bash
460
+ # Run security scan on codebase
461
+ claude "Use qe-security-scanner to audit src/ for OWASP Top 10 vulnerabilities"
462
+ ```
463
+
464
+ **Output:**
465
+ ```
466
+ Security Scan Complete:
467
+ - 0 Critical vulnerabilities
468
+ - 2 Medium issues:
469
+ - SQL injection risk in src/db/query.ts:34
470
+ - XSS potential in src/components/UserInput.tsx:12
471
+ - 5 Low issues (informational)
472
+ Recommendations generated in security-report.md
473
+ ```
474
+
358
475
  ## MCP Integration
359
476
 
360
477
  Add the MCP server to Claude Code (requires global install):
@@ -55,7 +55,7 @@ When analyzing a live website URL, use this specialized execution pattern.
55
55
  ### Parameters
56
56
 
57
57
  - `URL`: Website to analyze (required)
58
- - `OUTPUT_FOLDER`: Where to save reports (default: `/workspaces/agentic-qe/Agentic QCSD/{domain}/`)
58
+ - `OUTPUT_FOLDER`: Where to save reports (default: `${PROJECT_ROOT}/Agentic QCSD/{domain}/` or `./Agentic QCSD/{domain}/`)
59
59
 
60
60
  ---
61
61
 
@@ -71,7 +71,10 @@ When analyzing a live website URL, use this specialized execution pattern.
71
71
 
72
72
  ```bash
73
73
  # SINGLE COMMAND - handles all tiers automatically:
74
- node /workspaces/agentic-qe/scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000
74
+ # Use npx for installed package, or node with relative path for local development
75
+ npx aqe fetch-content "${URL}" "${OUTPUT_FOLDER}" --timeout 30000
76
+ # OR if running from project root:
77
+ node ./scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000
75
78
  ```
76
79
 
77
80
  **What the script does automatically:**
@@ -84,9 +87,9 @@ node /workspaces/agentic-qe/scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}"
84
87
  **Execution:**
85
88
 
86
89
  ```javascript
87
- // 1. Run the automated fetch cascade
90
+ // 1. Run the automated fetch cascade (use relative path from project root)
88
91
  const fetchResult = Bash({
89
- command: `node /workspaces/agentic-qe/scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000`,
92
+ command: `node ./scripts/fetch-content.js "${URL}" "${OUTPUT_FOLDER}" --timeout 30000`,
90
93
  timeout: 120000 // 2 min total max
91
94
  })
92
95
 
@@ -0,0 +1,153 @@
1
+ /**
2
+ * A2A Agent Card Generator
3
+ *
4
+ * Parses agent markdown files and generates A2A v0.3 compatible Agent Cards.
5
+ * Supports batch generation for all QE agents.
6
+ *
7
+ * @module adapters/a2a/agent-cards/generator
8
+ */
9
+ import { AgentSkill, QEAgentCard, AgentCapabilities, AgentProvider, InputMode, OutputMode } from './schema.js';
10
+ /**
11
+ * Configuration for the Agent Card Generator
12
+ */
13
+ export interface AgentCardGeneratorConfig {
14
+ /** Base URL for agent endpoints */
15
+ readonly baseUrl: string;
16
+ /** Default agent version if not specified in markdown */
17
+ readonly defaultVersion?: string;
18
+ /** Default provider information */
19
+ readonly provider?: AgentProvider;
20
+ /** Default capabilities */
21
+ readonly defaultCapabilities?: AgentCapabilities;
22
+ /** Default input modes */
23
+ readonly defaultInputModes?: InputMode[];
24
+ /** Default output modes */
25
+ readonly defaultOutputModes?: OutputMode[];
26
+ /** Whether to include QE-specific metadata */
27
+ readonly includeQEMetadata?: boolean;
28
+ /** Custom skill extractor function */
29
+ readonly skillExtractor?: (markdown: string, parsedData: ParsedAgentMarkdown) => AgentSkill[];
30
+ /** Custom tag extractor function */
31
+ readonly tagExtractor?: (markdown: string, parsedData: ParsedAgentMarkdown) => string[];
32
+ }
33
+ /**
34
+ * Default generator configuration
35
+ */
36
+ export declare const DEFAULT_GENERATOR_CONFIG: Required<AgentCardGeneratorConfig>;
37
+ /**
38
+ * YAML frontmatter data from agent markdown
39
+ */
40
+ export interface AgentFrontmatter {
41
+ readonly name?: string;
42
+ readonly version?: string;
43
+ readonly updated?: string;
44
+ readonly description?: string;
45
+ readonly domain?: string;
46
+ readonly v2_compat?: {
47
+ readonly name?: string;
48
+ readonly deprecated_in?: string;
49
+ readonly removed_in?: string;
50
+ } | string;
51
+ }
52
+ /**
53
+ * Parsed agent markdown data
54
+ */
55
+ export interface ParsedAgentMarkdown {
56
+ /** Frontmatter data */
57
+ readonly frontmatter: AgentFrontmatter;
58
+ /** Agent identity section */
59
+ readonly identity?: string;
60
+ /** Capabilities section */
61
+ readonly capabilities?: string;
62
+ /** Implementation status section */
63
+ readonly implementationStatus?: string;
64
+ /** Skills available section */
65
+ readonly skillsAvailable?: string;
66
+ /** Memory namespace section */
67
+ readonly memoryNamespace?: string;
68
+ /** Examples section */
69
+ readonly examples?: string;
70
+ /** Output format section */
71
+ readonly outputFormat?: string;
72
+ /** Coordination notes section */
73
+ readonly coordinationNotes?: string;
74
+ /** Learning protocol section */
75
+ readonly learningProtocol?: string;
76
+ /** Raw markdown content */
77
+ readonly rawContent: string;
78
+ }
79
+ /**
80
+ * Result from generating agent cards
81
+ */
82
+ export interface GenerationResult {
83
+ /** Successfully generated cards */
84
+ readonly cards: Map<string, QEAgentCard>;
85
+ /** Errors encountered during generation */
86
+ readonly errors: Map<string, Error>;
87
+ /** Statistics about the generation */
88
+ readonly stats: {
89
+ readonly total: number;
90
+ readonly success: number;
91
+ readonly failed: number;
92
+ readonly duration: number;
93
+ };
94
+ }
95
+ /**
96
+ * Parse YAML frontmatter from markdown content
97
+ */
98
+ export declare function parseFrontmatter(markdown: string): AgentFrontmatter;
99
+ /**
100
+ * Extract a section from markdown by header name
101
+ */
102
+ export declare function extractSection(markdown: string, sectionName: string): string | undefined;
103
+ /**
104
+ * Parse agent markdown file content
105
+ */
106
+ export declare function parseAgentMarkdown(markdown: string): ParsedAgentMarkdown;
107
+ /**
108
+ * Extract examples from markdown content
109
+ */
110
+ export declare function extractExamples(markdown: string, parsed: ParsedAgentMarkdown): string[];
111
+ /**
112
+ * Extract memory namespaces from markdown
113
+ */
114
+ export declare function extractMemoryNamespaces(markdown: string, parsed: ParsedAgentMarkdown): {
115
+ reads: string[];
116
+ writes: string[];
117
+ };
118
+ /**
119
+ * Extract implementation status from markdown
120
+ */
121
+ export declare function extractImplementationStatus(markdown: string, parsed: ParsedAgentMarkdown): {
122
+ working: string[];
123
+ partial: string[];
124
+ planned: string[];
125
+ };
126
+ /**
127
+ * Generator for A2A Agent Cards from agent markdown files
128
+ */
129
+ export declare class AgentCardGenerator {
130
+ private readonly config;
131
+ constructor(config?: Partial<AgentCardGeneratorConfig>);
132
+ /**
133
+ * Generate an agent card from markdown content
134
+ */
135
+ generateFromMarkdown(markdown: string, agentId?: string): QEAgentCard;
136
+ /**
137
+ * Generate an agent card from a markdown file path
138
+ */
139
+ generateFromFile(filePath: string): Promise<QEAgentCard>;
140
+ /**
141
+ * Generate cards for all agent markdown files in a directory
142
+ */
143
+ generateFromDirectory(directoryPath: string, recursive?: boolean): Promise<GenerationResult>;
144
+ /**
145
+ * Generate cards for all 68 QE agents
146
+ */
147
+ generateAllCards(agentsBasePath: string): Promise<GenerationResult>;
148
+ }
149
+ /**
150
+ * Create an Agent Card Generator instance
151
+ */
152
+ export declare function createAgentCardGenerator(config?: Partial<AgentCardGeneratorConfig>): AgentCardGenerator;
153
+ //# sourceMappingURL=generator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generator.d.ts","sourceRoot":"","sources":["../../../../src/adapters/a2a/agent-cards/generator.ts"],"names":[],"mappings":"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"}