observability-toolkit 2.0.0 → 2.1.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 (1285) hide show
  1. package/README.md +163 -398
  2. package/dist/__tests__/find-constant-dedup.test.d.ts +11 -0
  3. package/dist/__tests__/find-constant-dedup.test.d.ts.map +1 -0
  4. package/dist/__tests__/find-constant-dedup.test.js +132 -0
  5. package/dist/__tests__/find-constant-dedup.test.js.map +1 -0
  6. package/dist/backends/backend-schemas.d.ts +309 -0
  7. package/dist/backends/backend-schemas.d.ts.map +1 -0
  8. package/dist/backends/backend-schemas.js +215 -0
  9. package/dist/backends/backend-schemas.js.map +1 -0
  10. package/dist/backends/cloud.d.ts +46 -0
  11. package/dist/backends/cloud.d.ts.map +1 -0
  12. package/dist/backends/cloud.js +520 -0
  13. package/dist/backends/cloud.js.map +1 -0
  14. package/dist/backends/cloud.test.d.ts +2 -0
  15. package/dist/backends/cloud.test.d.ts.map +1 -0
  16. package/dist/backends/cloud.test.js +436 -0
  17. package/dist/backends/cloud.test.js.map +1 -0
  18. package/dist/backends/index.d.ts +659 -386
  19. package/dist/backends/index.d.ts.map +1 -1
  20. package/dist/backends/index.js +318 -41
  21. package/dist/backends/index.js.map +1 -1
  22. package/dist/backends/index.test.js +578 -57
  23. package/dist/backends/index.test.js.map +1 -1
  24. package/dist/backends/local-jsonl-boolean-search.test.js +8 -7
  25. package/dist/backends/local-jsonl-boolean-search.test.js.map +1 -1
  26. package/dist/backends/local-jsonl-cache.test.js +33 -31
  27. package/dist/backends/local-jsonl-cache.test.js.map +1 -1
  28. package/dist/backends/local-jsonl-circuit-breaker.test.js +9 -7
  29. package/dist/backends/local-jsonl-circuit-breaker.test.js.map +1 -1
  30. package/dist/backends/local-jsonl-export.test.js +73 -58
  31. package/dist/backends/local-jsonl-export.test.js.map +1 -1
  32. package/dist/backends/local-jsonl-index.test.js +52 -50
  33. package/dist/backends/local-jsonl-index.test.js.map +1 -1
  34. package/dist/backends/local-jsonl-logs.test.js +47 -31
  35. package/dist/backends/local-jsonl-logs.test.js.map +1 -1
  36. package/dist/backends/local-jsonl-metrics.test.js +85 -82
  37. package/dist/backends/local-jsonl-metrics.test.js.map +1 -1
  38. package/dist/backends/local-jsonl-otlp-unwrap.test.d.ts +2 -0
  39. package/dist/backends/local-jsonl-otlp-unwrap.test.d.ts.map +1 -0
  40. package/dist/backends/local-jsonl-otlp-unwrap.test.js +602 -0
  41. package/dist/backends/local-jsonl-otlp-unwrap.test.js.map +1 -0
  42. package/dist/backends/local-jsonl-traces.test.js +161 -147
  43. package/dist/backends/local-jsonl-traces.test.js.map +1 -1
  44. package/dist/backends/local-jsonl.d.ts +37 -8
  45. package/dist/backends/local-jsonl.d.ts.map +1 -1
  46. package/dist/backends/local-jsonl.js +1088 -241
  47. package/dist/backends/local-jsonl.js.map +1 -1
  48. package/dist/backends/shared.d.ts +9 -0
  49. package/dist/backends/shared.d.ts.map +1 -0
  50. package/dist/backends/shared.js +9 -0
  51. package/dist/backends/shared.js.map +1 -0
  52. package/dist/generated/opentelemetry/proto/collector/logs/v1/logs_service_pb.d.ts +40 -0
  53. package/dist/generated/opentelemetry/proto/collector/logs/v1/logs_service_pb.d.ts.map +1 -0
  54. package/dist/generated/opentelemetry/proto/collector/logs/v1/logs_service_pb.js +27 -0
  55. package/dist/generated/opentelemetry/proto/collector/logs/v1/logs_service_pb.js.map +1 -0
  56. package/dist/generated/opentelemetry/proto/collector/metrics/v1/metrics_service_pb.d.ts +106 -0
  57. package/dist/generated/opentelemetry/proto/collector/metrics/v1/metrics_service_pb.d.ts.map +1 -0
  58. package/dist/generated/opentelemetry/proto/collector/metrics/v1/metrics_service_pb.js +43 -0
  59. package/dist/generated/opentelemetry/proto/collector/metrics/v1/metrics_service_pb.js.map +1 -0
  60. package/dist/generated/opentelemetry/proto/collector/profiles/v1development/profiles_service_pb.d.ts +111 -0
  61. package/dist/generated/opentelemetry/proto/collector/profiles/v1development/profiles_service_pb.d.ts.map +1 -0
  62. package/dist/generated/opentelemetry/proto/collector/profiles/v1development/profiles_service_pb.js +42 -0
  63. package/dist/generated/opentelemetry/proto/collector/profiles/v1development/profiles_service_pb.js.map +1 -0
  64. package/dist/generated/opentelemetry/proto/collector/trace/v1/trace_service_pb.d.ts +106 -0
  65. package/dist/generated/opentelemetry/proto/collector/trace/v1/trace_service_pb.d.ts.map +1 -0
  66. package/dist/generated/opentelemetry/proto/collector/trace/v1/trace_service_pb.js +43 -0
  67. package/dist/generated/opentelemetry/proto/collector/trace/v1/trace_service_pb.js.map +1 -0
  68. package/dist/generated/opentelemetry/proto/common/v1/common_pb.d.ts +243 -0
  69. package/dist/generated/opentelemetry/proto/common/v1/common_pb.d.ts.map +1 -0
  70. package/dist/generated/opentelemetry/proto/common/v1/common_pb.js +49 -0
  71. package/dist/generated/opentelemetry/proto/common/v1/common_pb.js.map +1 -0
  72. package/dist/generated/opentelemetry/proto/logs/v1/logs_pb.d.ts +90 -0
  73. package/dist/generated/opentelemetry/proto/logs/v1/logs_pb.d.ts.map +1 -0
  74. package/dist/generated/opentelemetry/proto/logs/v1/logs_pb.js +66 -0
  75. package/dist/generated/opentelemetry/proto/logs/v1/logs_pb.js.map +1 -0
  76. package/dist/generated/opentelemetry/proto/metrics/v1/metrics_pb.d.ts +1134 -0
  77. package/dist/generated/opentelemetry/proto/metrics/v1/metrics_pb.d.ts.map +1 -0
  78. package/dist/generated/opentelemetry/proto/metrics/v1/metrics_pb.js +223 -0
  79. package/dist/generated/opentelemetry/proto/metrics/v1/metrics_pb.js.map +1 -0
  80. package/dist/generated/opentelemetry/proto/profiles/v1development/profiles_pb.d.ts +678 -0
  81. package/dist/generated/opentelemetry/proto/profiles/v1development/profiles_pb.d.ts.map +1 -0
  82. package/dist/generated/opentelemetry/proto/profiles/v1development/profiles_pb.js +107 -0
  83. package/dist/generated/opentelemetry/proto/profiles/v1development/profiles_pb.js.map +1 -0
  84. package/dist/generated/opentelemetry/proto/resource/v1/resource_pb.d.ts +46 -0
  85. package/dist/generated/opentelemetry/proto/resource/v1/resource_pb.d.ts.map +1 -0
  86. package/dist/generated/opentelemetry/proto/resource/v1/resource_pb.js +25 -0
  87. package/dist/generated/opentelemetry/proto/resource/v1/resource_pb.js.map +1 -0
  88. package/dist/generated/opentelemetry/proto/trace/v1/trace_pb.d.ts +569 -0
  89. package/dist/generated/opentelemetry/proto/trace/v1/trace_pb.d.ts.map +1 -0
  90. package/dist/generated/opentelemetry/proto/trace/v1/trace_pb.js +195 -0
  91. package/dist/generated/opentelemetry/proto/trace/v1/trace_pb.js.map +1 -0
  92. package/dist/lib/agent-judge/agent-as-judge.d.ts +157 -0
  93. package/dist/lib/agent-judge/agent-as-judge.d.ts.map +1 -0
  94. package/dist/lib/agent-judge/agent-as-judge.js +137 -0
  95. package/dist/lib/agent-judge/agent-as-judge.js.map +1 -0
  96. package/dist/lib/agent-judge/agent-as-judge.test.d.ts.map +1 -0
  97. package/dist/lib/agent-judge/agent-as-judge.test.js +839 -0
  98. package/dist/lib/agent-judge/agent-as-judge.test.js.map +1 -0
  99. package/dist/lib/agent-judge/agent-eval-metrics.d.ts +293 -0
  100. package/dist/lib/agent-judge/agent-eval-metrics.d.ts.map +1 -0
  101. package/dist/lib/agent-judge/agent-eval-metrics.js +715 -0
  102. package/dist/lib/agent-judge/agent-eval-metrics.js.map +1 -0
  103. package/dist/lib/agent-judge/agent-eval-metrics.test.d.ts +5 -0
  104. package/dist/lib/agent-judge/agent-eval-metrics.test.d.ts.map +1 -0
  105. package/dist/lib/agent-judge/agent-eval-metrics.test.js +676 -0
  106. package/dist/lib/agent-judge/agent-eval-metrics.test.js.map +1 -0
  107. package/dist/lib/agent-judge/agent-judge-classes.d.ts +95 -0
  108. package/dist/lib/agent-judge/agent-judge-classes.d.ts.map +1 -0
  109. package/dist/lib/agent-judge/agent-judge-classes.js +222 -0
  110. package/dist/lib/agent-judge/agent-judge-classes.js.map +1 -0
  111. package/dist/lib/agent-judge/agent-judge-classes.test.d.ts +6 -0
  112. package/dist/lib/agent-judge/agent-judge-classes.test.d.ts.map +1 -0
  113. package/dist/lib/agent-judge/agent-judge-classes.test.js +271 -0
  114. package/dist/lib/agent-judge/agent-judge-classes.test.js.map +1 -0
  115. package/dist/lib/agent-judge/agent-judge-consensus.d.ts +58 -0
  116. package/dist/lib/agent-judge/agent-judge-consensus.d.ts.map +1 -0
  117. package/dist/lib/agent-judge/agent-judge-consensus.js +149 -0
  118. package/dist/lib/agent-judge/agent-judge-consensus.js.map +1 -0
  119. package/dist/lib/agent-judge/agent-judge-consensus.test.d.ts +2 -0
  120. package/dist/lib/agent-judge/agent-judge-consensus.test.d.ts.map +1 -0
  121. package/dist/lib/agent-judge/agent-judge-consensus.test.js +170 -0
  122. package/dist/lib/agent-judge/agent-judge-consensus.test.js.map +1 -0
  123. package/dist/lib/agent-judge/agent-judge-verification.d.ts +89 -0
  124. package/dist/lib/agent-judge/agent-judge-verification.d.ts.map +1 -0
  125. package/dist/lib/agent-judge/agent-judge-verification.js +235 -0
  126. package/dist/lib/agent-judge/agent-judge-verification.js.map +1 -0
  127. package/dist/lib/agent-judge/agent-judge-verification.test.d.ts +5 -0
  128. package/dist/lib/agent-judge/agent-judge-verification.test.d.ts.map +1 -0
  129. package/dist/lib/agent-judge/agent-judge-verification.test.js +399 -0
  130. package/dist/lib/agent-judge/agent-judge-verification.test.js.map +1 -0
  131. package/dist/lib/audit/agent-auditor-scoring.d.ts +167 -0
  132. package/dist/lib/audit/agent-auditor-scoring.d.ts.map +1 -0
  133. package/dist/lib/audit/agent-auditor-scoring.js +338 -0
  134. package/dist/lib/audit/agent-auditor-scoring.js.map +1 -0
  135. package/dist/lib/audit/agent-auditor-scoring.test.d.ts +2 -0
  136. package/dist/lib/audit/agent-auditor-scoring.test.d.ts.map +1 -0
  137. package/dist/lib/audit/agent-auditor-scoring.test.js +576 -0
  138. package/dist/lib/audit/agent-auditor-scoring.test.js.map +1 -0
  139. package/dist/lib/audit/audit-record.d.ts +139 -0
  140. package/dist/lib/audit/audit-record.d.ts.map +1 -0
  141. package/dist/lib/audit/audit-record.js +288 -0
  142. package/dist/lib/audit/audit-record.js.map +1 -0
  143. package/dist/lib/audit/audit-record.test.d.ts +5 -0
  144. package/dist/lib/audit/audit-record.test.d.ts.map +1 -0
  145. package/dist/lib/audit/audit-record.test.js +258 -0
  146. package/dist/lib/audit/audit-record.test.js.map +1 -0
  147. package/dist/lib/audit/audit-scoring-constants.d.ts +57 -0
  148. package/dist/lib/audit/audit-scoring-constants.d.ts.map +1 -0
  149. package/dist/lib/audit/audit-scoring-constants.js +59 -0
  150. package/dist/lib/audit/audit-scoring-constants.js.map +1 -0
  151. package/dist/lib/audit/compliance-report.d.ts +125 -0
  152. package/dist/lib/audit/compliance-report.d.ts.map +1 -0
  153. package/dist/lib/audit/compliance-report.js +205 -0
  154. package/dist/lib/audit/compliance-report.js.map +1 -0
  155. package/dist/lib/audit/compliance-report.test.d.ts +5 -0
  156. package/dist/lib/audit/compliance-report.test.d.ts.map +1 -0
  157. package/dist/lib/audit/compliance-report.test.js +290 -0
  158. package/dist/lib/audit/compliance-report.test.js.map +1 -0
  159. package/dist/lib/audit/retention-guard.d.ts +41 -0
  160. package/dist/lib/audit/retention-guard.d.ts.map +1 -0
  161. package/dist/lib/audit/retention-guard.js +103 -0
  162. package/dist/lib/audit/retention-guard.js.map +1 -0
  163. package/dist/lib/audit/retention-guard.test.d.ts +5 -0
  164. package/dist/lib/audit/retention-guard.test.d.ts.map +1 -0
  165. package/dist/lib/audit/retention-guard.test.js +109 -0
  166. package/dist/lib/audit/retention-guard.test.js.map +1 -0
  167. package/dist/lib/audit/skill-auditor-scoring.d.ts +69 -0
  168. package/dist/lib/audit/skill-auditor-scoring.d.ts.map +1 -0
  169. package/dist/lib/audit/skill-auditor-scoring.js +149 -0
  170. package/dist/lib/audit/skill-auditor-scoring.js.map +1 -0
  171. package/dist/lib/audit/skill-auditor-scoring.test.d.ts +2 -0
  172. package/dist/lib/audit/skill-auditor-scoring.test.d.ts.map +1 -0
  173. package/dist/lib/audit/skill-auditor-scoring.test.js +369 -0
  174. package/dist/lib/audit/skill-auditor-scoring.test.js.map +1 -0
  175. package/dist/lib/audit/verification-events.d.ts +119 -0
  176. package/dist/lib/audit/verification-events.d.ts.map +1 -0
  177. package/dist/lib/audit/verification-events.js +175 -0
  178. package/dist/lib/audit/verification-events.js.map +1 -0
  179. package/dist/lib/audit/verification-events.test.d.ts.map +1 -0
  180. package/dist/lib/audit/verification-events.test.js +197 -0
  181. package/dist/lib/audit/verification-events.test.js.map +1 -0
  182. package/dist/lib/core/constants-models.d.ts +90 -0
  183. package/dist/lib/core/constants-models.d.ts.map +1 -0
  184. package/dist/lib/core/constants-models.js +208 -0
  185. package/dist/lib/core/constants-models.js.map +1 -0
  186. package/dist/lib/core/constants-otel.d.ts +68 -0
  187. package/dist/lib/core/constants-otel.d.ts.map +1 -0
  188. package/dist/lib/core/constants-otel.js +128 -0
  189. package/dist/lib/core/constants-otel.js.map +1 -0
  190. package/dist/lib/core/constants-symlink.test.d.ts.map +1 -0
  191. package/dist/lib/core/constants-symlink.test.js +358 -0
  192. package/dist/lib/core/constants-symlink.test.js.map +1 -0
  193. package/dist/lib/core/constants-telemetry.d.ts +21 -0
  194. package/dist/lib/core/constants-telemetry.d.ts.map +1 -0
  195. package/dist/lib/core/constants-telemetry.js +162 -0
  196. package/dist/lib/core/constants-telemetry.js.map +1 -0
  197. package/dist/lib/core/constants.d.ts +152 -0
  198. package/dist/lib/core/constants.d.ts.map +1 -0
  199. package/dist/lib/core/constants.js +223 -0
  200. package/dist/lib/core/constants.js.map +1 -0
  201. package/dist/lib/core/constants.test.d.ts.map +1 -0
  202. package/dist/lib/core/constants.test.js +833 -0
  203. package/dist/lib/core/constants.test.js.map +1 -0
  204. package/dist/lib/core/doc-sync.test.d.ts +9 -0
  205. package/dist/lib/core/doc-sync.test.d.ts.map +1 -0
  206. package/dist/lib/core/doc-sync.test.js +159 -0
  207. package/dist/lib/core/doc-sync.test.js.map +1 -0
  208. package/dist/lib/core/edge-cases.test.d.ts.map +1 -0
  209. package/dist/lib/core/edge-cases.test.js +637 -0
  210. package/dist/lib/core/edge-cases.test.js.map +1 -0
  211. package/dist/lib/core/file-utils.d.ts +360 -0
  212. package/dist/lib/core/file-utils.d.ts.map +1 -0
  213. package/dist/lib/core/file-utils.js +890 -0
  214. package/dist/lib/core/file-utils.js.map +1 -0
  215. package/dist/lib/core/file-utils.test-constants.d.ts +38 -0
  216. package/dist/lib/core/file-utils.test-constants.d.ts.map +1 -0
  217. package/dist/lib/core/file-utils.test-constants.js +40 -0
  218. package/dist/lib/core/file-utils.test-constants.js.map +1 -0
  219. package/dist/lib/core/file-utils.test.d.ts.map +1 -0
  220. package/dist/lib/core/file-utils.test.js +1329 -0
  221. package/dist/lib/core/file-utils.test.js.map +1 -0
  222. package/dist/lib/core/input-validator.d.ts +125 -0
  223. package/dist/lib/core/input-validator.d.ts.map +1 -0
  224. package/dist/lib/core/input-validator.fuzz.test.d.ts.map +1 -0
  225. package/dist/lib/core/input-validator.fuzz.test.js +302 -0
  226. package/dist/lib/core/input-validator.fuzz.test.js.map +1 -0
  227. package/dist/lib/core/input-validator.js +348 -0
  228. package/dist/lib/core/input-validator.js.map +1 -0
  229. package/dist/lib/core/input-validator.test.d.ts.map +1 -0
  230. package/dist/lib/core/input-validator.test.js +465 -0
  231. package/dist/lib/core/input-validator.test.js.map +1 -0
  232. package/dist/lib/core/logger.d.ts +32 -0
  233. package/dist/lib/core/logger.d.ts.map +1 -0
  234. package/dist/lib/core/logger.js +104 -0
  235. package/dist/lib/core/logger.js.map +1 -0
  236. package/dist/lib/core/logger.test.d.ts.map +1 -0
  237. package/dist/lib/core/logger.test.js.map +1 -0
  238. package/dist/lib/core/schema-types.d.ts +37 -0
  239. package/dist/lib/core/schema-types.d.ts.map +1 -0
  240. package/dist/lib/core/schema-types.js +29 -0
  241. package/dist/lib/core/schema-types.js.map +1 -0
  242. package/dist/lib/core/server-utils.d.ts +98 -0
  243. package/dist/lib/core/server-utils.d.ts.map +1 -0
  244. package/dist/lib/core/server-utils.js +193 -0
  245. package/dist/lib/core/server-utils.js.map +1 -0
  246. package/dist/lib/core/shared-schemas.d.ts +301 -0
  247. package/dist/lib/core/shared-schemas.d.ts.map +1 -0
  248. package/dist/lib/core/shared-schemas.js +222 -0
  249. package/dist/lib/core/shared-schemas.js.map +1 -0
  250. package/dist/lib/core/shared-schemas.test.d.ts.map +1 -0
  251. package/dist/lib/core/shared-schemas.test.js +136 -0
  252. package/dist/lib/core/shared-schemas.test.js.map +1 -0
  253. package/dist/lib/core/units.d.ts +67 -0
  254. package/dist/lib/core/units.d.ts.map +1 -0
  255. package/dist/lib/core/units.js +88 -0
  256. package/dist/lib/core/units.js.map +1 -0
  257. package/dist/lib/cost/cost-estimation.d.ts +264 -0
  258. package/dist/lib/cost/cost-estimation.d.ts.map +1 -0
  259. package/dist/lib/cost/cost-estimation.js +541 -0
  260. package/dist/lib/cost/cost-estimation.js.map +1 -0
  261. package/dist/lib/cost/cost-estimation.test.d.ts +5 -0
  262. package/dist/lib/cost/cost-estimation.test.d.ts.map +1 -0
  263. package/dist/lib/cost/cost-estimation.test.js +701 -0
  264. package/dist/lib/cost/cost-estimation.test.js.map +1 -0
  265. package/dist/lib/cost/pricing-cache.d.ts +59 -0
  266. package/dist/lib/cost/pricing-cache.d.ts.map +1 -0
  267. package/dist/lib/cost/pricing-cache.js +120 -0
  268. package/dist/lib/cost/pricing-cache.js.map +1 -0
  269. package/dist/lib/cost/pricing-cache.test.d.ts +5 -0
  270. package/dist/lib/cost/pricing-cache.test.d.ts.map +1 -0
  271. package/dist/lib/cost/pricing-cache.test.js +176 -0
  272. package/dist/lib/cost/pricing-cache.test.js.map +1 -0
  273. package/dist/lib/dashboard-file-utils.d.ts +35 -0
  274. package/dist/lib/dashboard-file-utils.d.ts.map +1 -0
  275. package/dist/lib/dashboard-file-utils.js +94 -0
  276. package/dist/lib/dashboard-file-utils.js.map +1 -0
  277. package/dist/lib/errors/error-sanitizer.d.ts +62 -0
  278. package/dist/lib/errors/error-sanitizer.d.ts.map +1 -0
  279. package/dist/lib/errors/error-sanitizer.js +235 -0
  280. package/dist/lib/errors/error-sanitizer.js.map +1 -0
  281. package/dist/lib/errors/error-sanitizer.test.d.ts.map +1 -0
  282. package/dist/lib/errors/error-sanitizer.test.js +534 -0
  283. package/dist/lib/errors/error-sanitizer.test.js.map +1 -0
  284. package/dist/lib/errors/error-types.d.ts +59 -0
  285. package/dist/lib/errors/error-types.d.ts.map +1 -0
  286. package/dist/lib/errors/error-types.js +187 -0
  287. package/dist/lib/errors/error-types.js.map +1 -0
  288. package/dist/lib/errors/error-types.test.d.ts.map +1 -0
  289. package/dist/lib/errors/error-types.test.js +246 -0
  290. package/dist/lib/errors/error-types.test.js.map +1 -0
  291. package/dist/lib/errors/query-sanitizer.d.ts.map +1 -0
  292. package/dist/lib/errors/query-sanitizer.js +269 -0
  293. package/dist/lib/errors/query-sanitizer.js.map +1 -0
  294. package/dist/lib/errors/query-sanitizer.test.d.ts.map +1 -0
  295. package/dist/lib/errors/query-sanitizer.test.js +403 -0
  296. package/dist/lib/errors/query-sanitizer.test.js.map +1 -0
  297. package/dist/lib/exports/confident-export.d.ts +105 -0
  298. package/dist/lib/exports/confident-export.d.ts.map +1 -0
  299. package/dist/lib/exports/confident-export.js +385 -0
  300. package/dist/lib/exports/confident-export.js.map +1 -0
  301. package/dist/lib/exports/confident-export.test.d.ts.map +1 -0
  302. package/dist/lib/exports/confident-export.test.js +848 -0
  303. package/dist/lib/exports/confident-export.test.js.map +1 -0
  304. package/dist/lib/exports/datadog-export.d.ts +200 -0
  305. package/dist/lib/exports/datadog-export.d.ts.map +1 -0
  306. package/dist/lib/exports/datadog-export.js +488 -0
  307. package/dist/lib/exports/datadog-export.js.map +1 -0
  308. package/dist/lib/exports/datadog-export.test.d.ts +2 -0
  309. package/dist/lib/exports/datadog-export.test.d.ts.map +1 -0
  310. package/dist/lib/exports/datadog-export.test.js +890 -0
  311. package/dist/lib/exports/datadog-export.test.js.map +1 -0
  312. package/dist/lib/exports/export-config-schemas.d.ts +67 -0
  313. package/dist/lib/exports/export-config-schemas.d.ts.map +1 -0
  314. package/dist/lib/exports/export-config-schemas.js +120 -0
  315. package/dist/lib/exports/export-config-schemas.js.map +1 -0
  316. package/dist/lib/exports/export-config-schemas.test.d.ts +8 -0
  317. package/dist/lib/exports/export-config-schemas.test.d.ts.map +1 -0
  318. package/dist/lib/exports/export-config-schemas.test.js +503 -0
  319. package/dist/lib/exports/export-config-schemas.test.js.map +1 -0
  320. package/dist/lib/exports/export-utils.d.ts +127 -0
  321. package/dist/lib/exports/export-utils.d.ts.map +1 -0
  322. package/dist/lib/exports/export-utils.js +303 -0
  323. package/dist/lib/exports/export-utils.js.map +1 -0
  324. package/dist/lib/exports/export-utils.test.d.ts.map +1 -0
  325. package/dist/lib/exports/export-utils.test.js +344 -0
  326. package/dist/lib/exports/export-utils.test.js.map +1 -0
  327. package/dist/lib/exports/langfuse-export.d.ts +129 -0
  328. package/dist/lib/exports/langfuse-export.d.ts.map +1 -0
  329. package/dist/lib/exports/langfuse-export.js +370 -0
  330. package/dist/lib/exports/langfuse-export.js.map +1 -0
  331. package/dist/lib/exports/langfuse-export.test.d.ts.map +1 -0
  332. package/dist/lib/exports/langfuse-export.test.js +1020 -0
  333. package/dist/lib/exports/langfuse-export.test.js.map +1 -0
  334. package/dist/lib/exports/otlp-export.d.ts +179 -0
  335. package/dist/lib/exports/otlp-export.d.ts.map +1 -0
  336. package/dist/lib/exports/otlp-export.js +397 -0
  337. package/dist/lib/exports/otlp-export.js.map +1 -0
  338. package/dist/lib/exports/otlp-format-converter.d.ts +70 -0
  339. package/dist/lib/exports/otlp-format-converter.d.ts.map +1 -0
  340. package/dist/lib/exports/otlp-format-converter.js +401 -0
  341. package/dist/lib/exports/otlp-format-converter.js.map +1 -0
  342. package/dist/lib/exports/otlp-proto-encode.d.ts +53 -0
  343. package/dist/lib/exports/otlp-proto-encode.d.ts.map +1 -0
  344. package/dist/lib/exports/otlp-proto-encode.js +165 -0
  345. package/dist/lib/exports/otlp-proto-encode.js.map +1 -0
  346. package/dist/lib/exports/otlp-proto-encode.test.d.ts +7 -0
  347. package/dist/lib/exports/otlp-proto-encode.test.d.ts.map +1 -0
  348. package/dist/lib/exports/otlp-proto-encode.test.js +997 -0
  349. package/dist/lib/exports/otlp-proto-encode.test.js.map +1 -0
  350. package/dist/lib/exports/phoenix-export.d.ts +119 -0
  351. package/dist/lib/exports/phoenix-export.d.ts.map +1 -0
  352. package/dist/lib/exports/phoenix-export.js +448 -0
  353. package/dist/lib/exports/phoenix-export.js.map +1 -0
  354. package/dist/lib/exports/phoenix-export.test.d.ts.map +1 -0
  355. package/dist/lib/exports/phoenix-export.test.js +816 -0
  356. package/dist/lib/exports/phoenix-export.test.js.map +1 -0
  357. package/dist/lib/index.d.ts +16 -0
  358. package/dist/lib/index.d.ts.map +1 -0
  359. package/dist/lib/index.js +31 -0
  360. package/dist/lib/index.js.map +1 -0
  361. package/dist/lib/judge/evaluation-hooks-schemas.d.ts +186 -0
  362. package/dist/lib/judge/evaluation-hooks-schemas.d.ts.map +1 -0
  363. package/dist/lib/judge/evaluation-hooks-schemas.js +125 -0
  364. package/dist/lib/judge/evaluation-hooks-schemas.js.map +1 -0
  365. package/dist/lib/judge/evaluation-hooks.d.ts +88 -0
  366. package/dist/lib/judge/evaluation-hooks.d.ts.map +1 -0
  367. package/dist/lib/judge/evaluation-hooks.js +658 -0
  368. package/dist/lib/judge/evaluation-hooks.js.map +1 -0
  369. package/dist/lib/judge/evaluation-hooks.test.d.ts.map +1 -0
  370. package/dist/lib/judge/evaluation-hooks.test.js +934 -0
  371. package/dist/lib/judge/evaluation-hooks.test.js.map +1 -0
  372. package/dist/lib/judge/llm-as-judge.d.ts +138 -0
  373. package/dist/lib/judge/llm-as-judge.d.ts.map +1 -0
  374. package/dist/lib/judge/llm-as-judge.js +103 -0
  375. package/dist/lib/judge/llm-as-judge.js.map +1 -0
  376. package/dist/lib/judge/llm-as-judge.test.d.ts.map +1 -0
  377. package/dist/lib/judge/llm-as-judge.test.js +2179 -0
  378. package/dist/lib/judge/llm-as-judge.test.js.map +1 -0
  379. package/dist/lib/judge/llm-judge-bias.d.ts +44 -0
  380. package/dist/lib/judge/llm-judge-bias.d.ts.map +1 -0
  381. package/dist/lib/judge/llm-judge-bias.js +130 -0
  382. package/dist/lib/judge/llm-judge-bias.js.map +1 -0
  383. package/dist/lib/judge/llm-judge-bias.test.d.ts +2 -0
  384. package/dist/lib/judge/llm-judge-bias.test.d.ts.map +1 -0
  385. package/dist/lib/judge/llm-judge-bias.test.js +380 -0
  386. package/dist/lib/judge/llm-judge-bias.test.js.map +1 -0
  387. package/dist/lib/judge/llm-judge-code.d.ts +99 -0
  388. package/dist/lib/judge/llm-judge-code.d.ts.map +1 -0
  389. package/dist/lib/judge/llm-judge-code.js +261 -0
  390. package/dist/lib/judge/llm-judge-code.js.map +1 -0
  391. package/dist/lib/judge/llm-judge-code.test.d.ts +2 -0
  392. package/dist/lib/judge/llm-judge-code.test.d.ts.map +1 -0
  393. package/dist/lib/judge/llm-judge-code.test.js +981 -0
  394. package/dist/lib/judge/llm-judge-code.test.js.map +1 -0
  395. package/dist/lib/judge/llm-judge-config.d.ts +241 -0
  396. package/dist/lib/judge/llm-judge-config.d.ts.map +1 -0
  397. package/dist/lib/judge/llm-judge-config.js +390 -0
  398. package/dist/lib/judge/llm-judge-config.js.map +1 -0
  399. package/dist/lib/judge/llm-judge-config.test.d.ts +5 -0
  400. package/dist/lib/judge/llm-judge-config.test.d.ts.map +1 -0
  401. package/dist/lib/judge/llm-judge-config.test.js +392 -0
  402. package/dist/lib/judge/llm-judge-config.test.js.map +1 -0
  403. package/dist/lib/judge/llm-judge-constants.d.ts +111 -0
  404. package/dist/lib/judge/llm-judge-constants.d.ts.map +1 -0
  405. package/dist/lib/judge/llm-judge-constants.js +150 -0
  406. package/dist/lib/judge/llm-judge-constants.js.map +1 -0
  407. package/dist/lib/judge/llm-judge-dag.d.ts +57 -0
  408. package/dist/lib/judge/llm-judge-dag.d.ts.map +1 -0
  409. package/dist/lib/judge/llm-judge-dag.js +217 -0
  410. package/dist/lib/judge/llm-judge-dag.js.map +1 -0
  411. package/dist/lib/judge/llm-judge-dag.test.d.ts +8 -0
  412. package/dist/lib/judge/llm-judge-dag.test.d.ts.map +1 -0
  413. package/dist/lib/judge/llm-judge-dag.test.js +973 -0
  414. package/dist/lib/judge/llm-judge-dag.test.js.map +1 -0
  415. package/dist/lib/judge/llm-judge-domain.d.ts +42 -0
  416. package/dist/lib/judge/llm-judge-domain.d.ts.map +1 -0
  417. package/dist/lib/judge/llm-judge-domain.js +167 -0
  418. package/dist/lib/judge/llm-judge-domain.js.map +1 -0
  419. package/dist/lib/judge/llm-judge-domain.test.d.ts +6 -0
  420. package/dist/lib/judge/llm-judge-domain.test.d.ts.map +1 -0
  421. package/dist/lib/judge/llm-judge-domain.test.js +337 -0
  422. package/dist/lib/judge/llm-judge-domain.test.js.map +1 -0
  423. package/dist/lib/judge/llm-judge-geval.d.ts +42 -0
  424. package/dist/lib/judge/llm-judge-geval.d.ts.map +1 -0
  425. package/dist/lib/judge/llm-judge-geval.js +213 -0
  426. package/dist/lib/judge/llm-judge-geval.js.map +1 -0
  427. package/dist/lib/judge/llm-judge-geval.test.d.ts +2 -0
  428. package/dist/lib/judge/llm-judge-geval.test.d.ts.map +1 -0
  429. package/dist/lib/judge/llm-judge-geval.test.js +556 -0
  430. package/dist/lib/judge/llm-judge-geval.test.js.map +1 -0
  431. package/dist/lib/judge/llm-judge-otel.test.d.ts +9 -0
  432. package/dist/lib/judge/llm-judge-otel.test.d.ts.map +1 -0
  433. package/dist/lib/judge/llm-judge-otel.test.js +91 -0
  434. package/dist/lib/judge/llm-judge-otel.test.js.map +1 -0
  435. package/dist/lib/judge/llm-judge-qag.d.ts +38 -0
  436. package/dist/lib/judge/llm-judge-qag.d.ts.map +1 -0
  437. package/dist/lib/judge/llm-judge-qag.js +205 -0
  438. package/dist/lib/judge/llm-judge-qag.js.map +1 -0
  439. package/dist/lib/judge/llm-judge-qag.test.d.ts +2 -0
  440. package/dist/lib/judge/llm-judge-qag.test.d.ts.map +1 -0
  441. package/dist/lib/judge/llm-judge-qag.test.js +386 -0
  442. package/dist/lib/judge/llm-judge-qag.test.js.map +1 -0
  443. package/dist/lib/judge/llm-judge-resilience.d.ts +74 -0
  444. package/dist/lib/judge/llm-judge-resilience.d.ts.map +1 -0
  445. package/dist/lib/judge/llm-judge-resilience.js +146 -0
  446. package/dist/lib/judge/llm-judge-resilience.js.map +1 -0
  447. package/dist/lib/judge/llm-judge-resilience.test.d.ts +2 -0
  448. package/dist/lib/judge/llm-judge-resilience.test.d.ts.map +1 -0
  449. package/dist/lib/judge/llm-judge-resilience.test.js +353 -0
  450. package/dist/lib/judge/llm-judge-resilience.test.js.map +1 -0
  451. package/dist/lib/judge/llm-judge-security.d.ts +106 -0
  452. package/dist/lib/judge/llm-judge-security.d.ts.map +1 -0
  453. package/dist/lib/judge/llm-judge-security.js +314 -0
  454. package/dist/lib/judge/llm-judge-security.js.map +1 -0
  455. package/dist/lib/judge/llm-judge-security.test.d.ts +2 -0
  456. package/dist/lib/judge/llm-judge-security.test.d.ts.map +1 -0
  457. package/dist/lib/judge/llm-judge-security.test.js +1011 -0
  458. package/dist/lib/judge/llm-judge-security.test.js.map +1 -0
  459. package/dist/lib/observability/context-accumulator.d.ts +32 -0
  460. package/dist/lib/observability/context-accumulator.d.ts.map +1 -0
  461. package/dist/lib/observability/context-accumulator.js +87 -0
  462. package/dist/lib/observability/context-accumulator.js.map +1 -0
  463. package/dist/lib/observability/evaluation-events.d.ts +35 -0
  464. package/dist/lib/observability/evaluation-events.d.ts.map +1 -0
  465. package/dist/lib/observability/evaluation-events.js +90 -0
  466. package/dist/lib/observability/evaluation-events.js.map +1 -0
  467. package/dist/lib/observability/file-span-exporter.d.ts +17 -0
  468. package/dist/lib/observability/file-span-exporter.d.ts.map +1 -0
  469. package/dist/lib/observability/file-span-exporter.js +49 -0
  470. package/dist/lib/observability/file-span-exporter.js.map +1 -0
  471. package/dist/lib/observability/histogram-bucket-constants.d.ts +25 -0
  472. package/dist/lib/observability/histogram-bucket-constants.d.ts.map +1 -0
  473. package/dist/lib/observability/histogram-bucket-constants.js +60 -0
  474. package/dist/lib/observability/histogram-bucket-constants.js.map +1 -0
  475. package/dist/lib/observability/histogram.d.ts +112 -0
  476. package/dist/lib/observability/histogram.d.ts.map +1 -0
  477. package/dist/lib/observability/histogram.js +170 -0
  478. package/dist/lib/observability/histogram.js.map +1 -0
  479. package/dist/lib/observability/histogram.test.d.ts.map +1 -0
  480. package/dist/lib/observability/histogram.test.js +385 -0
  481. package/dist/lib/observability/histogram.test.js.map +1 -0
  482. package/dist/lib/observability/indexer.d.ts +114 -0
  483. package/dist/lib/observability/indexer.d.ts.map +1 -0
  484. package/dist/lib/observability/indexer.js +402 -0
  485. package/dist/lib/observability/indexer.js.map +1 -0
  486. package/dist/lib/observability/indexer.test.d.ts.map +1 -0
  487. package/dist/lib/observability/indexer.test.js +713 -0
  488. package/dist/lib/observability/indexer.test.js.map +1 -0
  489. package/dist/lib/observability/instrumentation-eval.test.d.ts +5 -0
  490. package/dist/lib/observability/instrumentation-eval.test.d.ts.map +1 -0
  491. package/dist/lib/observability/instrumentation-eval.test.js +63 -0
  492. package/dist/lib/observability/instrumentation-eval.test.js.map +1 -0
  493. package/dist/lib/observability/instrumentation-init-errors.test.d.ts +13 -0
  494. package/dist/lib/observability/instrumentation-init-errors.test.d.ts.map +1 -0
  495. package/dist/lib/observability/instrumentation-init-errors.test.js +194 -0
  496. package/dist/lib/observability/instrumentation-init-errors.test.js.map +1 -0
  497. package/dist/lib/observability/instrumentation-retry-timeout.test.d.ts +15 -0
  498. package/dist/lib/observability/instrumentation-retry-timeout.test.d.ts.map +1 -0
  499. package/dist/lib/observability/instrumentation-retry-timeout.test.js +188 -0
  500. package/dist/lib/observability/instrumentation-retry-timeout.test.js.map +1 -0
  501. package/dist/lib/observability/instrumentation-set-otel.test.d.ts +5 -0
  502. package/dist/lib/observability/instrumentation-set-otel.test.d.ts.map +1 -0
  503. package/dist/lib/observability/instrumentation-set-otel.test.js +59 -0
  504. package/dist/lib/observability/instrumentation-set-otel.test.js.map +1 -0
  505. package/dist/lib/observability/instrumentation.d.ts +158 -0
  506. package/dist/lib/observability/instrumentation.d.ts.map +1 -0
  507. package/dist/lib/observability/instrumentation.integration.test.d.ts.map +1 -0
  508. package/dist/lib/observability/instrumentation.integration.test.js +590 -0
  509. package/dist/lib/observability/instrumentation.integration.test.js.map +1 -0
  510. package/dist/lib/observability/instrumentation.js +512 -0
  511. package/dist/lib/observability/instrumentation.js.map +1 -0
  512. package/dist/lib/observability/instrumentation.test.d.ts.map +1 -0
  513. package/dist/lib/observability/instrumentation.test.js +822 -0
  514. package/dist/lib/observability/instrumentation.test.js.map +1 -0
  515. package/dist/lib/observability/mcp-semconv-constants.d.ts +98 -0
  516. package/dist/lib/observability/mcp-semconv-constants.d.ts.map +1 -0
  517. package/dist/lib/observability/mcp-semconv-constants.js +102 -0
  518. package/dist/lib/observability/mcp-semconv-constants.js.map +1 -0
  519. package/dist/lib/observability/mcp-semconv.d.ts +37 -0
  520. package/dist/lib/observability/mcp-semconv.d.ts.map +1 -0
  521. package/dist/lib/observability/mcp-semconv.js +87 -0
  522. package/dist/lib/observability/mcp-semconv.js.map +1 -0
  523. package/dist/lib/observability/mcp-semconv.test.d.ts +2 -0
  524. package/dist/lib/observability/mcp-semconv.test.d.ts.map +1 -0
  525. package/dist/lib/observability/mcp-semconv.test.js +168 -0
  526. package/dist/lib/observability/mcp-semconv.test.js.map +1 -0
  527. package/dist/lib/observability/metrics.d.ts +100 -0
  528. package/dist/lib/observability/metrics.d.ts.map +1 -0
  529. package/dist/lib/observability/metrics.js +429 -0
  530. package/dist/lib/observability/metrics.js.map +1 -0
  531. package/dist/lib/observability/metrics.test.d.ts.map +1 -0
  532. package/dist/lib/observability/metrics.test.js +191 -0
  533. package/dist/lib/observability/metrics.test.js.map +1 -0
  534. package/dist/lib/observability/observability-test-constants.d.ts +34 -0
  535. package/dist/lib/observability/observability-test-constants.d.ts.map +1 -0
  536. package/dist/lib/observability/observability-test-constants.js +55 -0
  537. package/dist/lib/observability/observability-test-constants.js.map +1 -0
  538. package/dist/lib/observability/opentelemetry-resources.test.d.ts +2 -0
  539. package/dist/lib/observability/opentelemetry-resources.test.d.ts.map +1 -0
  540. package/dist/lib/observability/opentelemetry-resources.test.js +19 -0
  541. package/dist/lib/observability/opentelemetry-resources.test.js.map +1 -0
  542. package/dist/lib/observability/parse-stats.d.ts.map +1 -0
  543. package/dist/lib/observability/parse-stats.js +207 -0
  544. package/dist/lib/observability/parse-stats.js.map +1 -0
  545. package/dist/lib/observability/parse-stats.test.d.ts.map +1 -0
  546. package/dist/lib/observability/parse-stats.test.js +287 -0
  547. package/dist/lib/observability/parse-stats.test.js.map +1 -0
  548. package/dist/lib/observability/render-trace-tree.d.ts +31 -0
  549. package/dist/lib/observability/render-trace-tree.d.ts.map +1 -0
  550. package/dist/lib/observability/render-trace-tree.js +95 -0
  551. package/dist/lib/observability/render-trace-tree.js.map +1 -0
  552. package/dist/lib/observability/render-trace-tree.test.d.ts +5 -0
  553. package/dist/lib/observability/render-trace-tree.test.d.ts.map +1 -0
  554. package/dist/lib/observability/render-trace-tree.test.js +97 -0
  555. package/dist/lib/observability/render-trace-tree.test.js.map +1 -0
  556. package/dist/lib/observability/span-attributes.d.ts +27 -0
  557. package/dist/lib/observability/span-attributes.d.ts.map +1 -0
  558. package/dist/lib/observability/span-attributes.js +85 -0
  559. package/dist/lib/observability/span-attributes.js.map +1 -0
  560. package/dist/lib/observability/trace-anomaly-detector.d.ts +23 -0
  561. package/dist/lib/observability/trace-anomaly-detector.d.ts.map +1 -0
  562. package/dist/lib/observability/trace-anomaly-detector.js +211 -0
  563. package/dist/lib/observability/trace-anomaly-detector.js.map +1 -0
  564. package/dist/lib/observability/trace-anomaly-detector.test.d.ts +5 -0
  565. package/dist/lib/observability/trace-anomaly-detector.test.d.ts.map +1 -0
  566. package/dist/lib/observability/trace-anomaly-detector.test.js +224 -0
  567. package/dist/lib/observability/trace-anomaly-detector.test.js.map +1 -0
  568. package/dist/lib/observability/trace-anomaly-schemas.d.ts +189 -0
  569. package/dist/lib/observability/trace-anomaly-schemas.d.ts.map +1 -0
  570. package/dist/lib/observability/trace-anomaly-schemas.js +167 -0
  571. package/dist/lib/observability/trace-anomaly-schemas.js.map +1 -0
  572. package/dist/lib/privacy/content-redaction.d.ts +141 -0
  573. package/dist/lib/privacy/content-redaction.d.ts.map +1 -0
  574. package/dist/lib/privacy/content-redaction.js +210 -0
  575. package/dist/lib/privacy/content-redaction.js.map +1 -0
  576. package/dist/lib/privacy/content-redaction.test.d.ts +2 -0
  577. package/dist/lib/privacy/content-redaction.test.d.ts.map +1 -0
  578. package/dist/lib/privacy/content-redaction.test.js +302 -0
  579. package/dist/lib/privacy/content-redaction.test.js.map +1 -0
  580. package/dist/lib/quality/bucket-utils.d.ts +17 -0
  581. package/dist/lib/quality/bucket-utils.d.ts.map +1 -0
  582. package/dist/lib/quality/bucket-utils.js +31 -0
  583. package/dist/lib/quality/bucket-utils.js.map +1 -0
  584. package/dist/lib/quality/bucket-utils.test.d.ts +2 -0
  585. package/dist/lib/quality/bucket-utils.test.d.ts.map +1 -0
  586. package/dist/lib/quality/bucket-utils.test.js +42 -0
  587. package/dist/lib/quality/bucket-utils.test.js.map +1 -0
  588. package/dist/lib/quality/qfe-backtest-detail.test.d.ts +5 -0
  589. package/dist/lib/quality/qfe-backtest-detail.test.d.ts.map +1 -0
  590. package/dist/lib/quality/qfe-backtest-detail.test.js +179 -0
  591. package/dist/lib/quality/qfe-backtest-detail.test.js.map +1 -0
  592. package/dist/lib/quality/qfe-calibration-paths.test.d.ts +5 -0
  593. package/dist/lib/quality/qfe-calibration-paths.test.d.ts.map +1 -0
  594. package/dist/lib/quality/qfe-calibration-paths.test.js +203 -0
  595. package/dist/lib/quality/qfe-calibration-paths.test.js.map +1 -0
  596. package/dist/lib/quality/qfe-correlation-helpers.test.d.ts +6 -0
  597. package/dist/lib/quality/qfe-correlation-helpers.test.d.ts.map +1 -0
  598. package/dist/lib/quality/qfe-correlation-helpers.test.js +143 -0
  599. package/dist/lib/quality/qfe-correlation-helpers.test.js.map +1 -0
  600. package/dist/lib/quality/qfe-cqi-paths.test.d.ts +6 -0
  601. package/dist/lib/quality/qfe-cqi-paths.test.d.ts.map +1 -0
  602. package/dist/lib/quality/qfe-cqi-paths.test.js +231 -0
  603. package/dist/lib/quality/qfe-cqi-paths.test.js.map +1 -0
  604. package/dist/lib/quality/qfe-critic-internals.test.d.ts +6 -0
  605. package/dist/lib/quality/qfe-critic-internals.test.d.ts.map +1 -0
  606. package/dist/lib/quality/qfe-critic-internals.test.js +191 -0
  607. package/dist/lib/quality/qfe-critic-internals.test.js.map +1 -0
  608. package/dist/lib/quality/qfe-derived-paths.test.d.ts +2 -0
  609. package/dist/lib/quality/qfe-derived-paths.test.d.ts.map +1 -0
  610. package/dist/lib/quality/qfe-derived-paths.test.js +372 -0
  611. package/dist/lib/quality/qfe-derived-paths.test.js.map +1 -0
  612. package/dist/lib/quality/qfe-dynamics-paths.test.d.ts +8 -0
  613. package/dist/lib/quality/qfe-dynamics-paths.test.d.ts.map +1 -0
  614. package/dist/lib/quality/qfe-dynamics-paths.test.js +223 -0
  615. package/dist/lib/quality/qfe-dynamics-paths.test.js.map +1 -0
  616. package/dist/lib/quality/qfe-granger-internals.test.d.ts +6 -0
  617. package/dist/lib/quality/qfe-granger-internals.test.d.ts.map +1 -0
  618. package/dist/lib/quality/qfe-granger-internals.test.js +158 -0
  619. package/dist/lib/quality/qfe-granger-internals.test.js.map +1 -0
  620. package/dist/lib/quality/qfe-label-normalize.test.d.ts +7 -0
  621. package/dist/lib/quality/qfe-label-normalize.test.d.ts.map +1 -0
  622. package/dist/lib/quality/qfe-label-normalize.test.js +332 -0
  623. package/dist/lib/quality/qfe-label-normalize.test.js.map +1 -0
  624. package/dist/lib/quality/qfe-ordinal-edge.test.d.ts +6 -0
  625. package/dist/lib/quality/qfe-ordinal-edge.test.d.ts.map +1 -0
  626. package/dist/lib/quality/qfe-ordinal-edge.test.js +98 -0
  627. package/dist/lib/quality/qfe-ordinal-edge.test.js.map +1 -0
  628. package/dist/lib/quality/qfe-roles-detail.test.d.ts +5 -0
  629. package/dist/lib/quality/qfe-roles-detail.test.d.ts.map +1 -0
  630. package/dist/lib/quality/qfe-roles-detail.test.js +115 -0
  631. package/dist/lib/quality/qfe-roles-detail.test.js.map +1 -0
  632. package/dist/lib/quality/qfe-rolling-detail.test.d.ts +7 -0
  633. package/dist/lib/quality/qfe-rolling-detail.test.d.ts.map +1 -0
  634. package/dist/lib/quality/qfe-rolling-detail.test.js +249 -0
  635. package/dist/lib/quality/qfe-rolling-detail.test.js.map +1 -0
  636. package/dist/lib/quality/qfe-stats-internals.test.d.ts +7 -0
  637. package/dist/lib/quality/qfe-stats-internals.test.d.ts.map +1 -0
  638. package/dist/lib/quality/qfe-stats-internals.test.js +143 -0
  639. package/dist/lib/quality/qfe-stats-internals.test.js.map +1 -0
  640. package/dist/lib/quality/qfe-streaming.test.d.ts +5 -0
  641. package/dist/lib/quality/qfe-streaming.test.d.ts.map +1 -0
  642. package/dist/lib/quality/qfe-streaming.test.js +239 -0
  643. package/dist/lib/quality/qfe-streaming.test.js.map +1 -0
  644. package/dist/lib/quality/qfe-sweep-detail.test.d.ts +6 -0
  645. package/dist/lib/quality/qfe-sweep-detail.test.d.ts.map +1 -0
  646. package/dist/lib/quality/qfe-sweep-detail.test.js +291 -0
  647. package/dist/lib/quality/qfe-sweep-detail.test.js.map +1 -0
  648. package/dist/lib/quality/quality-alerts.d.ts +23 -0
  649. package/dist/lib/quality/quality-alerts.d.ts.map +1 -0
  650. package/dist/lib/quality/quality-alerts.js +89 -0
  651. package/dist/lib/quality/quality-alerts.js.map +1 -0
  652. package/dist/lib/quality/quality-alerts.test.d.ts +2 -0
  653. package/dist/lib/quality/quality-alerts.test.d.ts.map +1 -0
  654. package/dist/lib/quality/quality-alerts.test.js +86 -0
  655. package/dist/lib/quality/quality-alerts.test.js.map +1 -0
  656. package/dist/lib/quality/quality-constants.d.ts +294 -0
  657. package/dist/lib/quality/quality-constants.d.ts.map +1 -0
  658. package/dist/lib/quality/quality-constants.js +335 -0
  659. package/dist/lib/quality/quality-constants.js.map +1 -0
  660. package/dist/lib/quality/quality-feature-engineering.d.ts +1071 -0
  661. package/dist/lib/quality/quality-feature-engineering.d.ts.map +1 -0
  662. package/dist/lib/quality/quality-feature-engineering.js +2076 -0
  663. package/dist/lib/quality/quality-feature-engineering.js.map +1 -0
  664. package/dist/lib/quality/quality-feature-engineering.test.d.ts +5 -0
  665. package/dist/lib/quality/quality-feature-engineering.test.d.ts.map +1 -0
  666. package/dist/lib/quality/quality-feature-engineering.test.js +2908 -0
  667. package/dist/lib/quality/quality-feature-engineering.test.js.map +1 -0
  668. package/dist/lib/quality/quality-metrics.d.ts +943 -0
  669. package/dist/lib/quality/quality-metrics.d.ts.map +1 -0
  670. package/dist/lib/quality/quality-metrics.js +1151 -0
  671. package/dist/lib/quality/quality-metrics.js.map +1 -0
  672. package/dist/lib/quality/quality-metrics.test.d.ts +5 -0
  673. package/dist/lib/quality/quality-metrics.test.d.ts.map +1 -0
  674. package/dist/lib/quality/quality-metrics.test.js +2766 -0
  675. package/dist/lib/quality/quality-metrics.test.js.map +1 -0
  676. package/dist/lib/quality/quality-multi-agent.d.ts +106 -0
  677. package/dist/lib/quality/quality-multi-agent.d.ts.map +1 -0
  678. package/dist/lib/quality/quality-multi-agent.js +124 -0
  679. package/dist/lib/quality/quality-multi-agent.js.map +1 -0
  680. package/dist/lib/quality/quality-multi-agent.test.d.ts +6 -0
  681. package/dist/lib/quality/quality-multi-agent.test.d.ts.map +1 -0
  682. package/dist/lib/quality/quality-multi-agent.test.js +163 -0
  683. package/dist/lib/quality/quality-multi-agent.test.js.map +1 -0
  684. package/dist/lib/quality/quality-sla.d.ts +35 -0
  685. package/dist/lib/quality/quality-sla.d.ts.map +1 -0
  686. package/dist/lib/quality/quality-sla.js +62 -0
  687. package/dist/lib/quality/quality-sla.js.map +1 -0
  688. package/dist/lib/quality/quality-sla.test.d.ts +5 -0
  689. package/dist/lib/quality/quality-sla.test.d.ts.map +1 -0
  690. package/dist/lib/quality/quality-sla.test.js +144 -0
  691. package/dist/lib/quality/quality-sla.test.js.map +1 -0
  692. package/dist/lib/quality/quality-test-constants.d.ts +23 -0
  693. package/dist/lib/quality/quality-test-constants.d.ts.map +1 -0
  694. package/dist/lib/quality/quality-test-constants.js +25 -0
  695. package/dist/lib/quality/quality-test-constants.js.map +1 -0
  696. package/dist/lib/quality/quality-trends.d.ts +101 -0
  697. package/dist/lib/quality/quality-trends.d.ts.map +1 -0
  698. package/dist/lib/quality/quality-trends.js +299 -0
  699. package/dist/lib/quality/quality-trends.js.map +1 -0
  700. package/dist/lib/quality/quality-trends.test.d.ts +6 -0
  701. package/dist/lib/quality/quality-trends.test.d.ts.map +1 -0
  702. package/dist/lib/quality/quality-trends.test.js +377 -0
  703. package/dist/lib/quality/quality-trends.test.js.map +1 -0
  704. package/dist/lib/quality/quality-views.d.ts +966 -0
  705. package/dist/lib/quality/quality-views.d.ts.map +1 -0
  706. package/dist/lib/quality/quality-views.js +367 -0
  707. package/dist/lib/quality/quality-views.js.map +1 -0
  708. package/dist/lib/quality/quality-views.test.d.ts +6 -0
  709. package/dist/lib/quality/quality-views.test.d.ts.map +1 -0
  710. package/dist/lib/quality/quality-views.test.js +262 -0
  711. package/dist/lib/quality/quality-views.test.js.map +1 -0
  712. package/dist/lib/quality/quality-visualization.d.ts +112 -0
  713. package/dist/lib/quality/quality-visualization.d.ts.map +1 -0
  714. package/dist/lib/quality/quality-visualization.js +136 -0
  715. package/dist/lib/quality/quality-visualization.js.map +1 -0
  716. package/dist/lib/quality/quality-visualization.test.d.ts +5 -0
  717. package/dist/lib/quality/quality-visualization.test.d.ts.map +1 -0
  718. package/dist/lib/quality/quality-visualization.test.js +189 -0
  719. package/dist/lib/quality/quality-visualization.test.js.map +1 -0
  720. package/dist/lib/resilience/cache.d.ts +56 -0
  721. package/dist/lib/resilience/cache.d.ts.map +1 -0
  722. package/dist/lib/resilience/cache.js +96 -0
  723. package/dist/lib/resilience/cache.js.map +1 -0
  724. package/dist/lib/resilience/cache.test.d.ts.map +1 -0
  725. package/dist/lib/resilience/cache.test.js +106 -0
  726. package/dist/lib/resilience/cache.test.js.map +1 -0
  727. package/dist/lib/resilience/circuit-breaker.d.ts +147 -0
  728. package/dist/lib/resilience/circuit-breaker.d.ts.map +1 -0
  729. package/dist/lib/resilience/circuit-breaker.js +251 -0
  730. package/dist/lib/resilience/circuit-breaker.js.map +1 -0
  731. package/dist/lib/resilience/circuit-breaker.test.d.ts.map +1 -0
  732. package/dist/lib/resilience/circuit-breaker.test.js +266 -0
  733. package/dist/lib/resilience/circuit-breaker.test.js.map +1 -0
  734. package/dist/lib/resilience/toon-encoder.d.ts +31 -0
  735. package/dist/lib/resilience/toon-encoder.d.ts.map +1 -0
  736. package/dist/lib/resilience/toon-encoder.js +66 -0
  737. package/dist/lib/resilience/toon-encoder.js.map +1 -0
  738. package/dist/lib/resilience/toon-encoder.test.d.ts.map +1 -0
  739. package/dist/lib/resilience/toon-encoder.test.js +86 -0
  740. package/dist/lib/resilience/toon-encoder.test.js.map +1 -0
  741. package/dist/lib/testing/mock-llm-builder.d.ts +139 -0
  742. package/dist/lib/testing/mock-llm-builder.d.ts.map +1 -0
  743. package/dist/lib/testing/mock-llm-builder.js +254 -0
  744. package/dist/lib/testing/mock-llm-builder.js.map +1 -0
  745. package/dist/lib/testing/mock-llm-builder.test.d.ts +5 -0
  746. package/dist/lib/testing/mock-llm-builder.test.d.ts.map +1 -0
  747. package/dist/lib/testing/mock-llm-builder.test.js +304 -0
  748. package/dist/lib/testing/mock-llm-builder.test.js.map +1 -0
  749. package/dist/lib/validation/api-schemas.d.ts +705 -0
  750. package/dist/lib/validation/api-schemas.d.ts.map +1 -0
  751. package/dist/lib/validation/api-schemas.js +351 -0
  752. package/dist/lib/validation/api-schemas.js.map +1 -0
  753. package/dist/lib/validation/api-schemas.test.d.ts +5 -0
  754. package/dist/lib/validation/api-schemas.test.d.ts.map +1 -0
  755. package/dist/lib/validation/api-schemas.test.js +427 -0
  756. package/dist/lib/validation/api-schemas.test.js.map +1 -0
  757. package/dist/lib/validation/dashboard-schemas.d.ts +203 -0
  758. package/dist/lib/validation/dashboard-schemas.d.ts.map +1 -0
  759. package/dist/lib/validation/dashboard-schemas.js +186 -0
  760. package/dist/lib/validation/dashboard-schemas.js.map +1 -0
  761. package/dist/lib/validation/dashboard-schemas.test.d.ts +5 -0
  762. package/dist/lib/validation/dashboard-schemas.test.d.ts.map +1 -0
  763. package/dist/lib/validation/dashboard-schemas.test.js +353 -0
  764. package/dist/lib/validation/dashboard-schemas.test.js.map +1 -0
  765. package/dist/server.d.ts +2 -1
  766. package/dist/server.d.ts.map +1 -1
  767. package/dist/server.js +158 -144
  768. package/dist/server.js.map +1 -1
  769. package/dist/server.test.js +102 -95
  770. package/dist/server.test.js.map +1 -1
  771. package/dist/test-helpers/assertions.d.ts +6 -0
  772. package/dist/test-helpers/assertions.d.ts.map +1 -0
  773. package/dist/test-helpers/assertions.js +11 -0
  774. package/dist/test-helpers/assertions.js.map +1 -0
  775. package/dist/test-helpers/env-utils.d.ts +0 -64
  776. package/dist/test-helpers/env-utils.d.ts.map +1 -1
  777. package/dist/test-helpers/env-utils.js +0 -100
  778. package/dist/test-helpers/env-utils.js.map +1 -1
  779. package/dist/test-helpers/fuzz-generators.d.ts.map +1 -1
  780. package/dist/test-helpers/fuzz-generators.js +62 -22
  781. package/dist/test-helpers/fuzz-generators.js.map +1 -1
  782. package/dist/test-helpers/index.d.ts +3 -2
  783. package/dist/test-helpers/index.d.ts.map +1 -1
  784. package/dist/test-helpers/index.js +4 -2
  785. package/dist/test-helpers/index.js.map +1 -1
  786. package/dist/test-helpers/memfs-utils.test.js +81 -76
  787. package/dist/test-helpers/memfs-utils.test.js.map +1 -1
  788. package/dist/test-helpers/mock-backends.d.ts +19 -17
  789. package/dist/test-helpers/mock-backends.d.ts.map +1 -1
  790. package/dist/test-helpers/mock-backends.js +16 -4
  791. package/dist/test-helpers/mock-backends.js.map +1 -1
  792. package/dist/test-helpers/mock-backends.test.js +43 -112
  793. package/dist/test-helpers/mock-backends.test.js.map +1 -1
  794. package/dist/test-helpers/race-condition-helpers.d.ts.map +1 -1
  795. package/dist/test-helpers/race-condition-helpers.js +3 -2
  796. package/dist/test-helpers/race-condition-helpers.js.map +1 -1
  797. package/dist/test-helpers/schema-validators.d.ts +2 -2
  798. package/dist/test-helpers/schema-validators.d.ts.map +1 -1
  799. package/dist/test-helpers/schema-validators.js +35 -31
  800. package/dist/test-helpers/schema-validators.js.map +1 -1
  801. package/dist/test-helpers/test-constants.d.ts +74 -0
  802. package/dist/test-helpers/test-constants.d.ts.map +1 -0
  803. package/dist/test-helpers/test-constants.js +78 -0
  804. package/dist/test-helpers/test-constants.js.map +1 -0
  805. package/dist/test-helpers/test-data-builders.d.ts +25 -7
  806. package/dist/test-helpers/test-data-builders.d.ts.map +1 -1
  807. package/dist/test-helpers/test-data-builders.js +32 -9
  808. package/dist/test-helpers/test-data-builders.js.map +1 -1
  809. package/dist/test-helpers/test-data-builders.test.js +116 -107
  810. package/dist/test-helpers/test-data-builders.test.js.map +1 -1
  811. package/dist/test-helpers/tool-validators.d.ts +1 -1
  812. package/dist/test-helpers/tool-validators.d.ts.map +1 -1
  813. package/dist/test-helpers/tool-validators.js +10 -10
  814. package/dist/test-helpers/tool-validators.js.map +1 -1
  815. package/dist/tools/audit-trail.d.ts +170 -0
  816. package/dist/tools/audit-trail.d.ts.map +1 -0
  817. package/dist/tools/audit-trail.js +109 -0
  818. package/dist/tools/audit-trail.js.map +1 -0
  819. package/dist/tools/audit-trail.test.d.ts +5 -0
  820. package/dist/tools/audit-trail.test.d.ts.map +1 -0
  821. package/dist/tools/audit-trail.test.js +122 -0
  822. package/dist/tools/audit-trail.test.js.map +1 -0
  823. package/dist/tools/context-stats.d.ts +6 -20
  824. package/dist/tools/context-stats.d.ts.map +1 -1
  825. package/dist/tools/context-stats.js +106 -88
  826. package/dist/tools/context-stats.js.map +1 -1
  827. package/dist/tools/context-stats.test.js +109 -60
  828. package/dist/tools/context-stats.test.js.map +1 -1
  829. package/dist/tools/detect-trace-anomalies.d.ts +123 -0
  830. package/dist/tools/detect-trace-anomalies.d.ts.map +1 -0
  831. package/dist/tools/detect-trace-anomalies.js +66 -0
  832. package/dist/tools/detect-trace-anomalies.js.map +1 -0
  833. package/dist/tools/estimate-cost.d.ts +77 -0
  834. package/dist/tools/estimate-cost.d.ts.map +1 -0
  835. package/dist/tools/estimate-cost.js +104 -0
  836. package/dist/tools/estimate-cost.js.map +1 -0
  837. package/dist/tools/estimate-cost.test.d.ts +5 -0
  838. package/dist/tools/estimate-cost.test.d.ts.map +1 -0
  839. package/dist/tools/estimate-cost.test.js +343 -0
  840. package/dist/tools/estimate-cost.test.js.map +1 -0
  841. package/dist/tools/export-base.d.ts +77 -0
  842. package/dist/tools/export-base.d.ts.map +1 -0
  843. package/dist/tools/export-base.js +150 -0
  844. package/dist/tools/export-base.js.map +1 -0
  845. package/dist/tools/export-base.test.d.ts +18 -0
  846. package/dist/tools/export-base.test.d.ts.map +1 -0
  847. package/dist/tools/export-base.test.js +220 -0
  848. package/dist/tools/export-base.test.js.map +1 -0
  849. package/dist/tools/export-confident.d.ts +94 -90
  850. package/dist/tools/export-confident.d.ts.map +1 -1
  851. package/dist/tools/export-confident.js +17 -115
  852. package/dist/tools/export-confident.js.map +1 -1
  853. package/dist/tools/export-confident.test.js +79 -75
  854. package/dist/tools/export-confident.test.js.map +1 -1
  855. package/dist/tools/export-datadog.d.ts +77 -116
  856. package/dist/tools/export-datadog.d.ts.map +1 -1
  857. package/dist/tools/export-datadog.js +38 -40
  858. package/dist/tools/export-datadog.js.map +1 -1
  859. package/dist/tools/export-datadog.test.js +122 -165
  860. package/dist/tools/export-datadog.test.js.map +1 -1
  861. package/dist/tools/export-jaeger.d.ts +100 -0
  862. package/dist/tools/export-jaeger.d.ts.map +1 -0
  863. package/dist/tools/export-jaeger.js +154 -0
  864. package/dist/tools/export-jaeger.js.map +1 -0
  865. package/dist/tools/export-jaeger.test.d.ts +2 -0
  866. package/dist/tools/export-jaeger.test.d.ts.map +1 -0
  867. package/dist/tools/export-jaeger.test.js +113 -0
  868. package/dist/tools/export-jaeger.test.js.map +1 -0
  869. package/dist/tools/export-langfuse.d.ts +78 -80
  870. package/dist/tools/export-langfuse.d.ts.map +1 -1
  871. package/dist/tools/export-langfuse.js +15 -113
  872. package/dist/tools/export-langfuse.js.map +1 -1
  873. package/dist/tools/export-langfuse.test.js +70 -81
  874. package/dist/tools/export-langfuse.test.js.map +1 -1
  875. package/dist/tools/export-phoenix.d.ts +115 -90
  876. package/dist/tools/export-phoenix.d.ts.map +1 -1
  877. package/dist/tools/export-phoenix.js +29 -117
  878. package/dist/tools/export-phoenix.js.map +1 -1
  879. package/dist/tools/export-phoenix.test.js +95 -94
  880. package/dist/tools/export-phoenix.test.js.map +1 -1
  881. package/dist/tools/get-trace-url.d.ts +2 -10
  882. package/dist/tools/get-trace-url.d.ts.map +1 -1
  883. package/dist/tools/get-trace-url.js +5 -8
  884. package/dist/tools/get-trace-url.js.map +1 -1
  885. package/dist/tools/get-trace-url.test.js +81 -399
  886. package/dist/tools/get-trace-url.test.js.map +1 -1
  887. package/dist/tools/hallucination-detection.d.ts +203 -0
  888. package/dist/tools/hallucination-detection.d.ts.map +1 -0
  889. package/dist/tools/hallucination-detection.js +189 -0
  890. package/dist/tools/hallucination-detection.js.map +1 -0
  891. package/dist/tools/hallucination-detection.test.d.ts +5 -0
  892. package/dist/tools/hallucination-detection.test.d.ts.map +1 -0
  893. package/dist/tools/hallucination-detection.test.js +529 -0
  894. package/dist/tools/hallucination-detection.test.js.map +1 -0
  895. package/dist/tools/health-check.d.ts +9 -16
  896. package/dist/tools/health-check.d.ts.map +1 -1
  897. package/dist/tools/health-check.js +88 -101
  898. package/dist/tools/health-check.js.map +1 -1
  899. package/dist/tools/health-check.test.js +72 -165
  900. package/dist/tools/health-check.test.js.map +1 -1
  901. package/dist/tools/index.d.ts +13 -0
  902. package/dist/tools/index.d.ts.map +1 -1
  903. package/dist/tools/index.js +13 -0
  904. package/dist/tools/index.js.map +1 -1
  905. package/dist/tools/ingest-constants.d.ts +8 -0
  906. package/dist/tools/ingest-constants.d.ts.map +1 -0
  907. package/dist/tools/ingest-constants.js +8 -0
  908. package/dist/tools/ingest-constants.js.map +1 -0
  909. package/dist/tools/ingest-spans.d.ts +45 -0
  910. package/dist/tools/ingest-spans.d.ts.map +1 -0
  911. package/dist/tools/ingest-spans.js +129 -0
  912. package/dist/tools/ingest-spans.js.map +1 -0
  913. package/dist/tools/ingest-spans.test.d.ts +5 -0
  914. package/dist/tools/ingest-spans.test.d.ts.map +1 -0
  915. package/dist/tools/ingest-spans.test.js +250 -0
  916. package/dist/tools/ingest-spans.test.js.map +1 -0
  917. package/dist/tools/ingest-traces.d.ts +76 -0
  918. package/dist/tools/ingest-traces.d.ts.map +1 -0
  919. package/dist/tools/ingest-traces.js +164 -0
  920. package/dist/tools/ingest-traces.js.map +1 -0
  921. package/dist/tools/ingest-traces.test.d.ts +5 -0
  922. package/dist/tools/ingest-traces.test.d.ts.map +1 -0
  923. package/dist/tools/ingest-traces.test.js +483 -0
  924. package/dist/tools/ingest-traces.test.js.map +1 -0
  925. package/dist/tools/inject-evaluations.d.ts +136 -1197
  926. package/dist/tools/inject-evaluations.d.ts.map +1 -1
  927. package/dist/tools/inject-evaluations.js +65 -53
  928. package/dist/tools/inject-evaluations.js.map +1 -1
  929. package/dist/tools/inject-evaluations.test.js +83 -71
  930. package/dist/tools/inject-evaluations.test.js.map +1 -1
  931. package/dist/tools/manage-datasets.d.ts +850 -0
  932. package/dist/tools/manage-datasets.d.ts.map +1 -0
  933. package/dist/tools/manage-datasets.js +139 -0
  934. package/dist/tools/manage-datasets.js.map +1 -0
  935. package/dist/tools/manage-datasets.test.d.ts +5 -0
  936. package/dist/tools/manage-datasets.test.d.ts.map +1 -0
  937. package/dist/tools/manage-datasets.test.js +430 -0
  938. package/dist/tools/manage-datasets.test.js.map +1 -0
  939. package/dist/tools/multi-agent-coordination.d.ts +178 -0
  940. package/dist/tools/multi-agent-coordination.d.ts.map +1 -0
  941. package/dist/tools/multi-agent-coordination.js +270 -0
  942. package/dist/tools/multi-agent-coordination.js.map +1 -0
  943. package/dist/tools/multi-agent-coordination.test.d.ts +5 -0
  944. package/dist/tools/multi-agent-coordination.test.d.ts.map +1 -0
  945. package/dist/tools/multi-agent-coordination.test.js +530 -0
  946. package/dist/tools/multi-agent-coordination.test.js.map +1 -0
  947. package/dist/tools/query-evaluations.d.ts +147 -105
  948. package/dist/tools/query-evaluations.d.ts.map +1 -1
  949. package/dist/tools/query-evaluations.js +205 -178
  950. package/dist/tools/query-evaluations.js.map +1 -1
  951. package/dist/tools/query-evaluations.test.js +386 -391
  952. package/dist/tools/query-evaluations.test.js.map +1 -1
  953. package/dist/tools/query-llm-events.d.ts +100 -75
  954. package/dist/tools/query-llm-events.d.ts.map +1 -1
  955. package/dist/tools/query-llm-events.js +106 -80
  956. package/dist/tools/query-llm-events.js.map +1 -1
  957. package/dist/tools/query-llm-events.test.js +183 -346
  958. package/dist/tools/query-llm-events.test.js.map +1 -1
  959. package/dist/tools/query-logs.d.ts +45 -58
  960. package/dist/tools/query-logs.d.ts.map +1 -1
  961. package/dist/tools/query-logs.js +54 -101
  962. package/dist/tools/query-logs.js.map +1 -1
  963. package/dist/tools/query-logs.test.js +118 -314
  964. package/dist/tools/query-logs.test.js.map +1 -1
  965. package/dist/tools/query-metric-histograms.d.ts +112 -0
  966. package/dist/tools/query-metric-histograms.d.ts.map +1 -0
  967. package/dist/tools/query-metric-histograms.js +69 -0
  968. package/dist/tools/query-metric-histograms.js.map +1 -0
  969. package/dist/tools/query-metric-histograms.test.d.ts +5 -0
  970. package/dist/tools/query-metric-histograms.test.d.ts.map +1 -0
  971. package/dist/tools/query-metric-histograms.test.js +209 -0
  972. package/dist/tools/query-metric-histograms.test.js.map +1 -0
  973. package/dist/tools/query-metrics.d.ts +159 -60
  974. package/dist/tools/query-metrics.d.ts.map +1 -1
  975. package/dist/tools/query-metrics.js +133 -111
  976. package/dist/tools/query-metrics.js.map +1 -1
  977. package/dist/tools/query-metrics.test.js +314 -389
  978. package/dist/tools/query-metrics.test.js.map +1 -1
  979. package/dist/tools/query-regressions.d.ts +76 -0
  980. package/dist/tools/query-regressions.d.ts.map +1 -0
  981. package/dist/tools/query-regressions.js +122 -0
  982. package/dist/tools/query-regressions.js.map +1 -0
  983. package/dist/tools/query-regressions.test.d.ts +8 -0
  984. package/dist/tools/query-regressions.test.d.ts.map +1 -0
  985. package/dist/tools/query-regressions.test.js +129 -0
  986. package/dist/tools/query-regressions.test.js.map +1 -0
  987. package/dist/tools/query-traces.d.ts +103 -71
  988. package/dist/tools/query-traces.d.ts.map +1 -1
  989. package/dist/tools/query-traces.js +75 -106
  990. package/dist/tools/query-traces.js.map +1 -1
  991. package/dist/tools/query-traces.test.js +140 -846
  992. package/dist/tools/query-traces.test.js.map +1 -1
  993. package/dist/tools/query-verifications.d.ts +55 -43
  994. package/dist/tools/query-verifications.d.ts.map +1 -1
  995. package/dist/tools/query-verifications.js +47 -46
  996. package/dist/tools/query-verifications.js.map +1 -1
  997. package/dist/tools/query-verifications.test.js +42 -35
  998. package/dist/tools/query-verifications.test.js.map +1 -1
  999. package/dist/tools/routing-telemetry.d.ts +168 -0
  1000. package/dist/tools/routing-telemetry.d.ts.map +1 -0
  1001. package/dist/tools/routing-telemetry.js +267 -0
  1002. package/dist/tools/routing-telemetry.js.map +1 -0
  1003. package/dist/tools/routing-telemetry.test.d.ts +5 -0
  1004. package/dist/tools/routing-telemetry.test.d.ts.map +1 -0
  1005. package/dist/tools/routing-telemetry.test.js +747 -0
  1006. package/dist/tools/routing-telemetry.test.js.map +1 -0
  1007. package/dist/tools/setup-claudeignore.d.ts +4 -32
  1008. package/dist/tools/setup-claudeignore.d.ts.map +1 -1
  1009. package/dist/tools/setup-claudeignore.js +18 -22
  1010. package/dist/tools/setup-claudeignore.js.map +1 -1
  1011. package/dist/tools/setup-claudeignore.test.js +50 -49
  1012. package/dist/tools/setup-claudeignore.test.js.map +1 -1
  1013. package/dist/tools/token-budget.d.ts +170 -0
  1014. package/dist/tools/token-budget.d.ts.map +1 -0
  1015. package/dist/tools/token-budget.js +219 -0
  1016. package/dist/tools/token-budget.js.map +1 -0
  1017. package/dist/tools/token-budget.test.d.ts +5 -0
  1018. package/dist/tools/token-budget.test.d.ts.map +1 -0
  1019. package/dist/tools/token-budget.test.js +293 -0
  1020. package/dist/tools/token-budget.test.js.map +1 -0
  1021. package/package.json +72 -10
  1022. package/dist/backends/local-jsonl.test.d.ts +0 -2
  1023. package/dist/backends/local-jsonl.test.d.ts.map +0 -1
  1024. package/dist/backends/local-jsonl.test.js +0 -4651
  1025. package/dist/backends/local-jsonl.test.js.map +0 -1
  1026. package/dist/backends/signoz-api-circuit-breaker.test.d.ts +0 -6
  1027. package/dist/backends/signoz-api-circuit-breaker.test.d.ts.map +0 -1
  1028. package/dist/backends/signoz-api-circuit-breaker.test.js +0 -548
  1029. package/dist/backends/signoz-api-circuit-breaker.test.js.map +0 -1
  1030. package/dist/backends/signoz-api-rate-limiter.test.d.ts +0 -6
  1031. package/dist/backends/signoz-api-rate-limiter.test.d.ts.map +0 -1
  1032. package/dist/backends/signoz-api-rate-limiter.test.js +0 -390
  1033. package/dist/backends/signoz-api-rate-limiter.test.js.map +0 -1
  1034. package/dist/backends/signoz-api-ssrf.test.d.ts +0 -6
  1035. package/dist/backends/signoz-api-ssrf.test.d.ts.map +0 -1
  1036. package/dist/backends/signoz-api-ssrf.test.js +0 -216
  1037. package/dist/backends/signoz-api-ssrf.test.js.map +0 -1
  1038. package/dist/backends/signoz-api-test-helpers.d.ts +0 -80
  1039. package/dist/backends/signoz-api-test-helpers.d.ts.map +0 -1
  1040. package/dist/backends/signoz-api-test-helpers.js +0 -79
  1041. package/dist/backends/signoz-api-test-helpers.js.map +0 -1
  1042. package/dist/backends/signoz-api.d.ts +0 -109
  1043. package/dist/backends/signoz-api.d.ts.map +0 -1
  1044. package/dist/backends/signoz-api.integration.test.d.ts +0 -8
  1045. package/dist/backends/signoz-api.integration.test.d.ts.map +0 -1
  1046. package/dist/backends/signoz-api.integration.test.js +0 -137
  1047. package/dist/backends/signoz-api.integration.test.js.map +0 -1
  1048. package/dist/backends/signoz-api.js +0 -1132
  1049. package/dist/backends/signoz-api.js.map +0 -1
  1050. package/dist/backends/signoz-api.test.d.ts +0 -11
  1051. package/dist/backends/signoz-api.test.d.ts.map +0 -1
  1052. package/dist/backends/signoz-api.test.js +0 -832
  1053. package/dist/backends/signoz-api.test.js.map +0 -1
  1054. package/dist/lib/agent-as-judge.d.ts +0 -388
  1055. package/dist/lib/agent-as-judge.d.ts.map +0 -1
  1056. package/dist/lib/agent-as-judge.js +0 -740
  1057. package/dist/lib/agent-as-judge.js.map +0 -1
  1058. package/dist/lib/agent-as-judge.test.d.ts.map +0 -1
  1059. package/dist/lib/agent-as-judge.test.js +0 -816
  1060. package/dist/lib/agent-as-judge.test.js.map +0 -1
  1061. package/dist/lib/cache.d.ts +0 -90
  1062. package/dist/lib/cache.d.ts.map +0 -1
  1063. package/dist/lib/cache.js +0 -133
  1064. package/dist/lib/cache.js.map +0 -1
  1065. package/dist/lib/cache.test.d.ts.map +0 -1
  1066. package/dist/lib/cache.test.js +0 -105
  1067. package/dist/lib/cache.test.js.map +0 -1
  1068. package/dist/lib/circuit-breaker.d.ts +0 -101
  1069. package/dist/lib/circuit-breaker.d.ts.map +0 -1
  1070. package/dist/lib/circuit-breaker.js +0 -158
  1071. package/dist/lib/circuit-breaker.js.map +0 -1
  1072. package/dist/lib/circuit-breaker.test.d.ts.map +0 -1
  1073. package/dist/lib/circuit-breaker.test.js +0 -263
  1074. package/dist/lib/circuit-breaker.test.js.map +0 -1
  1075. package/dist/lib/confident-export.d.ts +0 -101
  1076. package/dist/lib/confident-export.d.ts.map +0 -1
  1077. package/dist/lib/confident-export.js +0 -393
  1078. package/dist/lib/confident-export.js.map +0 -1
  1079. package/dist/lib/confident-export.test.d.ts.map +0 -1
  1080. package/dist/lib/confident-export.test.js +0 -835
  1081. package/dist/lib/confident-export.test.js.map +0 -1
  1082. package/dist/lib/constants-symlink.test.d.ts.map +0 -1
  1083. package/dist/lib/constants-symlink.test.js +0 -357
  1084. package/dist/lib/constants-symlink.test.js.map +0 -1
  1085. package/dist/lib/constants.d.ts +0 -183
  1086. package/dist/lib/constants.d.ts.map +0 -1
  1087. package/dist/lib/constants.js +0 -453
  1088. package/dist/lib/constants.js.map +0 -1
  1089. package/dist/lib/constants.test.d.ts.map +0 -1
  1090. package/dist/lib/constants.test.js +0 -717
  1091. package/dist/lib/constants.test.js.map +0 -1
  1092. package/dist/lib/datadog-export.d.ts +0 -156
  1093. package/dist/lib/datadog-export.d.ts.map +0 -1
  1094. package/dist/lib/datadog-export.js +0 -464
  1095. package/dist/lib/datadog-export.js.map +0 -1
  1096. package/dist/lib/datadog-export.test.d.ts +0 -14
  1097. package/dist/lib/datadog-export.test.d.ts.map +0 -1
  1098. package/dist/lib/datadog-export.test.js +0 -890
  1099. package/dist/lib/datadog-export.test.js.map +0 -1
  1100. package/dist/lib/edge-cases.test.d.ts.map +0 -1
  1101. package/dist/lib/edge-cases.test.js +0 -634
  1102. package/dist/lib/edge-cases.test.js.map +0 -1
  1103. package/dist/lib/error-sanitizer.d.ts +0 -57
  1104. package/dist/lib/error-sanitizer.d.ts.map +0 -1
  1105. package/dist/lib/error-sanitizer.js +0 -233
  1106. package/dist/lib/error-sanitizer.js.map +0 -1
  1107. package/dist/lib/error-sanitizer.test.d.ts.map +0 -1
  1108. package/dist/lib/error-sanitizer.test.js +0 -528
  1109. package/dist/lib/error-sanitizer.test.js.map +0 -1
  1110. package/dist/lib/error-types.d.ts +0 -54
  1111. package/dist/lib/error-types.d.ts.map +0 -1
  1112. package/dist/lib/error-types.js +0 -154
  1113. package/dist/lib/error-types.js.map +0 -1
  1114. package/dist/lib/error-types.test.d.ts.map +0 -1
  1115. package/dist/lib/error-types.test.js +0 -196
  1116. package/dist/lib/error-types.test.js.map +0 -1
  1117. package/dist/lib/evaluation-hooks.d.ts +0 -49
  1118. package/dist/lib/evaluation-hooks.d.ts.map +0 -1
  1119. package/dist/lib/evaluation-hooks.js +0 -488
  1120. package/dist/lib/evaluation-hooks.js.map +0 -1
  1121. package/dist/lib/evaluation-hooks.test.d.ts.map +0 -1
  1122. package/dist/lib/evaluation-hooks.test.js +0 -624
  1123. package/dist/lib/evaluation-hooks.test.js.map +0 -1
  1124. package/dist/lib/export-utils.d.ts +0 -99
  1125. package/dist/lib/export-utils.d.ts.map +0 -1
  1126. package/dist/lib/export-utils.js +0 -238
  1127. package/dist/lib/export-utils.js.map +0 -1
  1128. package/dist/lib/export-utils.test.d.ts.map +0 -1
  1129. package/dist/lib/export-utils.test.js +0 -193
  1130. package/dist/lib/export-utils.test.js.map +0 -1
  1131. package/dist/lib/file-utils.d.ts +0 -320
  1132. package/dist/lib/file-utils.d.ts.map +0 -1
  1133. package/dist/lib/file-utils.js +0 -816
  1134. package/dist/lib/file-utils.js.map +0 -1
  1135. package/dist/lib/file-utils.test.d.ts.map +0 -1
  1136. package/dist/lib/file-utils.test.js +0 -1333
  1137. package/dist/lib/file-utils.test.js.map +0 -1
  1138. package/dist/lib/histogram.d.ts +0 -119
  1139. package/dist/lib/histogram.d.ts.map +0 -1
  1140. package/dist/lib/histogram.js +0 -202
  1141. package/dist/lib/histogram.js.map +0 -1
  1142. package/dist/lib/histogram.test.d.ts.map +0 -1
  1143. package/dist/lib/histogram.test.js +0 -381
  1144. package/dist/lib/histogram.test.js.map +0 -1
  1145. package/dist/lib/indexer.d.ts +0 -96
  1146. package/dist/lib/indexer.d.ts.map +0 -1
  1147. package/dist/lib/indexer.js +0 -353
  1148. package/dist/lib/indexer.js.map +0 -1
  1149. package/dist/lib/indexer.test.d.ts.map +0 -1
  1150. package/dist/lib/indexer.test.js +0 -696
  1151. package/dist/lib/indexer.test.js.map +0 -1
  1152. package/dist/lib/input-validator.d.ts +0 -115
  1153. package/dist/lib/input-validator.d.ts.map +0 -1
  1154. package/dist/lib/input-validator.fuzz.test.d.ts.map +0 -1
  1155. package/dist/lib/input-validator.fuzz.test.js +0 -290
  1156. package/dist/lib/input-validator.fuzz.test.js.map +0 -1
  1157. package/dist/lib/input-validator.js +0 -304
  1158. package/dist/lib/input-validator.js.map +0 -1
  1159. package/dist/lib/input-validator.test.d.ts.map +0 -1
  1160. package/dist/lib/input-validator.test.js +0 -415
  1161. package/dist/lib/input-validator.test.js.map +0 -1
  1162. package/dist/lib/instrumentation.d.ts +0 -153
  1163. package/dist/lib/instrumentation.d.ts.map +0 -1
  1164. package/dist/lib/instrumentation.integration.test.d.ts.map +0 -1
  1165. package/dist/lib/instrumentation.integration.test.js +0 -589
  1166. package/dist/lib/instrumentation.integration.test.js.map +0 -1
  1167. package/dist/lib/instrumentation.js +0 -520
  1168. package/dist/lib/instrumentation.js.map +0 -1
  1169. package/dist/lib/instrumentation.test.d.ts.map +0 -1
  1170. package/dist/lib/instrumentation.test.js +0 -821
  1171. package/dist/lib/instrumentation.test.js.map +0 -1
  1172. package/dist/lib/langfuse-export.d.ts +0 -125
  1173. package/dist/lib/langfuse-export.d.ts.map +0 -1
  1174. package/dist/lib/langfuse-export.js +0 -367
  1175. package/dist/lib/langfuse-export.js.map +0 -1
  1176. package/dist/lib/langfuse-export.test.d.ts.map +0 -1
  1177. package/dist/lib/langfuse-export.test.js +0 -1007
  1178. package/dist/lib/langfuse-export.test.js.map +0 -1
  1179. package/dist/lib/llm-as-judge.d.ts +0 -657
  1180. package/dist/lib/llm-as-judge.d.ts.map +0 -1
  1181. package/dist/lib/llm-as-judge.js +0 -1397
  1182. package/dist/lib/llm-as-judge.js.map +0 -1
  1183. package/dist/lib/llm-as-judge.test.d.ts.map +0 -1
  1184. package/dist/lib/llm-as-judge.test.js +0 -2409
  1185. package/dist/lib/llm-as-judge.test.js.map +0 -1
  1186. package/dist/lib/logger.d.ts +0 -46
  1187. package/dist/lib/logger.d.ts.map +0 -1
  1188. package/dist/lib/logger.js +0 -81
  1189. package/dist/lib/logger.js.map +0 -1
  1190. package/dist/lib/logger.test.d.ts.map +0 -1
  1191. package/dist/lib/logger.test.js.map +0 -1
  1192. package/dist/lib/metrics.d.ts +0 -62
  1193. package/dist/lib/metrics.d.ts.map +0 -1
  1194. package/dist/lib/metrics.js +0 -166
  1195. package/dist/lib/metrics.js.map +0 -1
  1196. package/dist/lib/metrics.test.d.ts.map +0 -1
  1197. package/dist/lib/metrics.test.js +0 -189
  1198. package/dist/lib/metrics.test.js.map +0 -1
  1199. package/dist/lib/otlp-export.d.ts +0 -178
  1200. package/dist/lib/otlp-export.d.ts.map +0 -1
  1201. package/dist/lib/otlp-export.js +0 -382
  1202. package/dist/lib/otlp-export.js.map +0 -1
  1203. package/dist/lib/parse-stats.d.ts.map +0 -1
  1204. package/dist/lib/parse-stats.js +0 -206
  1205. package/dist/lib/parse-stats.js.map +0 -1
  1206. package/dist/lib/parse-stats.test.d.ts.map +0 -1
  1207. package/dist/lib/parse-stats.test.js +0 -283
  1208. package/dist/lib/parse-stats.test.js.map +0 -1
  1209. package/dist/lib/phoenix-export.d.ts +0 -109
  1210. package/dist/lib/phoenix-export.d.ts.map +0 -1
  1211. package/dist/lib/phoenix-export.js +0 -429
  1212. package/dist/lib/phoenix-export.js.map +0 -1
  1213. package/dist/lib/phoenix-export.test.d.ts.map +0 -1
  1214. package/dist/lib/phoenix-export.test.js +0 -725
  1215. package/dist/lib/phoenix-export.test.js.map +0 -1
  1216. package/dist/lib/query-sanitizer.d.ts.map +0 -1
  1217. package/dist/lib/query-sanitizer.js +0 -261
  1218. package/dist/lib/query-sanitizer.js.map +0 -1
  1219. package/dist/lib/query-sanitizer.test.d.ts.map +0 -1
  1220. package/dist/lib/query-sanitizer.test.js +0 -400
  1221. package/dist/lib/query-sanitizer.test.js.map +0 -1
  1222. package/dist/lib/server-utils.d.ts +0 -93
  1223. package/dist/lib/server-utils.d.ts.map +0 -1
  1224. package/dist/lib/server-utils.js +0 -181
  1225. package/dist/lib/server-utils.js.map +0 -1
  1226. package/dist/lib/shared-schemas.d.ts +0 -87
  1227. package/dist/lib/shared-schemas.d.ts.map +0 -1
  1228. package/dist/lib/shared-schemas.js +0 -87
  1229. package/dist/lib/shared-schemas.js.map +0 -1
  1230. package/dist/lib/shared-schemas.test.d.ts.map +0 -1
  1231. package/dist/lib/shared-schemas.test.js +0 -106
  1232. package/dist/lib/shared-schemas.test.js.map +0 -1
  1233. package/dist/lib/toon-encoder.d.ts +0 -26
  1234. package/dist/lib/toon-encoder.d.ts.map +0 -1
  1235. package/dist/lib/toon-encoder.js +0 -61
  1236. package/dist/lib/toon-encoder.js.map +0 -1
  1237. package/dist/lib/toon-encoder.test.d.ts.map +0 -1
  1238. package/dist/lib/toon-encoder.test.js +0 -85
  1239. package/dist/lib/toon-encoder.test.js.map +0 -1
  1240. package/dist/lib/verification-events.d.ts +0 -100
  1241. package/dist/lib/verification-events.d.ts.map +0 -1
  1242. package/dist/lib/verification-events.js +0 -162
  1243. package/dist/lib/verification-events.js.map +0 -1
  1244. package/dist/lib/verification-events.test.d.ts.map +0 -1
  1245. package/dist/lib/verification-events.test.js +0 -193
  1246. package/dist/lib/verification-events.test.js.map +0 -1
  1247. package/dist/tools/signoz.integration.test.d.ts +0 -8
  1248. package/dist/tools/signoz.integration.test.d.ts.map +0 -1
  1249. package/dist/tools/signoz.integration.test.js +0 -141
  1250. package/dist/tools/signoz.integration.test.js.map +0 -1
  1251. package/dist/types/evaluation-hooks.d.ts +0 -176
  1252. package/dist/types/evaluation-hooks.d.ts.map +0 -1
  1253. package/dist/types/evaluation-hooks.js +0 -49
  1254. package/dist/types/evaluation-hooks.js.map +0 -1
  1255. /package/dist/lib/{agent-as-judge.test.d.ts → agent-judge/agent-as-judge.test.d.ts} +0 -0
  1256. /package/dist/lib/{verification-events.test.d.ts → audit/verification-events.test.d.ts} +0 -0
  1257. /package/dist/lib/{constants-symlink.test.d.ts → core/constants-symlink.test.d.ts} +0 -0
  1258. /package/dist/lib/{constants.test.d.ts → core/constants.test.d.ts} +0 -0
  1259. /package/dist/lib/{edge-cases.test.d.ts → core/edge-cases.test.d.ts} +0 -0
  1260. /package/dist/lib/{file-utils.test.d.ts → core/file-utils.test.d.ts} +0 -0
  1261. /package/dist/lib/{input-validator.fuzz.test.d.ts → core/input-validator.fuzz.test.d.ts} +0 -0
  1262. /package/dist/lib/{input-validator.test.d.ts → core/input-validator.test.d.ts} +0 -0
  1263. /package/dist/lib/{logger.test.d.ts → core/logger.test.d.ts} +0 -0
  1264. /package/dist/lib/{logger.test.js → core/logger.test.js} +0 -0
  1265. /package/dist/lib/{shared-schemas.test.d.ts → core/shared-schemas.test.d.ts} +0 -0
  1266. /package/dist/lib/{error-sanitizer.test.d.ts → errors/error-sanitizer.test.d.ts} +0 -0
  1267. /package/dist/lib/{error-types.test.d.ts → errors/error-types.test.d.ts} +0 -0
  1268. /package/dist/lib/{query-sanitizer.d.ts → errors/query-sanitizer.d.ts} +0 -0
  1269. /package/dist/lib/{query-sanitizer.test.d.ts → errors/query-sanitizer.test.d.ts} +0 -0
  1270. /package/dist/lib/{confident-export.test.d.ts → exports/confident-export.test.d.ts} +0 -0
  1271. /package/dist/lib/{export-utils.test.d.ts → exports/export-utils.test.d.ts} +0 -0
  1272. /package/dist/lib/{langfuse-export.test.d.ts → exports/langfuse-export.test.d.ts} +0 -0
  1273. /package/dist/lib/{phoenix-export.test.d.ts → exports/phoenix-export.test.d.ts} +0 -0
  1274. /package/dist/lib/{evaluation-hooks.test.d.ts → judge/evaluation-hooks.test.d.ts} +0 -0
  1275. /package/dist/lib/{llm-as-judge.test.d.ts → judge/llm-as-judge.test.d.ts} +0 -0
  1276. /package/dist/lib/{histogram.test.d.ts → observability/histogram.test.d.ts} +0 -0
  1277. /package/dist/lib/{indexer.test.d.ts → observability/indexer.test.d.ts} +0 -0
  1278. /package/dist/lib/{instrumentation.integration.test.d.ts → observability/instrumentation.integration.test.d.ts} +0 -0
  1279. /package/dist/lib/{instrumentation.test.d.ts → observability/instrumentation.test.d.ts} +0 -0
  1280. /package/dist/lib/{metrics.test.d.ts → observability/metrics.test.d.ts} +0 -0
  1281. /package/dist/lib/{parse-stats.d.ts → observability/parse-stats.d.ts} +0 -0
  1282. /package/dist/lib/{parse-stats.test.d.ts → observability/parse-stats.test.d.ts} +0 -0
  1283. /package/dist/lib/{cache.test.d.ts → resilience/cache.test.d.ts} +0 -0
  1284. /package/dist/lib/{circuit-breaker.test.d.ts → resilience/circuit-breaker.test.d.ts} +0 -0
  1285. /package/dist/lib/{toon-encoder.test.d.ts → resilience/toon-encoder.test.d.ts} +0 -0
