@dotsetlabs/bellwether 0.10.0

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 (403) hide show
  1. package/CHANGELOG.md +291 -0
  2. package/LICENSE +21 -0
  3. package/README.md +739 -0
  4. package/dist/auth/credentials.d.ts +64 -0
  5. package/dist/auth/credentials.js +218 -0
  6. package/dist/auth/index.d.ts +6 -0
  7. package/dist/auth/index.js +6 -0
  8. package/dist/auth/keychain.d.ts +64 -0
  9. package/dist/auth/keychain.js +268 -0
  10. package/dist/baseline/ab-testing.d.ts +80 -0
  11. package/dist/baseline/ab-testing.js +236 -0
  12. package/dist/baseline/ai-compatibility-scorer.d.ts +95 -0
  13. package/dist/baseline/ai-compatibility-scorer.js +606 -0
  14. package/dist/baseline/calibration.d.ts +77 -0
  15. package/dist/baseline/calibration.js +136 -0
  16. package/dist/baseline/category-matching.d.ts +85 -0
  17. package/dist/baseline/category-matching.js +289 -0
  18. package/dist/baseline/change-impact-analyzer.d.ts +98 -0
  19. package/dist/baseline/change-impact-analyzer.js +592 -0
  20. package/dist/baseline/comparator.d.ts +64 -0
  21. package/dist/baseline/comparator.js +916 -0
  22. package/dist/baseline/confidence.d.ts +55 -0
  23. package/dist/baseline/confidence.js +122 -0
  24. package/dist/baseline/converter.d.ts +61 -0
  25. package/dist/baseline/converter.js +585 -0
  26. package/dist/baseline/dependency-analyzer.d.ts +89 -0
  27. package/dist/baseline/dependency-analyzer.js +567 -0
  28. package/dist/baseline/deprecation-tracker.d.ts +133 -0
  29. package/dist/baseline/deprecation-tracker.js +322 -0
  30. package/dist/baseline/diff.d.ts +55 -0
  31. package/dist/baseline/diff.js +1584 -0
  32. package/dist/baseline/documentation-scorer.d.ts +205 -0
  33. package/dist/baseline/documentation-scorer.js +466 -0
  34. package/dist/baseline/embeddings.d.ts +118 -0
  35. package/dist/baseline/embeddings.js +251 -0
  36. package/dist/baseline/error-analyzer.d.ts +198 -0
  37. package/dist/baseline/error-analyzer.js +721 -0
  38. package/dist/baseline/evaluation/evaluator.d.ts +42 -0
  39. package/dist/baseline/evaluation/evaluator.js +323 -0
  40. package/dist/baseline/evaluation/expanded-dataset.d.ts +45 -0
  41. package/dist/baseline/evaluation/expanded-dataset.js +1164 -0
  42. package/dist/baseline/evaluation/golden-dataset.d.ts +58 -0
  43. package/dist/baseline/evaluation/golden-dataset.js +717 -0
  44. package/dist/baseline/evaluation/index.d.ts +15 -0
  45. package/dist/baseline/evaluation/index.js +15 -0
  46. package/dist/baseline/evaluation/types.d.ts +186 -0
  47. package/dist/baseline/evaluation/types.js +8 -0
  48. package/dist/baseline/external-dependency-detector.d.ts +181 -0
  49. package/dist/baseline/external-dependency-detector.js +524 -0
  50. package/dist/baseline/golden-output.d.ts +162 -0
  51. package/dist/baseline/golden-output.js +636 -0
  52. package/dist/baseline/health-scorer.d.ts +174 -0
  53. package/dist/baseline/health-scorer.js +451 -0
  54. package/dist/baseline/incremental-checker.d.ts +97 -0
  55. package/dist/baseline/incremental-checker.js +174 -0
  56. package/dist/baseline/index.d.ts +31 -0
  57. package/dist/baseline/index.js +42 -0
  58. package/dist/baseline/migration-generator.d.ts +137 -0
  59. package/dist/baseline/migration-generator.js +554 -0
  60. package/dist/baseline/migrations.d.ts +60 -0
  61. package/dist/baseline/migrations.js +197 -0
  62. package/dist/baseline/performance-tracker.d.ts +214 -0
  63. package/dist/baseline/performance-tracker.js +577 -0
  64. package/dist/baseline/pr-comment-generator.d.ts +117 -0
  65. package/dist/baseline/pr-comment-generator.js +546 -0
  66. package/dist/baseline/response-fingerprint.d.ts +127 -0
  67. package/dist/baseline/response-fingerprint.js +728 -0
  68. package/dist/baseline/response-schema-tracker.d.ts +129 -0
  69. package/dist/baseline/response-schema-tracker.js +420 -0
  70. package/dist/baseline/risk-scorer.d.ts +54 -0
  71. package/dist/baseline/risk-scorer.js +434 -0
  72. package/dist/baseline/saver.d.ts +89 -0
  73. package/dist/baseline/saver.js +554 -0
  74. package/dist/baseline/scenario-generator.d.ts +151 -0
  75. package/dist/baseline/scenario-generator.js +905 -0
  76. package/dist/baseline/schema-compare.d.ts +86 -0
  77. package/dist/baseline/schema-compare.js +557 -0
  78. package/dist/baseline/schema-evolution.d.ts +189 -0
  79. package/dist/baseline/schema-evolution.js +467 -0
  80. package/dist/baseline/semantic.d.ts +203 -0
  81. package/dist/baseline/semantic.js +908 -0
  82. package/dist/baseline/synonyms.d.ts +60 -0
  83. package/dist/baseline/synonyms.js +386 -0
  84. package/dist/baseline/telemetry.d.ts +165 -0
  85. package/dist/baseline/telemetry.js +294 -0
  86. package/dist/baseline/test-pruner.d.ts +120 -0
  87. package/dist/baseline/test-pruner.js +387 -0
  88. package/dist/baseline/types.d.ts +449 -0
  89. package/dist/baseline/types.js +5 -0
  90. package/dist/baseline/version.d.ts +138 -0
  91. package/dist/baseline/version.js +206 -0
  92. package/dist/cache/index.d.ts +5 -0
  93. package/dist/cache/index.js +5 -0
  94. package/dist/cache/response-cache.d.ts +151 -0
  95. package/dist/cache/response-cache.js +287 -0
  96. package/dist/ci/index.d.ts +60 -0
  97. package/dist/ci/index.js +342 -0
  98. package/dist/cli/commands/auth.d.ts +12 -0
  99. package/dist/cli/commands/auth.js +352 -0
  100. package/dist/cli/commands/badge.d.ts +3 -0
  101. package/dist/cli/commands/badge.js +74 -0
  102. package/dist/cli/commands/baseline-accept.d.ts +15 -0
  103. package/dist/cli/commands/baseline-accept.js +178 -0
  104. package/dist/cli/commands/baseline-migrate.d.ts +12 -0
  105. package/dist/cli/commands/baseline-migrate.js +164 -0
  106. package/dist/cli/commands/baseline.d.ts +14 -0
  107. package/dist/cli/commands/baseline.js +449 -0
  108. package/dist/cli/commands/beta.d.ts +10 -0
  109. package/dist/cli/commands/beta.js +231 -0
  110. package/dist/cli/commands/check.d.ts +11 -0
  111. package/dist/cli/commands/check.js +820 -0
  112. package/dist/cli/commands/cloud/badge.d.ts +3 -0
  113. package/dist/cli/commands/cloud/badge.js +74 -0
  114. package/dist/cli/commands/cloud/diff.d.ts +6 -0
  115. package/dist/cli/commands/cloud/diff.js +79 -0
  116. package/dist/cli/commands/cloud/history.d.ts +6 -0
  117. package/dist/cli/commands/cloud/history.js +102 -0
  118. package/dist/cli/commands/cloud/link.d.ts +9 -0
  119. package/dist/cli/commands/cloud/link.js +119 -0
  120. package/dist/cli/commands/cloud/login.d.ts +7 -0
  121. package/dist/cli/commands/cloud/login.js +499 -0
  122. package/dist/cli/commands/cloud/projects.d.ts +6 -0
  123. package/dist/cli/commands/cloud/projects.js +44 -0
  124. package/dist/cli/commands/cloud/shared.d.ts +7 -0
  125. package/dist/cli/commands/cloud/shared.js +42 -0
  126. package/dist/cli/commands/cloud/teams.d.ts +8 -0
  127. package/dist/cli/commands/cloud/teams.js +169 -0
  128. package/dist/cli/commands/cloud/upload.d.ts +8 -0
  129. package/dist/cli/commands/cloud/upload.js +181 -0
  130. package/dist/cli/commands/contract.d.ts +11 -0
  131. package/dist/cli/commands/contract.js +280 -0
  132. package/dist/cli/commands/discover.d.ts +3 -0
  133. package/dist/cli/commands/discover.js +82 -0
  134. package/dist/cli/commands/eval.d.ts +9 -0
  135. package/dist/cli/commands/eval.js +187 -0
  136. package/dist/cli/commands/explore.d.ts +11 -0
  137. package/dist/cli/commands/explore.js +437 -0
  138. package/dist/cli/commands/feedback.d.ts +9 -0
  139. package/dist/cli/commands/feedback.js +174 -0
  140. package/dist/cli/commands/golden.d.ts +12 -0
  141. package/dist/cli/commands/golden.js +407 -0
  142. package/dist/cli/commands/history.d.ts +10 -0
  143. package/dist/cli/commands/history.js +202 -0
  144. package/dist/cli/commands/init.d.ts +9 -0
  145. package/dist/cli/commands/init.js +219 -0
  146. package/dist/cli/commands/interview.d.ts +3 -0
  147. package/dist/cli/commands/interview.js +903 -0
  148. package/dist/cli/commands/link.d.ts +10 -0
  149. package/dist/cli/commands/link.js +169 -0
  150. package/dist/cli/commands/login.d.ts +7 -0
  151. package/dist/cli/commands/login.js +499 -0
  152. package/dist/cli/commands/preset.d.ts +33 -0
  153. package/dist/cli/commands/preset.js +297 -0
  154. package/dist/cli/commands/profile.d.ts +33 -0
  155. package/dist/cli/commands/profile.js +286 -0
  156. package/dist/cli/commands/registry.d.ts +11 -0
  157. package/dist/cli/commands/registry.js +146 -0
  158. package/dist/cli/commands/shared.d.ts +79 -0
  159. package/dist/cli/commands/shared.js +196 -0
  160. package/dist/cli/commands/teams.d.ts +8 -0
  161. package/dist/cli/commands/teams.js +169 -0
  162. package/dist/cli/commands/test.d.ts +9 -0
  163. package/dist/cli/commands/test.js +500 -0
  164. package/dist/cli/commands/upload.d.ts +8 -0
  165. package/dist/cli/commands/upload.js +223 -0
  166. package/dist/cli/commands/validate-config.d.ts +6 -0
  167. package/dist/cli/commands/validate-config.js +35 -0
  168. package/dist/cli/commands/verify.d.ts +11 -0
  169. package/dist/cli/commands/verify.js +283 -0
  170. package/dist/cli/commands/watch.d.ts +12 -0
  171. package/dist/cli/commands/watch.js +253 -0
  172. package/dist/cli/index.d.ts +3 -0
  173. package/dist/cli/index.js +178 -0
  174. package/dist/cli/interactive.d.ts +47 -0
  175. package/dist/cli/interactive.js +216 -0
  176. package/dist/cli/output/terminal-reporter.d.ts +19 -0
  177. package/dist/cli/output/terminal-reporter.js +104 -0
  178. package/dist/cli/output.d.ts +226 -0
  179. package/dist/cli/output.js +438 -0
  180. package/dist/cli/utils/env.d.ts +5 -0
  181. package/dist/cli/utils/env.js +14 -0
  182. package/dist/cli/utils/progress.d.ts +59 -0
  183. package/dist/cli/utils/progress.js +206 -0
  184. package/dist/cli/utils/server-context.d.ts +10 -0
  185. package/dist/cli/utils/server-context.js +36 -0
  186. package/dist/cloud/auth.d.ts +144 -0
  187. package/dist/cloud/auth.js +374 -0
  188. package/dist/cloud/client.d.ts +24 -0
  189. package/dist/cloud/client.js +65 -0
  190. package/dist/cloud/http-client.d.ts +38 -0
  191. package/dist/cloud/http-client.js +215 -0
  192. package/dist/cloud/index.d.ts +23 -0
  193. package/dist/cloud/index.js +25 -0
  194. package/dist/cloud/mock-client.d.ts +107 -0
  195. package/dist/cloud/mock-client.js +545 -0
  196. package/dist/cloud/types.d.ts +515 -0
  197. package/dist/cloud/types.js +15 -0
  198. package/dist/config/defaults.d.ts +160 -0
  199. package/dist/config/defaults.js +169 -0
  200. package/dist/config/loader.d.ts +24 -0
  201. package/dist/config/loader.js +122 -0
  202. package/dist/config/template.d.ts +42 -0
  203. package/dist/config/template.js +647 -0
  204. package/dist/config/validator.d.ts +2112 -0
  205. package/dist/config/validator.js +658 -0
  206. package/dist/constants/cloud.d.ts +107 -0
  207. package/dist/constants/cloud.js +110 -0
  208. package/dist/constants/core.d.ts +521 -0
  209. package/dist/constants/core.js +556 -0
  210. package/dist/constants/testing.d.ts +1283 -0
  211. package/dist/constants/testing.js +1568 -0
  212. package/dist/constants.d.ts +10 -0
  213. package/dist/constants.js +10 -0
  214. package/dist/contract/index.d.ts +6 -0
  215. package/dist/contract/index.js +5 -0
  216. package/dist/contract/validator.d.ts +177 -0
  217. package/dist/contract/validator.js +574 -0
  218. package/dist/cost/index.d.ts +6 -0
  219. package/dist/cost/index.js +5 -0
  220. package/dist/cost/tracker.d.ts +134 -0
  221. package/dist/cost/tracker.js +313 -0
  222. package/dist/discovery/discovery.d.ts +16 -0
  223. package/dist/discovery/discovery.js +173 -0
  224. package/dist/discovery/types.d.ts +51 -0
  225. package/dist/discovery/types.js +2 -0
  226. package/dist/docs/agents.d.ts +3 -0
  227. package/dist/docs/agents.js +995 -0
  228. package/dist/docs/contract.d.ts +51 -0
  229. package/dist/docs/contract.js +1681 -0
  230. package/dist/docs/generator.d.ts +4 -0
  231. package/dist/docs/generator.js +4 -0
  232. package/dist/docs/html-reporter.d.ts +9 -0
  233. package/dist/docs/html-reporter.js +757 -0
  234. package/dist/docs/index.d.ts +10 -0
  235. package/dist/docs/index.js +11 -0
  236. package/dist/docs/junit-reporter.d.ts +18 -0
  237. package/dist/docs/junit-reporter.js +210 -0
  238. package/dist/docs/report.d.ts +14 -0
  239. package/dist/docs/report.js +44 -0
  240. package/dist/docs/sarif-reporter.d.ts +19 -0
  241. package/dist/docs/sarif-reporter.js +335 -0
  242. package/dist/docs/shared.d.ts +35 -0
  243. package/dist/docs/shared.js +162 -0
  244. package/dist/docs/templates.d.ts +12 -0
  245. package/dist/docs/templates.js +76 -0
  246. package/dist/errors/index.d.ts +6 -0
  247. package/dist/errors/index.js +6 -0
  248. package/dist/errors/retry.d.ts +92 -0
  249. package/dist/errors/retry.js +323 -0
  250. package/dist/errors/types.d.ts +321 -0
  251. package/dist/errors/types.js +584 -0
  252. package/dist/index.d.ts +32 -0
  253. package/dist/index.js +32 -0
  254. package/dist/interview/dependency-resolver.d.ts +11 -0
  255. package/dist/interview/dependency-resolver.js +32 -0
  256. package/dist/interview/interviewer.d.ts +232 -0
  257. package/dist/interview/interviewer.js +1939 -0
  258. package/dist/interview/mock-response-generator.d.ts +7 -0
  259. package/dist/interview/mock-response-generator.js +102 -0
  260. package/dist/interview/orchestrator.d.ts +237 -0
  261. package/dist/interview/orchestrator.js +1296 -0
  262. package/dist/interview/rate-limiter.d.ts +15 -0
  263. package/dist/interview/rate-limiter.js +55 -0
  264. package/dist/interview/response-validator.d.ts +10 -0
  265. package/dist/interview/response-validator.js +132 -0
  266. package/dist/interview/schema-inferrer.d.ts +8 -0
  267. package/dist/interview/schema-inferrer.js +71 -0
  268. package/dist/interview/schema-test-generator.d.ts +71 -0
  269. package/dist/interview/schema-test-generator.js +834 -0
  270. package/dist/interview/smart-value-generator.d.ts +155 -0
  271. package/dist/interview/smart-value-generator.js +554 -0
  272. package/dist/interview/stateful-test-runner.d.ts +19 -0
  273. package/dist/interview/stateful-test-runner.js +106 -0
  274. package/dist/interview/types.d.ts +561 -0
  275. package/dist/interview/types.js +2 -0
  276. package/dist/llm/anthropic.d.ts +41 -0
  277. package/dist/llm/anthropic.js +355 -0
  278. package/dist/llm/client.d.ts +123 -0
  279. package/dist/llm/client.js +42 -0
  280. package/dist/llm/factory.d.ts +38 -0
  281. package/dist/llm/factory.js +145 -0
  282. package/dist/llm/fallback.d.ts +140 -0
  283. package/dist/llm/fallback.js +379 -0
  284. package/dist/llm/index.d.ts +18 -0
  285. package/dist/llm/index.js +15 -0
  286. package/dist/llm/ollama.d.ts +37 -0
  287. package/dist/llm/ollama.js +330 -0
  288. package/dist/llm/openai.d.ts +25 -0
  289. package/dist/llm/openai.js +320 -0
  290. package/dist/llm/token-budget.d.ts +161 -0
  291. package/dist/llm/token-budget.js +395 -0
  292. package/dist/logging/logger.d.ts +70 -0
  293. package/dist/logging/logger.js +130 -0
  294. package/dist/metrics/collector.d.ts +106 -0
  295. package/dist/metrics/collector.js +547 -0
  296. package/dist/metrics/index.d.ts +7 -0
  297. package/dist/metrics/index.js +7 -0
  298. package/dist/metrics/prometheus.d.ts +20 -0
  299. package/dist/metrics/prometheus.js +241 -0
  300. package/dist/metrics/types.d.ts +209 -0
  301. package/dist/metrics/types.js +5 -0
  302. package/dist/persona/builtins.d.ts +54 -0
  303. package/dist/persona/builtins.js +219 -0
  304. package/dist/persona/index.d.ts +8 -0
  305. package/dist/persona/index.js +8 -0
  306. package/dist/persona/loader.d.ts +30 -0
  307. package/dist/persona/loader.js +190 -0
  308. package/dist/persona/types.d.ts +144 -0
  309. package/dist/persona/types.js +5 -0
  310. package/dist/persona/validation.d.ts +94 -0
  311. package/dist/persona/validation.js +332 -0
  312. package/dist/prompts/index.d.ts +5 -0
  313. package/dist/prompts/index.js +5 -0
  314. package/dist/prompts/templates.d.ts +180 -0
  315. package/dist/prompts/templates.js +431 -0
  316. package/dist/registry/client.d.ts +49 -0
  317. package/dist/registry/client.js +191 -0
  318. package/dist/registry/index.d.ts +7 -0
  319. package/dist/registry/index.js +6 -0
  320. package/dist/registry/types.d.ts +140 -0
  321. package/dist/registry/types.js +6 -0
  322. package/dist/scenarios/evaluator.d.ts +43 -0
  323. package/dist/scenarios/evaluator.js +206 -0
  324. package/dist/scenarios/index.d.ts +10 -0
  325. package/dist/scenarios/index.js +9 -0
  326. package/dist/scenarios/loader.d.ts +20 -0
  327. package/dist/scenarios/loader.js +285 -0
  328. package/dist/scenarios/types.d.ts +153 -0
  329. package/dist/scenarios/types.js +8 -0
  330. package/dist/security/index.d.ts +17 -0
  331. package/dist/security/index.js +18 -0
  332. package/dist/security/payloads.d.ts +61 -0
  333. package/dist/security/payloads.js +268 -0
  334. package/dist/security/security-tester.d.ts +42 -0
  335. package/dist/security/security-tester.js +582 -0
  336. package/dist/security/types.d.ts +166 -0
  337. package/dist/security/types.js +8 -0
  338. package/dist/transport/base-transport.d.ts +59 -0
  339. package/dist/transport/base-transport.js +38 -0
  340. package/dist/transport/http-transport.d.ts +67 -0
  341. package/dist/transport/http-transport.js +238 -0
  342. package/dist/transport/mcp-client.d.ts +141 -0
  343. package/dist/transport/mcp-client.js +496 -0
  344. package/dist/transport/sse-transport.d.ts +88 -0
  345. package/dist/transport/sse-transport.js +316 -0
  346. package/dist/transport/stdio-transport.d.ts +43 -0
  347. package/dist/transport/stdio-transport.js +238 -0
  348. package/dist/transport/types.d.ts +125 -0
  349. package/dist/transport/types.js +16 -0
  350. package/dist/utils/concurrency.d.ts +123 -0
  351. package/dist/utils/concurrency.js +213 -0
  352. package/dist/utils/formatters.d.ts +16 -0
  353. package/dist/utils/formatters.js +37 -0
  354. package/dist/utils/index.d.ts +8 -0
  355. package/dist/utils/index.js +8 -0
  356. package/dist/utils/jsonpath.d.ts +87 -0
  357. package/dist/utils/jsonpath.js +326 -0
  358. package/dist/utils/markdown.d.ts +113 -0
  359. package/dist/utils/markdown.js +265 -0
  360. package/dist/utils/network.d.ts +14 -0
  361. package/dist/utils/network.js +17 -0
  362. package/dist/utils/sanitize.d.ts +92 -0
  363. package/dist/utils/sanitize.js +191 -0
  364. package/dist/utils/semantic.d.ts +194 -0
  365. package/dist/utils/semantic.js +1051 -0
  366. package/dist/utils/smart-truncate.d.ts +94 -0
  367. package/dist/utils/smart-truncate.js +361 -0
  368. package/dist/utils/timeout.d.ts +153 -0
  369. package/dist/utils/timeout.js +205 -0
  370. package/dist/utils/yaml-parser.d.ts +58 -0
  371. package/dist/utils/yaml-parser.js +86 -0
  372. package/dist/validation/index.d.ts +32 -0
  373. package/dist/validation/index.js +32 -0
  374. package/dist/validation/semantic-test-generator.d.ts +50 -0
  375. package/dist/validation/semantic-test-generator.js +176 -0
  376. package/dist/validation/semantic-types.d.ts +66 -0
  377. package/dist/validation/semantic-types.js +94 -0
  378. package/dist/validation/semantic-validator.d.ts +38 -0
  379. package/dist/validation/semantic-validator.js +340 -0
  380. package/dist/verification/index.d.ts +6 -0
  381. package/dist/verification/index.js +5 -0
  382. package/dist/verification/types.d.ts +133 -0
  383. package/dist/verification/types.js +5 -0
  384. package/dist/verification/verifier.d.ts +30 -0
  385. package/dist/verification/verifier.js +309 -0
  386. package/dist/version.d.ts +19 -0
  387. package/dist/version.js +48 -0
  388. package/dist/workflow/auto-generator.d.ts +27 -0
  389. package/dist/workflow/auto-generator.js +513 -0
  390. package/dist/workflow/discovery.d.ts +40 -0
  391. package/dist/workflow/discovery.js +195 -0
  392. package/dist/workflow/executor.d.ts +82 -0
  393. package/dist/workflow/executor.js +611 -0
  394. package/dist/workflow/index.d.ts +10 -0
  395. package/dist/workflow/index.js +10 -0
  396. package/dist/workflow/loader.d.ts +24 -0
  397. package/dist/workflow/loader.js +194 -0
  398. package/dist/workflow/state-tracker.d.ts +98 -0
  399. package/dist/workflow/state-tracker.js +424 -0
  400. package/dist/workflow/types.d.ts +337 -0
  401. package/dist/workflow/types.js +5 -0
  402. package/package.json +94 -0
  403. package/schemas/bellwether-check.schema.json +651 -0