@@ -0,0 +1,747 @@
1
+ /**
2
+ * Unit tests for routing-telemetry tool (R8)
3
+ */
4
+ import { describe, it } from 'vitest';
5
+ import assert from 'node:assert';
6
+ import { ROUTING_ATTRIBUTES } from '../backends/index.js';
7
+ import { createTraceBackend } from '../test-helpers/mock-backends.js';
8
+ import { routingTelemetry, routingTelemetrySchema, ROUTING_TELEMETRY_DEFAULT_LIMIT } from './routing-telemetry.js';
9
+ import { ONE_MILLION, ROUND_4DP_FACTOR } from '../lib/core/units.js';
10
+ import { MODEL_PRICING } from '../lib/core/constants-models.js';
11
+ import { SHORT_ID_LENGTH } from '../lib/core/constants.js';
12
+ import { RANDOM_STRING_RADIX, RANDOM_SUFFIX_START } from '../test-helpers/test-constants.js';
13
+ // ---------- test constants ----------
14
+ const ID_SLICE_START = RANDOM_SUFFIX_START;
15
+ const ID_SLICE_END = SHORT_ID_LENGTH;
16
+ const SPAN_DURATION_MS = 100;
17
+ const CLASSIFICATION_TIME_MS = 42;
18
+ // model fixtures
19
+ const MODEL_AUTO = 'auto';
20
+ const MODEL_GPT4O = 'gpt-4o';
21
+ const MODEL_GPT4O_MINI = 'gpt-4o-mini';
22
+ const MODEL_CLAUDE_OPUS = 'claude-opus-4-6';
23
+ const MODEL_CLAUDE_HAIKU = 'claude-haiku-4-5-20251001';
24
+ // token fixtures
25
+ const INPUT_TOKENS_SMALL = 1_000;
26
+ const OUTPUT_TOKENS_SMALL = 200;
27
+ const INPUT_TOKENS_LARGE = 5_000;
28
+ const OUTPUT_TOKENS_LARGE = 1_000;
29
+ // routing attribute fixtures
30
+ const STRATEGY_COST = 'cost_optimized';
31
+ const STRATEGY_PERF = 'performance';
32
+ // expected counts
33
+ const EXPECTED_ONE = 1;
34
+ const EXPECTED_TWO = 2;
35
+ const EXPECTED_THREE = 3;
36
+ // expected fallback rate (1 out of 2 = 0.5)
37
+ const EXPECTED_FALLBACK_RATE_HALF = 0.5;
38
+ const EXPECTED_FULL_FALLBACK_RATE = 1;
39
+ // ---------- helpers ----------
40
+ function makeSpan(overrides) {
41
+ const duration = overrides.durationMs ?? SPAN_DURATION_MS;
42
+ return {
43
+ traceId: overrides.traceId ?? 'trace-1',
44
+ spanId: `span-${Math.random().toString(RANDOM_STRING_RADIX).slice(ID_SLICE_START, ID_SLICE_END)}`,
45
+ name: 'chat',
46
+ startTimeUnixNano: Date.now() * ONE_MILLION,
47
+ endTimeUnixNano: (Date.now() + duration) * ONE_MILLION,
48
+ durationMs: duration,
49
+ attributes: {
50
+ 'gen_ai.request.model': overrides.requestModel,
51
+ ...(overrides.responseModel !== undefined && {
52
+ 'gen_ai.response.model': overrides.responseModel,
53
+ }),
54
+ ...(overrides.inputTokens !== undefined && {
55
+ 'gen_ai.usage.input_tokens': overrides.inputTokens,
56
+ }),
57
+ ...(overrides.outputTokens !== undefined && {
58
+ 'gen_ai.usage.output_tokens': overrides.outputTokens,
59
+ }),
60
+ ...(overrides.strategy !== undefined && {
61
+ 'routing.strategy': overrides.strategy,
62
+ }),
63
+ ...(overrides.fallbackTriggered !== undefined && {
64
+ 'routing.fallback_triggered': overrides.fallbackTriggered,
65
+ }),
66
+ ...(overrides.classificationTimeMs !== undefined && {
67
+ 'routing.classification.time_ms': overrides.classificationTimeMs,
68
+ }),
69
+ ...(overrides.finishReasons !== undefined && {
70
+ 'gen_ai.response.finish_reasons': overrides.finishReasons,
71
+ }),
72
+ ...(overrides.provider !== undefined && {
73
+ 'gen_ai.provider.name': overrides.provider,
74
+ }),
75
+ ...(overrides.system !== undefined && {
76
+ 'gen_ai.system': overrides.system,
77
+ }),
78
+ },
79
+ };
80
+ }
81
+ function makeBackend(spans) {
82
+ const store = { local: spans };
83
+ return createTraceBackend(store, 'local');
84
+ }
85
+ function isNoData(r) {
86
+ return r.kind === 'no-data';
87
+ }
88
+ function isResult(r) {
89
+ return r.kind === 'result';
90
+ }
91
+ // ---------- schema ----------
92
+ void describe('routingTelemetrySchema', () => {
93
+ void it('should accept empty input with defaults', () => {
94
+ const result = routingTelemetrySchema.parse({});
95
+ assert.strictEqual(result.backend, 'cloud');
96
+ assert.strictEqual(result.groupBy, 'model_pair');
97
+ assert.strictEqual(result.limit, ROUTING_TELEMETRY_DEFAULT_LIMIT);
98
+ });
99
+ void it('should accept groupBy strategy', () => {
100
+ const result = routingTelemetrySchema.parse({ groupBy: 'strategy' });
101
+ assert.strictEqual(result.groupBy, 'strategy');
102
+ });
103
+ void it('should reject invalid groupBy value', () => {
104
+ assert.throws(() => routingTelemetrySchema.parse({ groupBy: 'invalid' }));
105
+ });
106
+ void it('should accept optional model filter', () => {
107
+ const result = routingTelemetrySchema.parse({ model: MODEL_GPT4O });
108
+ assert.strictEqual(result.model, MODEL_GPT4O);
109
+ });
110
+ void it('should accept startDate and endDate filters', () => {
111
+ const result = routingTelemetrySchema.parse({
112
+ startDate: '2026-01-01',
113
+ endDate: '2026-03-01',
114
+ });
115
+ assert.strictEqual(result.startDate, '2026-01-01');
116
+ assert.strictEqual(result.endDate, '2026-03-01');
117
+ });
118
+ });
119
+ // ---------- handler ----------
120
+ void describe('routingTelemetry', () => {
121
+ void it('should return no-routing message when all spans have matching request/response models', async () => {
122
+ const backend = makeBackend([
123
+ makeSpan({ requestModel: MODEL_GPT4O, responseModel: MODEL_GPT4O }),
124
+ makeSpan({ requestModel: MODEL_CLAUDE_OPUS, responseModel: MODEL_CLAUDE_OPUS }),
125
+ ]);
126
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
127
+ assert.ok(isNoData(result), 'should return a no-data result indicating no routing');
128
+ assert.ok(result.message.toLowerCase().includes('no routing') || result.message.toLowerCase().includes('routing decisions'), `unexpected message: ${result.message}`);
129
+ });
130
+ void it('should return no-routing message when backend has no spans', async () => {
131
+ const backend = makeBackend([]);
132
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
133
+ assert.ok(isNoData(result), 'should return a no-data result for empty backend');
134
+ });
135
+ void it('should detect routing decisions where request model differs from response model', async () => {
136
+ const backend = makeBackend([
137
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
138
+ ]);
139
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
140
+ assert.ok(isResult(result), 'should return a full result');
141
+ assert.strictEqual(result.summary.routedSpans, EXPECTED_ONE);
142
+ });
143
+ void it('should include routing pair in results', async () => {
144
+ const backend = makeBackend([
145
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
146
+ ]);
147
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
148
+ assert.ok(isResult(result), 'should return a full result');
149
+ const group = result.groups[0];
150
+ assert.ok(group, 'should have at least one group');
151
+ assert.ok(('requestedModel' in group && group.requestedModel === MODEL_AUTO) || ('pair' in group && group.pair.includes(MODEL_AUTO)) || JSON.stringify(group).includes(MODEL_AUTO), 'routing pair should reference the requested model');
152
+ assert.ok(('actualModel' in group && group.actualModel === MODEL_GPT4O) || ('pair' in group && group.pair.includes(MODEL_GPT4O)) || JSON.stringify(group).includes(MODEL_GPT4O), 'routing pair should reference the actual model');
153
+ });
154
+ void it('should skip spans missing response model', async () => {
155
+ const backend = makeBackend([
156
+ makeSpan({ requestModel: MODEL_AUTO }),
157
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
158
+ ]);
159
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
160
+ assert.ok(isResult(result), 'should return a full result');
161
+ assert.strictEqual(result.summary.routedSpans, EXPECTED_ONE);
162
+ });
163
+ void it('should compute model distribution counting actual models selected', async () => {
164
+ const backend = makeBackend([
165
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
166
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
167
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O_MINI }),
168
+ ]);
169
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
170
+ assert.ok(isResult(result), 'should return a full result');
171
+ assert.ok(result.modelDistribution, 'should include model distribution');
172
+ const gpt4oCount = result.modelDistribution[MODEL_GPT4O];
173
+ assert.ok(gpt4oCount !== undefined, 'gpt-4o should appear in distribution');
174
+ assert.strictEqual(gpt4oCount, EXPECTED_TWO);
175
+ });
176
+ void it('should compute fallback rate from routing.fallback_triggered spans', async () => {
177
+ const backend = makeBackend([
178
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, fallbackTriggered: true }),
179
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, fallbackTriggered: false }),
180
+ ]);
181
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
182
+ assert.ok(isResult(result), 'should return a full result');
183
+ assert.strictEqual(result.summary.fallbackRate, EXPECTED_FALLBACK_RATE_HALF);
184
+ });
185
+ void it('should compute P50 and P99 routing latency when classification time is present', async () => {
186
+ const spans = Array.from({ length: 10 }, (_, i) => makeSpan({
187
+ requestModel: MODEL_AUTO,
188
+ responseModel: MODEL_GPT4O,
189
+ classificationTimeMs: (i + 1) * 10,
190
+ }));
191
+ const backend = makeBackend(spans);
192
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
193
+ assert.ok(isResult(result), 'should return a full result');
194
+ assert.ok(result.routingLatency, 'should include routing latency stats');
195
+ // HdrHistogram: input [10,20,...,100]
196
+ // p50: 50% of 10 = 5th value = 50
197
+ // p99: 99% of 10 → 10th value = 100
198
+ const EXPECTED_P50 = 50;
199
+ const EXPECTED_P99 = 100;
200
+ assert.strictEqual(result.routingLatency.p50, EXPECTED_P50, 'p50 should be 50');
201
+ assert.strictEqual(result.routingLatency.p99, EXPECTED_P99, `p99 should be 100, got ${result.routingLatency.p99}`);
202
+ assert.ok(result.routingLatency.p99 >= result.routingLatency.p50, 'p99 should be >= p50');
203
+ });
204
+ void it('should fallback to span durationMs when no spans have classification.time_ms (R8-F6)', async () => {
205
+ const backend = makeBackend([
206
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
207
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
208
+ ]);
209
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
210
+ assert.ok(isResult(result), 'should return a full result');
211
+ assert.ok(result.routingLatency, 'should have routing latency from span duration fallback');
212
+ assert.strictEqual(result.routingLatency.p50, SPAN_DURATION_MS, 'p50 should equal span durationMs');
213
+ assert.strictEqual(result.routingLatency.p99, SPAN_DURATION_MS, 'p99 should equal span durationMs');
214
+ assert.strictEqual(result.routingLatency.source, 'span_duration', 'source should indicate span_duration fallback');
215
+ });
216
+ void it('should compute routing latency from varied span durations (R8-F6-L2)', async () => {
217
+ // 10 spans with durationMs = 10,20,...,100 — no classificationTimeMs → fallback path
218
+ const spans = Array.from({ length: 10 }, (_, i) => makeSpan({
219
+ requestModel: MODEL_AUTO,
220
+ responseModel: MODEL_GPT4O,
221
+ durationMs: (i + 1) * 10,
222
+ }));
223
+ const backend = makeBackend(spans);
224
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
225
+ assert.ok(isResult(result), 'should return a full result');
226
+ assert.ok(result.routingLatency, 'should have routing latency from span duration fallback');
227
+ assert.strictEqual(result.routingLatency.source, 'span_duration', 'source should indicate span_duration fallback');
228
+ // HdrHistogram: input [10,20,...,100]
229
+ // p50: 50% of 10 = 5th value = 50
230
+ const EXPECTED_P50 = 50;
231
+ assert.strictEqual(result.routingLatency.p50, EXPECTED_P50, 'p50 should be 50');
232
+ // p99: 99% of 10 → 10th value = 100
233
+ const EXPECTED_P99 = 100;
234
+ assert.strictEqual(result.routingLatency.p99, EXPECTED_P99, `p99 should be 100, got ${result.routingLatency.p99}`);
235
+ });
236
+ void it('should prefer classification.time_ms over durationMs when both present (R8-F6)', async () => {
237
+ const backend = makeBackend([
238
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, classificationTimeMs: CLASSIFICATION_TIME_MS }),
239
+ ]);
240
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
241
+ assert.ok(isResult(result), 'should return a full result');
242
+ assert.ok(result.routingLatency, 'should have routing latency');
243
+ assert.strictEqual(result.routingLatency.p50, CLASSIFICATION_TIME_MS, 'should use classification time, not durationMs');
244
+ assert.strictEqual(result.routingLatency.source, 'classification_time', 'source should indicate classification_time');
245
+ });
246
+ void it('should group by model pair when groupBy is model_pair', async () => {
247
+ const backend = makeBackend([
248
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
249
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
250
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O_MINI }),
251
+ ]);
252
+ const result = await routingTelemetry({ backend: 'local', groupBy: 'model_pair' }, { localBackend: backend });
253
+ assert.ok(isResult(result), 'should return a full result');
254
+ assert.strictEqual(result.groups.length, EXPECTED_TWO);
255
+ const gpt4oGroup = result.groups.find((g) => ('actualModel' in g && g.actualModel === MODEL_GPT4O) || ('pair' in g && g.pair.includes(MODEL_GPT4O)));
256
+ assert.ok(gpt4oGroup, 'gpt-4o group should exist');
257
+ assert.strictEqual(gpt4oGroup.count, EXPECTED_TWO);
258
+ });
259
+ void it('should group by strategy when groupBy is strategy', async () => {
260
+ const backend = makeBackend([
261
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, strategy: STRATEGY_COST }),
262
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O_MINI, strategy: STRATEGY_COST }),
263
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_CLAUDE_OPUS, strategy: STRATEGY_PERF }),
264
+ ]);
265
+ const result = await routingTelemetry({ backend: 'local', groupBy: 'strategy' }, { localBackend: backend });
266
+ assert.ok(isResult(result), 'should return a full result');
267
+ assert.strictEqual(result.groups.length, EXPECTED_TWO);
268
+ const costGroup = result.groups.find((g) => 'strategy' in g && g.strategy === STRATEGY_COST);
269
+ assert.ok(costGroup, 'cost_optimized group should exist');
270
+ assert.strictEqual(costGroup.count, EXPECTED_TWO);
271
+ });
272
+ void it('should include per-strategy fallbackCount and fallbackRate (R8-F7)', async () => {
273
+ const backend = makeBackend([
274
+ // cost_optimized: 1/2 fallback → rate 0.5
275
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, strategy: STRATEGY_COST, fallbackTriggered: true }),
276
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O_MINI, strategy: STRATEGY_COST, fallbackTriggered: false }),
277
+ // performance: 0/1 fallback → rate 0
278
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_CLAUDE_OPUS, strategy: STRATEGY_PERF, fallbackTriggered: false }),
279
+ ]);
280
+ const result = await routingTelemetry({ backend: 'local', groupBy: 'strategy' }, { localBackend: backend });
281
+ assert.ok(isResult(result), 'should return a full result');
282
+ assert.strictEqual(result.groups.length, EXPECTED_TWO);
283
+ const costGroup = result.groups.find((g) => 'strategy' in g && g.strategy === STRATEGY_COST);
284
+ assert.ok(costGroup && 'fallbackCount' in costGroup, 'cost group should have fallbackCount');
285
+ assert.strictEqual(costGroup.fallbackCount, EXPECTED_ONE, 'cost group should have 1 fallback');
286
+ assert.strictEqual(costGroup.fallbackRate, EXPECTED_FALLBACK_RATE_HALF, 'cost group fallback rate should be 0.5');
287
+ const perfGroup = result.groups.find((g) => 'strategy' in g && g.strategy === STRATEGY_PERF);
288
+ assert.ok(perfGroup && 'fallbackRate' in perfGroup, 'perf group should have fallbackRate');
289
+ assert.strictEqual(perfGroup.fallbackCount, 0, 'perf group should have 0 fallbacks');
290
+ assert.strictEqual(perfGroup.fallbackRate, 0, 'perf group fallback rate should be 0');
291
+ });
292
+ void it('should include providerDistribution and per-group provider from gen_ai.provider.name (R8-F4)', async () => {
293
+ const backend = makeBackend([
294
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, provider: 'openai' }),
295
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O_MINI, provider: 'openai' }),
296
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_CLAUDE_OPUS, provider: 'anthropic' }),
297
+ ]);
298
+ const result = await routingTelemetry({ backend: 'local', groupBy: 'model_pair' }, { localBackend: backend });
299
+ assert.ok(isResult(result), 'should return a full result');
300
+ assert.ok(result.providerDistribution, 'should include providerDistribution');
301
+ assert.strictEqual(result.providerDistribution['openai'], EXPECTED_TWO, 'openai should have 2 spans');
302
+ assert.strictEqual(result.providerDistribution['anthropic'], EXPECTED_ONE, 'anthropic should have 1 span');
303
+ // Model pair groups should carry provider
304
+ const opusGroup = result.groups.find((g) => 'actualModel' in g && g.actualModel === MODEL_CLAUDE_OPUS);
305
+ assert.ok(opusGroup && 'provider' in opusGroup, 'opus group should have provider');
306
+ assert.strictEqual(opusGroup.provider, 'anthropic');
307
+ });
308
+ void it('should fallback to gen_ai.system when gen_ai.provider.name is absent (R8-F4)', async () => {
309
+ const backend = makeBackend([
310
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, system: 'openai' }),
311
+ ]);
312
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
313
+ assert.ok(isResult(result), 'should return a full result');
314
+ assert.strictEqual(result.providerDistribution['openai'], EXPECTED_ONE, 'should resolve provider from gen_ai.system');
315
+ });
316
+ void it('should use (unknown) provider when neither gen_ai.provider.name nor gen_ai.system present (R8-F4)', async () => {
317
+ const backend = makeBackend([
318
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
319
+ ]);
320
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
321
+ assert.ok(isResult(result), 'should return a full result');
322
+ assert.strictEqual(result.providerDistribution['(unknown)'], EXPECTED_ONE, 'should count as (unknown)');
323
+ // Model pair group should have null provider
324
+ const group = result.groups[0];
325
+ assert.ok(group && 'provider' in group, 'group should have provider field');
326
+ assert.strictEqual(group.provider, null, 'provider should be null when absent');
327
+ });
328
+ void it('should filter by model name matching either request or response model', async () => {
329
+ const backend = makeBackend([
330
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
331
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_CLAUDE_HAIKU }),
332
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
333
+ ]);
334
+ const result = await routingTelemetry({ backend: 'local', model: MODEL_GPT4O }, { localBackend: backend });
335
+ assert.ok(isResult(result), 'should return a full result');
336
+ assert.strictEqual(result.summary.routedSpans, EXPECTED_TWO);
337
+ });
338
+ void it('should compute cost savings comparing actual vs hypothetical expensive-model cost', async () => {
339
+ const backend = makeBackend([
340
+ makeSpan({
341
+ requestModel: MODEL_AUTO,
342
+ responseModel: MODEL_GPT4O_MINI,
343
+ inputTokens: INPUT_TOKENS_LARGE,
344
+ outputTokens: OUTPUT_TOKENS_LARGE,
345
+ }),
346
+ makeSpan({
347
+ requestModel: MODEL_AUTO,
348
+ responseModel: MODEL_GPT4O,
349
+ inputTokens: INPUT_TOKENS_SMALL,
350
+ outputTokens: OUTPUT_TOKENS_SMALL,
351
+ }),
352
+ ]);
353
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
354
+ assert.ok(isResult(result), 'should return a full result');
355
+ assert.ok(typeof result.costSavings === 'number', 'cost savings should be a number');
356
+ assert.ok(result.costSavings >= 0, 'cost savings should be non-negative');
357
+ });
358
+ void it('should include total routed span count in summary', async () => {
359
+ const backend = makeBackend([
360
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
361
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
362
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_CLAUDE_HAIKU }),
363
+ ]);
364
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
365
+ assert.ok(isResult(result), 'should return a full result');
366
+ assert.strictEqual(result.summary.routedSpans, EXPECTED_THREE);
367
+ });
368
+ void it('should include tool name obs_routing_telemetry in routingTelemetryTool export', async () => {
369
+ const { routingTelemetryTool } = await import('./routing-telemetry.js');
370
+ assert.strictEqual(routingTelemetryTool.name, 'obs_routing_telemetry');
371
+ });
372
+ });
373
+ // ---------- regression tests (review findings) ----------
374
+ void describe('H1/F1 — phantom pricing baseline', () => {
375
+ void it('should use single most expensive model by total cost, not mixed input/output', async () => {
376
+ // Model A: high input ($10), low output ($5) → total $15
377
+ // Model B: low input ($2), high output ($12) → total $14
378
+ // Phantom bug would pick input=$10 + output=$12 = $22 (wrong)
379
+ // Fix picks Model A (total $15) → hypothetical uses {input: 10, output: 5}
380
+ MODEL_PRICING['phantom-model-a'] = { input: 10, output: 5, provider: 'test' };
381
+ MODEL_PRICING['phantom-model-b'] = { input: 2, output: 12, provider: 'test' };
382
+ const spans = [
383
+ makeSpan({
384
+ requestModel: MODEL_AUTO,
385
+ responseModel: 'phantom-model-a',
386
+ inputTokens: 1_000_000,
387
+ outputTokens: 1_000_000,
388
+ }),
389
+ makeSpan({
390
+ requestModel: MODEL_AUTO,
391
+ responseModel: 'phantom-model-b',
392
+ inputTokens: 1_000_000,
393
+ outputTokens: 1_000_000,
394
+ }),
395
+ ];
396
+ const backend = makeBackend(spans);
397
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
398
+ assert.ok(isResult(result));
399
+ // Actual: model-a (10+5=15) + model-b (2+12=14) = 29
400
+ // Hypothetical (model-a pair): 2 * (10+5) = 30
401
+ // Savings = 30 - 29 = 1
402
+ assert.strictEqual(result.costSavings, 1);
403
+ delete MODEL_PRICING['phantom-model-a'];
404
+ delete MODEL_PRICING['phantom-model-b'];
405
+ });
406
+ void it('should round costSavings to 4 decimal places (F5)', async () => {
407
+ MODEL_PRICING['round-cheap'] = { input: 0.001, output: 0.001, provider: 'test' };
408
+ MODEL_PRICING['round-pricey'] = { input: 0.003, output: 0.003, provider: 'test' };
409
+ const spans = [
410
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: 'round-cheap', inputTokens: 333, outputTokens: 333 }),
411
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: 'round-pricey', inputTokens: 333, outputTokens: 333 }),
412
+ ];
413
+ const backend = makeBackend(spans);
414
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
415
+ assert.ok(isResult(result));
416
+ // costSavings * ROUND_4DP_FACTOR should be integer (no more than 4dp)
417
+ assert.strictEqual(result.costSavings * ROUND_4DP_FACTOR, Math.round(result.costSavings * ROUND_4DP_FACTOR));
418
+ delete MODEL_PRICING['round-cheap'];
419
+ delete MODEL_PRICING['round-pricey'];
420
+ });
421
+ });
422
+ void describe('M2/M3 — numeric coercion for OTLP string attributes', () => {
423
+ void it('should handle string token counts from OTLP JSON (M2)', async () => {
424
+ const spans = [
425
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
426
+ ];
427
+ // Simulate OTLP string values by overwriting attributes
428
+ const span0 = spans[0];
429
+ assert(span0 !== undefined && span0.attributes !== undefined, 'span0 and its attributes must exist');
430
+ span0.attributes['gen_ai.usage.input_tokens'] = '1000';
431
+ span0.attributes['gen_ai.usage.output_tokens'] = '500';
432
+ const backend = makeBackend(spans);
433
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
434
+ assert.ok(isResult(result));
435
+ assert.ok(Number.isFinite(result.costSavings), 'costSavings should not be NaN');
436
+ assert.ok(result.costSavings >= 0, 'costSavings should be non-negative');
437
+ });
438
+ void it('should handle string classificationTimeMs (M3)', async () => {
439
+ const spans = [
440
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
441
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
442
+ ];
443
+ const m3span0 = spans[0];
444
+ const m3span1 = spans[1];
445
+ assert(m3span0?.attributes !== undefined && m3span1?.attributes !== undefined, 'spans and attributes must exist');
446
+ m3span0.attributes['routing.classification.time_ms'] = '42.5';
447
+ m3span1.attributes['routing.classification.time_ms'] = '100';
448
+ const backend = makeBackend(spans);
449
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
450
+ assert.ok(isResult(result));
451
+ assert.ok(result.routingLatency, 'should have routing latency');
452
+ assert.ok(result.routingLatency.p50 > 0, 'p50 should be positive');
453
+ assert.ok(result.routingLatency.p99 > 0, 'p99 should be positive');
454
+ });
455
+ void it('should treat non-numeric token values as 0', async () => {
456
+ const spans = [
457
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
458
+ ];
459
+ const m4span0 = spans[0];
460
+ assert(m4span0?.attributes !== undefined, 'span0 and its attributes must exist');
461
+ m4span0.attributes['gen_ai.usage.input_tokens'] = 'not-a-number';
462
+ m4span0.attributes['gen_ai.usage.output_tokens'] = undefined;
463
+ const backend = makeBackend(spans);
464
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
465
+ assert.ok(isResult(result));
466
+ assert.ok(Number.isFinite(result.costSavings), 'should not produce NaN');
467
+ });
468
+ });
469
+ void describe('F3 — ROUTING_ATTRIBUTES exported constants', () => {
470
+ void it('should export routing attribute keys from backends/index', () => {
471
+ assert.strictEqual(ROUTING_ATTRIBUTES.STRATEGY, 'routing.strategy');
472
+ assert.strictEqual(ROUTING_ATTRIBUTES.FALLBACK_TRIGGERED, 'routing.fallback_triggered');
473
+ assert.strictEqual(ROUTING_ATTRIBUTES.CLASSIFICATION_TIME_MS, 'routing.classification.time_ms');
474
+ });
475
+ });
476
+ void describe('F8 — unknown models in MODEL_PRICING', () => {
477
+ void it('should produce costSavings=0 when all models are unknown (no pricing data)', async () => {
478
+ const backend = makeBackend([
479
+ makeSpan({
480
+ requestModel: 'unknown-model-x',
481
+ responseModel: 'unknown-model-y',
482
+ inputTokens: INPUT_TOKENS_LARGE,
483
+ outputTokens: OUTPUT_TOKENS_LARGE,
484
+ }),
485
+ ]);
486
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
487
+ assert.ok(isResult(result));
488
+ assert.strictEqual(result.costSavings, 0, 'unknown models should produce zero cost savings');
489
+ });
490
+ void it('should inflate savings when only some models are unknown (actualCost=0 for unknown)', async () => {
491
+ const backend = makeBackend([
492
+ makeSpan({
493
+ requestModel: MODEL_AUTO,
494
+ responseModel: 'unknown-model-z',
495
+ inputTokens: INPUT_TOKENS_LARGE,
496
+ outputTokens: OUTPUT_TOKENS_LARGE,
497
+ }),
498
+ makeSpan({
499
+ requestModel: MODEL_AUTO,
500
+ responseModel: MODEL_GPT4O,
501
+ inputTokens: INPUT_TOKENS_SMALL,
502
+ outputTokens: OUTPUT_TOKENS_SMALL,
503
+ }),
504
+ ]);
505
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
506
+ assert.ok(isResult(result));
507
+ // Unknown model contributes 0 to actualCost but hypothetical uses gpt-4o pricing → savings inflated
508
+ assert.ok(result.costSavings > 0, 'savings inflated when unknown model produces zero actual cost');
509
+ });
510
+ });
511
+ void describe('F10 — finish_reasons fallback signal', () => {
512
+ void it('should detect fallback from content_filter finish reason', async () => {
513
+ const backend = makeBackend([
514
+ makeSpan({
515
+ requestModel: MODEL_AUTO,
516
+ responseModel: MODEL_GPT4O,
517
+ finishReasons: ['content_filter'],
518
+ }),
519
+ makeSpan({
520
+ requestModel: MODEL_AUTO,
521
+ responseModel: MODEL_GPT4O,
522
+ finishReasons: ['stop'],
523
+ }),
524
+ ]);
525
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
526
+ assert.ok(isResult(result));
527
+ assert.strictEqual(result.summary.fallbackRate, EXPECTED_FALLBACK_RATE_HALF, 'content_filter should count as fallback');
528
+ });
529
+ void it('should detect fallback from length finish reason', async () => {
530
+ const backend = makeBackend([
531
+ makeSpan({
532
+ requestModel: MODEL_AUTO,
533
+ responseModel: MODEL_GPT4O,
534
+ finishReasons: ['length'],
535
+ }),
536
+ ]);
537
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
538
+ assert.ok(isResult(result));
539
+ assert.strictEqual(result.summary.fallbackRate, EXPECTED_FULL_FALLBACK_RATE, 'length should count as fallback');
540
+ });
541
+ void it('should not double-count when both fallbackTriggered and finish_reasons indicate fallback', async () => {
542
+ const backend = makeBackend([
543
+ makeSpan({
544
+ requestModel: MODEL_AUTO,
545
+ responseModel: MODEL_GPT4O,
546
+ fallbackTriggered: true,
547
+ finishReasons: ['content_filter'],
548
+ }),
549
+ ]);
550
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
551
+ assert.ok(isResult(result));
552
+ assert.strictEqual(result.summary.fallbackRate, EXPECTED_FULL_FALLBACK_RATE, 'should count as single fallback');
553
+ });
554
+ });
555
+ void describe('F12 — totalSpansScanned field', () => {
556
+ void it('should include totalSpansScanned in no-data result', async () => {
557
+ const TOTAL_SPANS = 3;
558
+ const backend = makeBackend([
559
+ makeSpan({ requestModel: MODEL_GPT4O, responseModel: MODEL_GPT4O }),
560
+ makeSpan({ requestModel: MODEL_GPT4O, responseModel: MODEL_GPT4O }),
561
+ makeSpan({ requestModel: MODEL_GPT4O, responseModel: MODEL_GPT4O }),
562
+ ]);
563
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
564
+ assert.ok(isNoData(result));
565
+ assert.strictEqual(result.totalSpansScanned, TOTAL_SPANS);
566
+ });
567
+ void it('should include totalSpansScanned in result', async () => {
568
+ const TOTAL_SPANS = 3;
569
+ const backend = makeBackend([
570
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O }),
571
+ makeSpan({ requestModel: MODEL_GPT4O, responseModel: MODEL_GPT4O }),
572
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_CLAUDE_HAIKU }),
573
+ ]);
574
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
575
+ assert.ok(isResult(result));
576
+ assert.strictEqual(result.totalSpansScanned, TOTAL_SPANS);
577
+ });
578
+ });
579
+ // ============================================================================
580
+ // Stress Tests (ST-R8)
581
+ // ============================================================================
582
+ // MAX_QUERY_LIMIT = 1000; use max to stress the routing at full capacity
583
+ const ST_R8_SPAN_COUNT = 1_000;
584
+ const ST_R8_UNIQUE_MODELS = 8;
585
+ const ST_R8_REQUEST_MODELS = ['auto', 'router', 'gpt-4-turbo', 'claude-3'];
586
+ const ST_R8_RESPONSE_MODELS = [
587
+ MODEL_GPT4O,
588
+ MODEL_GPT4O_MINI,
589
+ MODEL_CLAUDE_OPUS,
590
+ MODEL_CLAUDE_HAIKU,
591
+ 'claude-3-5-sonnet-20241022',
592
+ 'gpt-4-turbo',
593
+ 'claude-3-haiku-20240307',
594
+ 'claude-3-opus-20240229',
595
+ ];
596
+ function makeStressSpan(i) {
597
+ const requestModel = ST_R8_REQUEST_MODELS[i % ST_R8_REQUEST_MODELS.length];
598
+ const responseModel = ST_R8_RESPONSE_MODELS[i % ST_R8_UNIQUE_MODELS];
599
+ return makeSpan({
600
+ requestModel,
601
+ responseModel,
602
+ inputTokens: 500 + (i % 2000),
603
+ outputTokens: 100 + (i % 500),
604
+ strategy: i % 3 === 0 ? STRATEGY_COST : (i % 3 === 1 ? STRATEGY_PERF : undefined),
605
+ fallbackTriggered: i % 7 === 0,
606
+ classificationTimeMs: i % 5 === 0 ? 10 + (i % 50) : undefined,
607
+ });
608
+ }
609
+ void describe('routingTelemetry stress (ST-R8)', () => {
610
+ void it('high-volume (1K spans at max limit): produces a result and all numeric fields are finite', async () => {
611
+ const spans = Array.from({ length: ST_R8_SPAN_COUNT }, (_, i) => makeStressSpan(i));
612
+ const backend = makeBackend(spans);
613
+ const result = await routingTelemetry({ backend: 'local', limit: ST_R8_SPAN_COUNT }, { localBackend: backend });
614
+ assert.ok(isResult(result), `expected result, got no-data for ${ST_R8_SPAN_COUNT} spans`);
615
+ if (!isResult(result))
616
+ return;
617
+ assert.ok(isFinite(result.costSavings), `costSavings should be finite, got ${result.costSavings}`);
618
+ assert.ok(result.costSavings >= 0, `costSavings should be non-negative, got ${result.costSavings}`);
619
+ assert.ok(isFinite(result.summary.fallbackRate), `fallbackRate should be finite`);
620
+ assert.ok(result.summary.fallbackRate >= 0 && result.summary.fallbackRate <= 1, `fallbackRate ${result.summary.fallbackRate} out of [0,1]`);
621
+ });
622
+ void it('high-volume: modelDistribution has exactly the expected unique models', async () => {
623
+ const spans = Array.from({ length: ST_R8_SPAN_COUNT }, (_, i) => makeStressSpan(i));
624
+ const backend = makeBackend(spans);
625
+ const result = await routingTelemetry({ backend: 'local', limit: ST_R8_SPAN_COUNT }, { localBackend: backend });
626
+ assert.ok(isResult(result));
627
+ if (!isResult(result))
628
+ return;
629
+ // All 8 response models should appear (ST_R8_SPAN_COUNT / ST_R8_UNIQUE_MODELS = 125 each)
630
+ assert.strictEqual(Object.keys(result.modelDistribution).length, ST_R8_UNIQUE_MODELS, `expected ${ST_R8_UNIQUE_MODELS} unique models in distribution`);
631
+ });
632
+ void it('unknown model in pricing table: costSavings is 0 and does not throw', async () => {
633
+ const spans = [
634
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: 'unknown-future-model-xyz', inputTokens: 1000, outputTokens: 200 }),
635
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: 'another-unknown-model', inputTokens: 1000, outputTokens: 200 }),
636
+ ];
637
+ const backend = makeBackend(spans);
638
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
639
+ assert.ok(isResult(result), 'should return result (not no-data) for unknown-model spans');
640
+ if (!isResult(result))
641
+ return;
642
+ // Unknown models have no pricing → computeCost returns 0 → savings = max(0, 0-0) = 0
643
+ assert.strictEqual(result.costSavings, 0, 'cost savings should be 0 when models have no pricing entry');
644
+ });
645
+ void it('string-typed OTLP attributes: token counts parsed from strings work correctly', async () => {
646
+ // OTLP attributes may arrive as strings rather than numbers in some SDK versions
647
+ const spanWithStringAttrs = {
648
+ traceId: 'trace-str',
649
+ spanId: 'span-str',
650
+ name: 'chat',
651
+ startTimeUnixNano: Date.now() * 1_000_000,
652
+ endTimeUnixNano: (Date.now() + 100) * 1_000_000,
653
+ durationMs: 100,
654
+ attributes: {
655
+ 'gen_ai.request.model': MODEL_AUTO,
656
+ 'gen_ai.response.model': MODEL_GPT4O,
657
+ 'gen_ai.usage.input_tokens': '1000', // string-typed
658
+ 'gen_ai.usage.output_tokens': '200', // string-typed
659
+ 'routing.fallback_triggered': 'true', // string-typed bool
660
+ },
661
+ };
662
+ const backend = makeBackend([spanWithStringAttrs]);
663
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
664
+ assert.ok(isResult(result), 'should handle string-typed OTLP attributes');
665
+ if (!isResult(result))
666
+ return;
667
+ // String 'true' for fallback_triggered should be parsed as true
668
+ assert.strictEqual(result.summary.fallbackRate, 1, 'string "true" fallback_triggered should count as fallback');
669
+ // Token costs should be computed correctly from string-parsed numbers
670
+ assert.ok(result.costSavings >= 0, 'costSavings should be non-negative with string tokens');
671
+ });
672
+ void it('identical values produce p50 = p99 (no NaN or divide-by-zero)', async () => {
673
+ // All spans have the same classificationTimeMs — identical values case
674
+ const SPAN_COUNT = 100;
675
+ const spans = Array.from({ length: SPAN_COUNT }, () => makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, classificationTimeMs: CLASSIFICATION_TIME_MS }));
676
+ const backend = makeBackend(spans);
677
+ const result = await routingTelemetry({ backend: 'local', limit: SPAN_COUNT }, { localBackend: backend });
678
+ assert.ok(isResult(result));
679
+ if (!isResult(result))
680
+ return;
681
+ assert.ok(result.routingLatency !== undefined, 'routingLatency should be defined');
682
+ if (!result.routingLatency)
683
+ return;
684
+ assert.strictEqual(result.routingLatency.p50, CLASSIFICATION_TIME_MS, `p50 should be ${CLASSIFICATION_TIME_MS} for identical values`);
685
+ assert.strictEqual(result.routingLatency.p99, CLASSIFICATION_TIME_MS, `p99 should be ${CLASSIFICATION_TIME_MS} for identical values`);
686
+ assert.ok(isFinite(result.routingLatency.p50), 'p50 should be finite');
687
+ assert.ok(isFinite(result.routingLatency.p99), 'p99 should be finite');
688
+ });
689
+ void it('single-span array returns the span value for p50 and p99', async () => {
690
+ const SINGLE_MS = 77;
691
+ const backend = makeBackend([
692
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, classificationTimeMs: SINGLE_MS }),
693
+ ]);
694
+ const result = await routingTelemetry({ backend: 'local' }, { localBackend: backend });
695
+ assert.ok(isResult(result));
696
+ if (!isResult(result))
697
+ return;
698
+ assert.ok(result.routingLatency !== undefined);
699
+ assert.strictEqual(result.routingLatency?.p50, SINGLE_MS, `p50 should equal the single value (${SINGLE_MS})`);
700
+ assert.strictEqual(result.routingLatency?.p99, SINGLE_MS, `p99 should equal the single value (${SINGLE_MS})`);
701
+ });
702
+ void it('cost savings accuracy: cheaper model saves the expected amount vs expensive baseline', async () => {
703
+ const PRICING_GPT4O = MODEL_PRICING[MODEL_GPT4O];
704
+ const PRICING_HAIKU = MODEL_PRICING[MODEL_CLAUDE_HAIKU];
705
+ if (!PRICING_GPT4O || !PRICING_HAIKU) {
706
+ // Skip if either model is not in pricing table
707
+ return;
708
+ }
709
+ const INPUT_TOKENS = 10_000;
710
+ const OUTPUT_TOKENS = 2_000;
711
+ const CHEAP_SPAN_COUNT = 100;
712
+ // Most spans route 'auto' → haiku (cheap); one span routes 'auto' → gpt-4o (expensive baseline).
713
+ // Cost savings are computed vs the most expensive response model per request model.
714
+ // Both are routed (auto ≠ haiku, auto ≠ gpt-4o), so both are included in routedSpans.
715
+ const spans = [
716
+ ...Array.from({ length: CHEAP_SPAN_COUNT }, () => makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_CLAUDE_HAIKU, inputTokens: INPUT_TOKENS, outputTokens: OUTPUT_TOKENS })),
717
+ makeSpan({ requestModel: MODEL_AUTO, responseModel: MODEL_GPT4O, inputTokens: INPUT_TOKENS, outputTokens: OUTPUT_TOKENS }),
718
+ ];
719
+ const backend = makeBackend(spans);
720
+ const result = await routingTelemetry({ backend: 'local', limit: CHEAP_SPAN_COUNT + 1 }, { localBackend: backend });
721
+ assert.ok(isResult(result));
722
+ if (!isResult(result))
723
+ return;
724
+ // With haiku cheaper than gpt-4o, savings should be positive
725
+ assert.ok(result.costSavings > 0, `cost savings should be positive when routing to cheaper model, got ${result.costSavings}`);
726
+ });
727
+ void it('high cardinality: 20 unique (request, response) model pairs produce non-empty groups', async () => {
728
+ const UNIQUE_PAIRS = 20;
729
+ const spans = Array.from({ length: UNIQUE_PAIRS * 50 }, (_, i) => {
730
+ const pairIdx = Math.floor(i / 50);
731
+ return makeSpan({
732
+ requestModel: `request-model-${pairIdx}`,
733
+ responseModel: `response-model-${pairIdx}`,
734
+ inputTokens: 1000,
735
+ outputTokens: 200,
736
+ });
737
+ });
738
+ const backend = makeBackend(spans);
739
+ const result = await routingTelemetry({ backend: 'local', limit: UNIQUE_PAIRS * 50, groupBy: 'model_pair' }, { localBackend: backend });
740
+ assert.ok(isResult(result));
741
+ if (!isResult(result))
742
+ return;
743
+ assert.ok(result.groups.length > 0, 'groups should be non-empty for high cardinality inputs');
744
+ assert.ok(isFinite(result.costSavings), 'costSavings should be finite for high cardinality');
745
+ });
746
+ });
747
+ //# sourceMappingURL=routing-telemetry.test.js.map