@@ -0,0 +1,651 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://unpkg.com/@dotsetlabs/bellwether/schemas/bellwether-check.schema.json",
4
+ "title": "Bellwether Check Report",
5
+ "type": "object",
6
+ "required": [
7
+ "$schema",
8
+ "discovery",
9
+ "toolProfiles",
10
+ "summary",
11
+ "limitations",
12
+ "recommendations",
13
+ "metadata"
14
+ ],
15
+ "properties": {
16
+ "$schema": {
17
+ "type": "string"
18
+ },
19
+ "discovery": {
20
+ "$ref": "#/$defs/DiscoveryResult"
21
+ },
22
+ "toolProfiles": {
23
+ "type": "array",
24
+ "items": {
25
+ "$ref": "#/$defs/ToolProfile"
26
+ }
27
+ },
28
+ "promptProfiles": {
29
+ "type": "array",
30
+ "items": {
31
+ "$ref": "#/$defs/PromptProfile"
32
+ }
33
+ },
34
+ "resourceProfiles": {
35
+ "type": "array",
36
+ "items": {
37
+ "$ref": "#/$defs/ResourceProfile"
38
+ }
39
+ },
40
+ "workflowResults": {
41
+ "type": "array",
42
+ "items": {
43
+ "$ref": "#/$defs/WorkflowResult"
44
+ }
45
+ },
46
+ "scenarioResults": {
47
+ "type": "array",
48
+ "items": {
49
+ "$ref": "#/$defs/ScenarioResult"
50
+ }
51
+ },
52
+ "summary": {
53
+ "type": "string"
54
+ },
55
+ "limitations": {
56
+ "type": "array",
57
+ "items": {
58
+ "type": "string"
59
+ }
60
+ },
61
+ "recommendations": {
62
+ "type": "array",
63
+ "items": {
64
+ "type": "string"
65
+ }
66
+ },
67
+ "metadata": {
68
+ "$ref": "#/$defs/InterviewMetadata"
69
+ }
70
+ },
71
+ "additionalProperties": true,
72
+ "$defs": {
73
+ "DiscoveryResult": {
74
+ "type": "object",
75
+ "required": [
76
+ "serverInfo",
77
+ "protocolVersion",
78
+ "capabilities",
79
+ "tools",
80
+ "prompts",
81
+ "resources",
82
+ "timestamp",
83
+ "serverCommand",
84
+ "serverArgs"
85
+ ],
86
+ "properties": {
87
+ "serverInfo": {
88
+ "$ref": "#/$defs/MCPServerInfo"
89
+ },
90
+ "protocolVersion": {
91
+ "type": "string"
92
+ },
93
+ "capabilities": {
94
+ "$ref": "#/$defs/MCPServerCapabilities"
95
+ },
96
+ "tools": {
97
+ "type": "array",
98
+ "items": {
99
+ "$ref": "#/$defs/MCPTool"
100
+ }
101
+ },
102
+ "prompts": {
103
+ "type": "array",
104
+ "items": {
105
+ "$ref": "#/$defs/MCPPrompt"
106
+ }
107
+ },
108
+ "resources": {
109
+ "type": "array",
110
+ "items": {
111
+ "$ref": "#/$defs/MCPResource"
112
+ }
113
+ },
114
+ "timestamp": {
115
+ "type": "string",
116
+ "format": "date-time"
117
+ },
118
+ "serverCommand": {
119
+ "type": "string"
120
+ },
121
+ "serverArgs": {
122
+ "type": "array",
123
+ "items": {
124
+ "type": "string"
125
+ }
126
+ }
127
+ },
128
+ "additionalProperties": true
129
+ },
130
+ "MCPServerInfo": {
131
+ "type": "object",
132
+ "required": ["name", "version"],
133
+ "properties": {
134
+ "name": { "type": "string" },
135
+ "version": { "type": "string" }
136
+ },
137
+ "additionalProperties": true
138
+ },
139
+ "MCPServerCapabilities": {
140
+ "type": "object",
141
+ "properties": {
142
+ "tools": { "type": "object" },
143
+ "prompts": { "type": "object" },
144
+ "resources": { "type": "object" },
145
+ "logging": { "type": "object" }
146
+ },
147
+ "additionalProperties": true
148
+ },
149
+ "MCPTool": {
150
+ "type": "object",
151
+ "required": ["name"],
152
+ "properties": {
153
+ "name": { "type": "string" },
154
+ "description": { "type": "string" },
155
+ "inputSchema": { "type": "object" }
156
+ },
157
+ "additionalProperties": true
158
+ },
159
+ "MCPPrompt": {
160
+ "type": "object",
161
+ "required": ["name"],
162
+ "properties": {
163
+ "name": { "type": "string" },
164
+ "description": { "type": "string" },
165
+ "arguments": {
166
+ "type": "array",
167
+ "items": { "$ref": "#/$defs/MCPPromptArgument" }
168
+ }
169
+ },
170
+ "additionalProperties": true
171
+ },
172
+ "MCPPromptArgument": {
173
+ "type": "object",
174
+ "required": ["name"],
175
+ "properties": {
176
+ "name": { "type": "string" },
177
+ "description": { "type": "string" },
178
+ "required": { "type": "boolean" }
179
+ },
180
+ "additionalProperties": true
181
+ },
182
+ "MCPResource": {
183
+ "type": "object",
184
+ "required": ["uri", "name"],
185
+ "properties": {
186
+ "uri": { "type": "string" },
187
+ "name": { "type": "string" },
188
+ "description": { "type": "string" },
189
+ "mimeType": { "type": "string" }
190
+ },
191
+ "additionalProperties": true
192
+ },
193
+ "MCPToolCallResult": {
194
+ "type": "object",
195
+ "required": ["content"],
196
+ "properties": {
197
+ "content": {
198
+ "type": "array",
199
+ "items": { "$ref": "#/$defs/MCPContentBlock" }
200
+ },
201
+ "isError": { "type": "boolean" }
202
+ },
203
+ "additionalProperties": true
204
+ },
205
+ "MCPContentBlock": {
206
+ "type": "object",
207
+ "required": ["type"],
208
+ "properties": {
209
+ "type": { "type": "string", "enum": ["text", "image", "resource"] },
210
+ "text": { "type": "string" },
211
+ "data": { "type": "string" },
212
+ "mimeType": { "type": "string" }
213
+ },
214
+ "additionalProperties": true
215
+ },
216
+ "ToolProfile": {
217
+ "type": "object",
218
+ "required": ["name", "description", "interactions", "behavioralNotes", "limitations", "securityNotes"],
219
+ "properties": {
220
+ "name": { "type": "string" },
221
+ "description": { "type": "string" },
222
+ "interactions": {
223
+ "type": "array",
224
+ "items": { "$ref": "#/$defs/ToolInteraction" }
225
+ },
226
+ "behavioralNotes": {
227
+ "type": "array",
228
+ "items": { "type": "string" }
229
+ },
230
+ "limitations": {
231
+ "type": "array",
232
+ "items": { "type": "string" }
233
+ },
234
+ "securityNotes": {
235
+ "type": "array",
236
+ "items": { "type": "string" }
237
+ },
238
+ "findingsByPersona": {
239
+ "type": "array",
240
+ "items": { "$ref": "#/$defs/PersonaFindings" }
241
+ },
242
+ "errorClassification": { "$ref": "#/$defs/ErrorClassification" },
243
+ "skipped": { "type": "boolean" },
244
+ "skipReason": { "type": "string" },
245
+ "mocked": { "type": "boolean" },
246
+ "mockService": { "type": "string" },
247
+ "responseSchema": { "$ref": "#/$defs/ResponseSchema" },
248
+ "assertionSummary": { "$ref": "#/$defs/AssertionSummary" },
249
+ "dependencyInfo": { "$ref": "#/$defs/ToolDependencyInfo" }
250
+ },
251
+ "additionalProperties": true
252
+ },
253
+ "ToolInteraction": {
254
+ "type": "object",
255
+ "required": ["toolName", "question", "response", "error", "analysis", "durationMs"],
256
+ "properties": {
257
+ "toolName": { "type": "string" },
258
+ "question": { "$ref": "#/$defs/InterviewQuestion" },
259
+ "response": { "anyOf": [{ "$ref": "#/$defs/MCPToolCallResult" }, { "type": "null" }] },
260
+ "error": { "anyOf": [{ "type": "string" }, { "type": "null" }] },
261
+ "analysis": { "type": "string" },
262
+ "durationMs": { "type": "number" },
263
+ "toolExecutionMs": { "type": "number" },
264
+ "llmAnalysisMs": { "type": "number" },
265
+ "personaId": { "type": "string" },
266
+ "outcomeAssessment": { "$ref": "#/$defs/OutcomeAssessment" },
267
+ "assertionResults": {
268
+ "type": "array",
269
+ "items": { "$ref": "#/$defs/ResponseAssertionResult" }
270
+ },
271
+ "assertionsPassed": { "type": "boolean" },
272
+ "mocked": { "type": "boolean" },
273
+ "mockService": { "type": "string" }
274
+ },
275
+ "additionalProperties": true
276
+ },
277
+ "InterviewQuestion": {
278
+ "type": "object",
279
+ "required": ["description", "category", "args"],
280
+ "properties": {
281
+ "description": { "type": "string" },
282
+ "category": { "type": "string" },
283
+ "args": { "type": "object" },
284
+ "expectedOutcome": { "type": "string" },
285
+ "metadata": { "type": "object" }
286
+ },
287
+ "additionalProperties": true
288
+ },
289
+ "OutcomeAssessment": {
290
+ "type": "object",
291
+ "required": ["expected", "actual", "correct"],
292
+ "properties": {
293
+ "expected": { "type": "string" },
294
+ "actual": { "type": "string" },
295
+ "correct": { "type": "boolean" },
296
+ "isValidationSuccess": { "type": "boolean" }
297
+ },
298
+ "additionalProperties": true
299
+ },
300
+ "AssertionSummary": {
301
+ "type": "object",
302
+ "required": ["total", "passed", "failed"],
303
+ "properties": {
304
+ "total": { "type": "number" },
305
+ "passed": { "type": "number" },
306
+ "failed": { "type": "number" }
307
+ },
308
+ "additionalProperties": true
309
+ },
310
+ "ResponseSchema": {
311
+ "type": "object",
312
+ "required": ["inferredType", "sampleFingerprints"],
313
+ "properties": {
314
+ "inferredType": { "type": "string" },
315
+ "jsonSchema": { "type": "object" },
316
+ "markdownStructure": { "type": "object" },
317
+ "sampleFingerprints": {
318
+ "type": "array",
319
+ "items": { "type": "string" }
320
+ }
321
+ },
322
+ "additionalProperties": true
323
+ },
324
+ "ResponseAssertionResult": {
325
+ "type": "object",
326
+ "required": ["type", "passed"],
327
+ "properties": {
328
+ "type": { "type": "string" },
329
+ "passed": { "type": "boolean" },
330
+ "message": { "type": "string" },
331
+ "expected": {},
332
+ "actual": {}
333
+ },
334
+ "additionalProperties": true
335
+ },
336
+ "ToolDependencyInfo": {
337
+ "type": "object",
338
+ "required": ["tool", "dependsOn", "providesOutputFor", "sequencePosition"],
339
+ "properties": {
340
+ "tool": { "type": "string" },
341
+ "dependsOn": {
342
+ "type": "array",
343
+ "items": { "type": "string" }
344
+ },
345
+ "providesOutputFor": {
346
+ "type": "array",
347
+ "items": { "type": "string" }
348
+ },
349
+ "sequencePosition": { "type": "number" }
350
+ },
351
+ "additionalProperties": true
352
+ },
353
+ "PersonaFindings": {
354
+ "type": "object",
355
+ "required": ["personaId", "personaName", "behavioralNotes", "limitations", "securityNotes"],
356
+ "properties": {
357
+ "personaId": { "type": "string" },
358
+ "personaName": { "type": "string" },
359
+ "behavioralNotes": {
360
+ "type": "array",
361
+ "items": { "type": "string" }
362
+ },
363
+ "limitations": {
364
+ "type": "array",
365
+ "items": { "type": "string" }
366
+ },
367
+ "securityNotes": {
368
+ "type": "array",
369
+ "items": { "type": "string" }
370
+ }
371
+ },
372
+ "additionalProperties": true
373
+ },
374
+ "ErrorClassification": {
375
+ "type": "object",
376
+ "required": ["externalServiceErrors", "environmentErrors", "codeBugErrors", "unknownErrors"],
377
+ "properties": {
378
+ "externalServiceErrors": { "type": "number" },
379
+ "environmentErrors": { "type": "number" },
380
+ "codeBugErrors": { "type": "number" },
381
+ "unknownErrors": { "type": "number" },
382
+ "detectedServices": {
383
+ "type": "array",
384
+ "items": { "type": "string" }
385
+ }
386
+ },
387
+ "additionalProperties": true
388
+ },
389
+ "PromptProfile": {
390
+ "type": "object",
391
+ "required": ["name", "description", "arguments", "interactions", "behavioralNotes", "limitations"],
392
+ "properties": {
393
+ "name": { "type": "string" },
394
+ "description": { "type": "string" },
395
+ "arguments": {
396
+ "type": "array",
397
+ "items": { "$ref": "#/$defs/MCPPromptArgument" }
398
+ },
399
+ "interactions": {
400
+ "type": "array",
401
+ "items": { "$ref": "#/$defs/PromptInteraction" }
402
+ },
403
+ "behavioralNotes": {
404
+ "type": "array",
405
+ "items": { "type": "string" }
406
+ },
407
+ "limitations": {
408
+ "type": "array",
409
+ "items": { "type": "string" }
410
+ },
411
+ "exampleOutput": { "type": "string" }
412
+ },
413
+ "additionalProperties": true
414
+ },
415
+ "PromptInteraction": {
416
+ "type": "object",
417
+ "required": ["promptName", "question", "response", "error", "analysis", "durationMs"],
418
+ "properties": {
419
+ "promptName": { "type": "string" },
420
+ "question": { "$ref": "#/$defs/PromptQuestion" },
421
+ "response": { "anyOf": [{ "$ref": "#/$defs/MCPPromptGetResult" }, { "type": "null" }] },
422
+ "error": { "anyOf": [{ "type": "string" }, { "type": "null" }] },
423
+ "analysis": { "type": "string" },
424
+ "durationMs": { "type": "number" }
425
+ },
426
+ "additionalProperties": true
427
+ },
428
+ "PromptQuestion": {
429
+ "type": "object",
430
+ "required": ["description", "args"],
431
+ "properties": {
432
+ "description": { "type": "string" },
433
+ "args": { "type": "object" }
434
+ },
435
+ "additionalProperties": true
436
+ },
437
+ "MCPPromptGetResult": {
438
+ "type": "object",
439
+ "required": ["messages"],
440
+ "properties": {
441
+ "description": { "type": "string" },
442
+ "messages": {
443
+ "type": "array",
444
+ "items": { "$ref": "#/$defs/MCPPromptMessage" }
445
+ }
446
+ },
447
+ "additionalProperties": true
448
+ },
449
+ "MCPPromptMessage": {
450
+ "type": "object",
451
+ "required": ["role", "content"],
452
+ "properties": {
453
+ "role": { "type": "string" },
454
+ "content": { "$ref": "#/$defs/MCPPromptContent" }
455
+ },
456
+ "additionalProperties": true
457
+ },
458
+ "MCPPromptContent": {
459
+ "type": "object",
460
+ "required": ["type"],
461
+ "properties": {
462
+ "type": { "type": "string" },
463
+ "text": { "type": "string" },
464
+ "data": { "type": "string" },
465
+ "mimeType": { "type": "string" }
466
+ },
467
+ "additionalProperties": true
468
+ },
469
+ "ResourceProfile": {
470
+ "type": "object",
471
+ "required": ["uri", "name", "description", "interactions", "behavioralNotes", "limitations"],
472
+ "properties": {
473
+ "uri": { "type": "string" },
474
+ "name": { "type": "string" },
475
+ "description": { "type": "string" },
476
+ "mimeType": { "type": "string" },
477
+ "interactions": {
478
+ "type": "array",
479
+ "items": { "$ref": "#/$defs/ResourceInteraction" }
480
+ },
481
+ "behavioralNotes": {
482
+ "type": "array",
483
+ "items": { "type": "string" }
484
+ },
485
+ "limitations": {
486
+ "type": "array",
487
+ "items": { "type": "string" }
488
+ },
489
+ "contentPreview": { "type": "string" }
490
+ },
491
+ "additionalProperties": true
492
+ },
493
+ "ResourceInteraction": {
494
+ "type": "object",
495
+ "required": ["resourceUri", "resourceName", "question", "response", "error", "analysis", "durationMs"],
496
+ "properties": {
497
+ "resourceUri": { "type": "string" },
498
+ "resourceName": { "type": "string" },
499
+ "question": { "$ref": "#/$defs/ResourceQuestion" },
500
+ "response": { "anyOf": [{ "$ref": "#/$defs/MCPResourceReadResult" }, { "type": "null" }] },
501
+ "error": { "anyOf": [{ "type": "string" }, { "type": "null" }] },
502
+ "analysis": { "type": "string" },
503
+ "durationMs": { "type": "number" }
504
+ },
505
+ "additionalProperties": true
506
+ },
507
+ "ResourceQuestion": {
508
+ "type": "object",
509
+ "required": ["description", "category"],
510
+ "properties": {
511
+ "description": { "type": "string" },
512
+ "category": { "type": "string" }
513
+ },
514
+ "additionalProperties": true
515
+ },
516
+ "MCPResourceReadResult": {
517
+ "type": "object",
518
+ "required": ["contents"],
519
+ "properties": {
520
+ "contents": {
521
+ "type": "array",
522
+ "items": { "$ref": "#/$defs/MCPResourceContent" }
523
+ }
524
+ },
525
+ "additionalProperties": true
526
+ },
527
+ "MCPResourceContent": {
528
+ "type": "object",
529
+ "required": ["uri"],
530
+ "properties": {
531
+ "uri": { "type": "string" },
532
+ "mimeType": { "type": "string" },
533
+ "text": { "type": "string" },
534
+ "blob": { "type": "string" }
535
+ },
536
+ "additionalProperties": true
537
+ },
538
+ "WorkflowResult": {
539
+ "type": "object",
540
+ "properties": {
541
+ "name": { "type": "string" },
542
+ "passed": { "type": "boolean" },
543
+ "steps": { "type": "array" },
544
+ "error": { "type": "string" }
545
+ },
546
+ "additionalProperties": true
547
+ },
548
+ "ScenarioResult": {
549
+ "type": "object",
550
+ "properties": {
551
+ "scenario": { "type": "object" },
552
+ "passed": { "type": "boolean" },
553
+ "error": { "type": "string" },
554
+ "durationMs": { "type": "number" }
555
+ },
556
+ "additionalProperties": true
557
+ },
558
+ "InterviewMetadata": {
559
+ "type": "object",
560
+ "required": ["startTime", "endTime", "durationMs", "toolCallCount", "errorCount"],
561
+ "properties": {
562
+ "startTime": { "type": "string", "format": "date-time" },
563
+ "endTime": { "type": "string", "format": "date-time" },
564
+ "durationMs": { "type": "number" },
565
+ "toolCallCount": { "type": "number" },
566
+ "resourceReadCount": { "type": "number" },
567
+ "errorCount": { "type": "number" },
568
+ "model": { "type": "string" },
569
+ "personas": {
570
+ "type": "array",
571
+ "items": { "$ref": "#/$defs/PersonaSummary" }
572
+ },
573
+ "workflows": { "$ref": "#/$defs/WorkflowSummary" },
574
+ "serverCommand": { "type": "string" },
575
+ "rateLimit": { "$ref": "#/$defs/RateLimitSummary" },
576
+ "externalServices": { "$ref": "#/$defs/ExternalServiceSummary" },
577
+ "assertions": { "$ref": "#/$defs/AssertionSummary" },
578
+ "statefulTesting": { "$ref": "#/$defs/StatefulTestingSummary" }
579
+ },
580
+ "additionalProperties": true
581
+ },
582
+ "PersonaSummary": {
583
+ "type": "object",
584
+ "required": ["id", "name", "questionsAsked", "toolCallCount", "errorCount"],
585
+ "properties": {
586
+ "id": { "type": "string" },
587
+ "name": { "type": "string" },
588
+ "questionsAsked": { "type": "number" },
589
+ "toolCallCount": { "type": "number" },
590
+ "errorCount": { "type": "number" }
591
+ },
592
+ "additionalProperties": true
593
+ },
594
+ "WorkflowSummary": {
595
+ "type": "object",
596
+ "required": ["workflowCount", "successfulCount", "failedCount", "discoveredCount", "loadedCount"],
597
+ "properties": {
598
+ "workflowCount": { "type": "number" },
599
+ "successfulCount": { "type": "number" },
600
+ "failedCount": { "type": "number" },
601
+ "discoveredCount": { "type": "number" },
602
+ "loadedCount": { "type": "number" }
603
+ },
604
+ "additionalProperties": true
605
+ },
606
+ "RateLimitSummary": {
607
+ "type": "object",
608
+ "required": ["totalEvents", "totalRetries", "tools"],
609
+ "properties": {
610
+ "totalEvents": { "type": "number" },
611
+ "totalRetries": { "type": "number" },
612
+ "tools": {
613
+ "type": "array",
614
+ "items": { "type": "string" }
615
+ }
616
+ },
617
+ "additionalProperties": true
618
+ },
619
+ "ExternalServiceSummary": {
620
+ "type": "object",
621
+ "required": ["mode", "unconfiguredServices", "skippedTools", "mockedTools"],
622
+ "properties": {
623
+ "mode": { "type": "string" },
624
+ "unconfiguredServices": {
625
+ "type": "array",
626
+ "items": { "type": "string" }
627
+ },
628
+ "skippedTools": {
629
+ "type": "array",
630
+ "items": { "type": "string" }
631
+ },
632
+ "mockedTools": {
633
+ "type": "array",
634
+ "items": { "type": "string" }
635
+ }
636
+ },
637
+ "additionalProperties": true
638
+ },
639
+ "StatefulTestingSummary": {
640
+ "type": "object",
641
+ "required": ["enabled", "toolCount", "dependencyCount", "maxChainLength"],
642
+ "properties": {
643
+ "enabled": { "type": "boolean" },
644
+ "toolCount": { "type": "number" },
645
+ "dependencyCount": { "type": "number" },
646
+ "maxChainLength": { "type": "number" }
647
+ },
648
+ "additionalProperties": true
649
+ }
650
+ }
651
+ }