promptfoo 0.95.0 → 0.96.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (350) hide show
  1. package/README.md +3 -1
  2. package/dist/package.json +19 -17
  3. package/dist/src/app/assets/{index-zXzgAsKj.js → index-CL29fyye.js} +185 -185
  4. package/dist/src/app/assets/{index.es-Jztl1qad.js → index.es-CsYHA4xg.js} +1 -1
  5. package/dist/src/app/assets/{sync-BJBBGzPI.js → sync-B9AjROwZ.js} +1 -1
  6. package/dist/src/app/index.html +1 -1
  7. package/dist/src/assertions/answerRelevance.d.ts +3 -0
  8. package/dist/src/assertions/answerRelevance.d.ts.map +1 -0
  9. package/dist/src/assertions/answerRelevance.js +19 -0
  10. package/dist/src/assertions/answerRelevance.js.map +1 -0
  11. package/dist/src/assertions/bleu.d.ts +23 -0
  12. package/dist/src/assertions/bleu.d.ts.map +1 -0
  13. package/dist/src/assertions/bleu.js +132 -0
  14. package/dist/src/assertions/bleu.js.map +1 -0
  15. package/dist/src/assertions/classifier.d.ts +3 -0
  16. package/dist/src/assertions/classifier.d.ts.map +1 -0
  17. package/dist/src/assertions/classifier.js +22 -0
  18. package/dist/src/assertions/classifier.js.map +1 -0
  19. package/dist/src/assertions/contains.d.ts +8 -0
  20. package/dist/src/assertions/contains.d.ts.map +1 -0
  21. package/dist/src/assertions/contains.js +110 -0
  22. package/dist/src/assertions/contains.js.map +1 -0
  23. package/dist/src/assertions/contextFaithfulness.d.ts +3 -0
  24. package/dist/src/assertions/contextFaithfulness.d.ts.map +1 -0
  25. package/dist/src/assertions/contextFaithfulness.js +19 -0
  26. package/dist/src/assertions/contextFaithfulness.js.map +1 -0
  27. package/dist/src/assertions/contextRecall.d.ts +3 -0
  28. package/dist/src/assertions/contextRecall.d.ts.map +1 -0
  29. package/dist/src/assertions/contextRecall.js +18 -0
  30. package/dist/src/assertions/contextRecall.js.map +1 -0
  31. package/dist/src/assertions/contextRelevance.d.ts +3 -0
  32. package/dist/src/assertions/contextRelevance.d.ts.map +1 -0
  33. package/dist/src/assertions/contextRelevance.js +19 -0
  34. package/dist/src/assertions/contextRelevance.js.map +1 -0
  35. package/dist/src/assertions/cost.d.ts +3 -0
  36. package/dist/src/assertions/cost.d.ts.map +1 -0
  37. package/dist/src/assertions/cost.js +22 -0
  38. package/dist/src/assertions/cost.js.map +1 -0
  39. package/dist/src/assertions/equals.d.ts +4 -0
  40. package/dist/src/assertions/equals.d.ts.map +1 -0
  41. package/dist/src/assertions/equals.js +32 -0
  42. package/dist/src/assertions/equals.js.map +1 -0
  43. package/dist/src/assertions/factuality.d.ts +3 -0
  44. package/dist/src/assertions/factuality.d.ts.map +1 -0
  45. package/dist/src/assertions/factuality.js +25 -0
  46. package/dist/src/assertions/factuality.js.map +1 -0
  47. package/dist/src/assertions/index.d.ts +1 -12
  48. package/dist/src/assertions/index.d.ts.map +1 -1
  49. package/dist/src/assertions/index.js +94 -987
  50. package/dist/src/assertions/index.js.map +1 -1
  51. package/dist/src/assertions/javascript.d.ts +4 -0
  52. package/dist/src/assertions/javascript.d.ts.map +1 -0
  53. package/dist/src/assertions/javascript.js +94 -0
  54. package/dist/src/assertions/javascript.js.map +1 -0
  55. package/dist/src/assertions/json.d.ts +7 -0
  56. package/dist/src/assertions/json.d.ts.map +1 -0
  57. package/dist/src/assertions/json.js +121 -0
  58. package/dist/src/assertions/json.js.map +1 -0
  59. package/dist/src/assertions/latency.d.ts +3 -0
  60. package/dist/src/assertions/latency.d.ts.map +1 -0
  61. package/dist/src/assertions/latency.js +22 -0
  62. package/dist/src/assertions/latency.js.map +1 -0
  63. package/dist/src/assertions/levenshtein.d.ts +3 -0
  64. package/dist/src/assertions/levenshtein.d.ts.map +1 -0
  65. package/dist/src/assertions/levenshtein.js +22 -0
  66. package/dist/src/assertions/levenshtein.js.map +1 -0
  67. package/dist/src/assertions/llmRubric.d.ts +3 -0
  68. package/dist/src/assertions/llmRubric.d.ts.map +1 -0
  69. package/dist/src/assertions/llmRubric.js +22 -0
  70. package/dist/src/assertions/llmRubric.js.map +1 -0
  71. package/dist/src/assertions/modelGradedClosedQa.d.ts +3 -0
  72. package/dist/src/assertions/modelGradedClosedQa.d.ts.map +1 -0
  73. package/dist/src/assertions/modelGradedClosedQa.js +25 -0
  74. package/dist/src/assertions/modelGradedClosedQa.js.map +1 -0
  75. package/dist/src/assertions/moderation.d.ts +3 -0
  76. package/dist/src/assertions/moderation.d.ts.map +1 -0
  77. package/dist/src/assertions/moderation.js +41 -0
  78. package/dist/src/assertions/moderation.js.map +1 -0
  79. package/dist/src/assertions/openai.d.ts +5 -0
  80. package/dist/src/assertions/openai.d.ts.map +1 -0
  81. package/dist/src/assertions/openai.js +68 -0
  82. package/dist/src/assertions/openai.js.map +1 -0
  83. package/dist/src/assertions/perplexity.d.ts +4 -0
  84. package/dist/src/assertions/perplexity.d.ts.map +1 -0
  85. package/dist/src/assertions/perplexity.js +40 -0
  86. package/dist/src/assertions/perplexity.js.map +1 -0
  87. package/dist/src/assertions/python.d.ts +4 -0
  88. package/dist/src/assertions/python.d.ts.map +1 -0
  89. package/dist/src/assertions/python.js +107 -0
  90. package/dist/src/assertions/python.js.map +1 -0
  91. package/dist/src/assertions/redteam.d.ts +3 -0
  92. package/dist/src/assertions/redteam.d.ts.map +1 -0
  93. package/dist/src/assertions/redteam.js +29 -0
  94. package/dist/src/assertions/redteam.js.map +1 -0
  95. package/dist/src/assertions/regex.d.ts +3 -0
  96. package/dist/src/assertions/regex.d.ts.map +1 -0
  97. package/dist/src/assertions/regex.js +34 -0
  98. package/dist/src/assertions/regex.js.map +1 -0
  99. package/dist/src/assertions/rouge.d.ts +3 -0
  100. package/dist/src/assertions/rouge.d.ts.map +1 -0
  101. package/dist/src/assertions/rouge.js +47 -0
  102. package/dist/src/assertions/rouge.js.map +1 -0
  103. package/dist/src/assertions/similar.d.ts +3 -0
  104. package/dist/src/assertions/similar.d.ts.map +1 -0
  105. package/dist/src/assertions/similar.js +40 -0
  106. package/dist/src/assertions/similar.js.map +1 -0
  107. package/dist/src/assertions/sql.d.ts +4 -0
  108. package/dist/src/assertions/sql.d.ts.map +1 -0
  109. package/dist/src/assertions/sql.js +98 -0
  110. package/dist/src/assertions/sql.js.map +1 -0
  111. package/dist/src/assertions/startsWith.d.ts +3 -0
  112. package/dist/src/assertions/startsWith.d.ts.map +1 -0
  113. package/dist/src/assertions/startsWith.js +22 -0
  114. package/dist/src/assertions/startsWith.js.map +1 -0
  115. package/dist/src/assertions/utils.d.ts +1 -0
  116. package/dist/src/assertions/utils.d.ts.map +1 -1
  117. package/dist/src/assertions/utils.js +7 -0
  118. package/dist/src/assertions/utils.js.map +1 -1
  119. package/dist/src/assertions/webhook.d.ts +3 -0
  120. package/dist/src/assertions/webhook.d.ts.map +1 -0
  121. package/dist/src/assertions/webhook.js +55 -0
  122. package/dist/src/assertions/webhook.js.map +1 -0
  123. package/dist/src/assertions/xml.d.ts +11 -0
  124. package/dist/src/assertions/xml.d.ts.map +1 -0
  125. package/dist/src/assertions/xml.js +86 -0
  126. package/dist/src/assertions/xml.js.map +1 -0
  127. package/dist/src/commands/eval/filterTests.d.ts +1 -0
  128. package/dist/src/commands/eval/filterTests.d.ts.map +1 -1
  129. package/dist/src/commands/eval/filterTests.js +14 -1
  130. package/dist/src/commands/eval/filterTests.js.map +1 -1
  131. package/dist/src/commands/eval.d.ts.map +1 -1
  132. package/dist/src/commands/eval.js +14 -3
  133. package/dist/src/commands/eval.js.map +1 -1
  134. package/dist/src/commands/import.d.ts.map +1 -1
  135. package/dist/src/commands/import.js +1 -0
  136. package/dist/src/commands/import.js.map +1 -1
  137. package/dist/src/commands/list.d.ts.map +1 -1
  138. package/dist/src/commands/list.js +15 -0
  139. package/dist/src/commands/list.js.map +1 -1
  140. package/dist/src/csv.d.ts.map +1 -1
  141. package/dist/src/csv.js +9 -4
  142. package/dist/src/csv.js.map +1 -1
  143. package/dist/src/database/tables.d.ts +189 -1
  144. package/dist/src/database/tables.d.ts.map +1 -1
  145. package/dist/src/envars.d.ts +9 -0
  146. package/dist/src/envars.d.ts.map +1 -1
  147. package/dist/src/envars.js.map +1 -1
  148. package/dist/src/evaluator.js +2 -2
  149. package/dist/src/evaluator.js.map +1 -1
  150. package/dist/src/evaluatorHelpers.d.ts.map +1 -1
  151. package/dist/src/evaluatorHelpers.js +4 -0
  152. package/dist/src/evaluatorHelpers.js.map +1 -1
  153. package/dist/src/fetch.d.ts.map +1 -1
  154. package/dist/src/fetch.js +8 -1
  155. package/dist/src/fetch.js.map +1 -1
  156. package/dist/src/globalConfig/accounts.d.ts +1 -0
  157. package/dist/src/globalConfig/accounts.d.ts.map +1 -1
  158. package/dist/src/globalConfig/accounts.js +24 -0
  159. package/dist/src/globalConfig/accounts.js.map +1 -1
  160. package/dist/src/index.d.ts +74 -68
  161. package/dist/src/index.d.ts.map +1 -1
  162. package/dist/src/onboarding.js +8 -8
  163. package/dist/src/onboarding.js.map +1 -1
  164. package/dist/src/providers/adaline.gateway.d.ts.map +1 -1
  165. package/dist/src/providers/adaline.gateway.js +4 -4
  166. package/dist/src/providers/adaline.gateway.js.map +1 -1
  167. package/dist/src/providers/anthropic.d.ts.map +1 -1
  168. package/dist/src/providers/anthropic.js +31 -0
  169. package/dist/src/providers/anthropic.js.map +1 -1
  170. package/dist/src/providers/{azureopenai.d.ts → azure.d.ts} +13 -13
  171. package/dist/src/providers/azure.d.ts.map +1 -0
  172. package/dist/src/providers/{azureopenai.js → azure.js} +64 -42
  173. package/dist/src/providers/azure.js.map +1 -0
  174. package/dist/src/providers/{azureopenaiUtil.d.ts → azureUtil.d.ts} +1 -1
  175. package/dist/src/providers/azureUtil.d.ts.map +1 -0
  176. package/dist/src/providers/{azureopenaiUtil.js → azureUtil.js} +3 -3
  177. package/dist/src/providers/azureUtil.js.map +1 -0
  178. package/dist/src/providers/bedrock.d.ts +5 -3
  179. package/dist/src/providers/bedrock.d.ts.map +1 -1
  180. package/dist/src/providers/bedrock.js +38 -9
  181. package/dist/src/providers/bedrock.js.map +1 -1
  182. package/dist/src/providers/defaults.d.ts.map +1 -1
  183. package/dist/src/providers/defaults.js +36 -0
  184. package/dist/src/providers/defaults.js.map +1 -1
  185. package/dist/src/providers/portkey.d.ts +3 -2
  186. package/dist/src/providers/portkey.d.ts.map +1 -1
  187. package/dist/src/providers/portkey.js +17 -10
  188. package/dist/src/providers/portkey.js.map +1 -1
  189. package/dist/src/providers/promptfoo.js +2 -2
  190. package/dist/src/providers/promptfoo.js.map +1 -1
  191. package/dist/src/providers.d.ts +9 -5
  192. package/dist/src/providers.d.ts.map +1 -1
  193. package/dist/src/providers.js +16 -11
  194. package/dist/src/providers.js.map +1 -1
  195. package/dist/src/redteam/commands/generate.d.ts.map +1 -1
  196. package/dist/src/redteam/commands/generate.js +5 -1
  197. package/dist/src/redteam/commands/generate.js.map +1 -1
  198. package/dist/src/redteam/commands/init.d.ts +11 -0
  199. package/dist/src/redteam/commands/init.d.ts.map +1 -1
  200. package/dist/src/redteam/commands/init.js +47 -12
  201. package/dist/src/redteam/commands/init.js.map +1 -1
  202. package/dist/src/redteam/commands/poison.d.ts +3 -0
  203. package/dist/src/redteam/commands/poison.d.ts.map +1 -0
  204. package/dist/src/redteam/commands/poison.js +165 -0
  205. package/dist/src/redteam/commands/poison.js.map +1 -0
  206. package/dist/src/redteam/commands/run.d.ts.map +1 -1
  207. package/dist/src/redteam/commands/run.js +2 -0
  208. package/dist/src/redteam/commands/run.js.map +1 -1
  209. package/dist/src/redteam/constants.d.ts +6 -5
  210. package/dist/src/redteam/constants.d.ts.map +1 -1
  211. package/dist/src/redteam/constants.js +54 -37
  212. package/dist/src/redteam/constants.js.map +1 -1
  213. package/dist/src/redteam/extraction/util.js +1 -1
  214. package/dist/src/redteam/extraction/util.js.map +1 -1
  215. package/dist/src/redteam/graders.d.ts +34 -32
  216. package/dist/src/redteam/graders.d.ts.map +1 -1
  217. package/dist/src/redteam/graders.js +34 -33
  218. package/dist/src/redteam/graders.js.map +1 -1
  219. package/dist/src/redteam/index.d.ts.map +1 -1
  220. package/dist/src/redteam/index.js +9 -2
  221. package/dist/src/redteam/index.js.map +1 -1
  222. package/dist/src/redteam/plugins/bfla.d.ts.map +1 -1
  223. package/dist/src/redteam/plugins/bfla.js +5 -3
  224. package/dist/src/redteam/plugins/bfla.js.map +1 -1
  225. package/dist/src/redteam/plugins/bola.js +3 -3
  226. package/dist/src/redteam/plugins/index.d.ts.map +1 -1
  227. package/dist/src/redteam/plugins/index.js +3 -2
  228. package/dist/src/redteam/plugins/index.js.map +1 -1
  229. package/dist/src/redteam/plugins/intent.d.ts +22 -0
  230. package/dist/src/redteam/plugins/intent.d.ts.map +1 -0
  231. package/dist/src/redteam/plugins/intent.js +100 -0
  232. package/dist/src/redteam/plugins/intent.js.map +1 -0
  233. package/dist/src/redteam/plugins/pii.d.ts.map +1 -1
  234. package/dist/src/redteam/plugins/pii.js +21 -14
  235. package/dist/src/redteam/plugins/pii.js.map +1 -1
  236. package/dist/src/redteam/plugins/rbac.d.ts.map +1 -1
  237. package/dist/src/redteam/plugins/rbac.js +5 -4
  238. package/dist/src/redteam/plugins/rbac.js.map +1 -1
  239. package/dist/src/redteam/plugins/sqlInjection.d.ts.map +1 -1
  240. package/dist/src/redteam/plugins/sqlInjection.js +13 -4
  241. package/dist/src/redteam/plugins/sqlInjection.js.map +1 -1
  242. package/dist/src/redteam/providers/crescendo/index.d.ts.map +1 -1
  243. package/dist/src/redteam/providers/crescendo/index.js +6 -4
  244. package/dist/src/redteam/providers/crescendo/index.js.map +1 -1
  245. package/dist/src/redteam/providers/goat.d.ts +2 -0
  246. package/dist/src/redteam/providers/goat.d.ts.map +1 -1
  247. package/dist/src/redteam/providers/goat.js +10 -3
  248. package/dist/src/redteam/providers/goat.js.map +1 -1
  249. package/dist/src/redteam/providers/iterative.d.ts.map +1 -1
  250. package/dist/src/redteam/providers/iterative.js +4 -2
  251. package/dist/src/redteam/providers/iterative.js.map +1 -1
  252. package/dist/src/redteam/providers/iterativeImage.d.ts.map +1 -1
  253. package/dist/src/redteam/providers/iterativeImage.js +4 -2
  254. package/dist/src/redteam/providers/iterativeImage.js.map +1 -1
  255. package/dist/src/redteam/providers/iterativeTree.d.ts +3 -1
  256. package/dist/src/redteam/providers/iterativeTree.d.ts.map +1 -1
  257. package/dist/src/redteam/providers/iterativeTree.js +5 -3
  258. package/dist/src/redteam/providers/iterativeTree.js.map +1 -1
  259. package/dist/src/redteam/providers/shared.d.ts +2 -2
  260. package/dist/src/redteam/providers/shared.d.ts.map +1 -1
  261. package/dist/src/redteam/providers/shared.js +2 -2
  262. package/dist/src/redteam/providers/shared.js.map +1 -1
  263. package/dist/src/redteam/strategies/mathPrompt.js +1 -1
  264. package/dist/src/redteam/strategies/mathPrompt.js.map +1 -1
  265. package/dist/src/redteam/strategies/multilingual.js +1 -1
  266. package/dist/src/redteam/strategies/multilingual.js.map +1 -1
  267. package/dist/src/redteam/types.d.ts +1 -0
  268. package/dist/src/redteam/types.d.ts.map +1 -1
  269. package/dist/src/remoteGrading.js +1 -1
  270. package/dist/src/remoteGrading.js.map +1 -1
  271. package/dist/src/telemetry.d.ts +2 -2
  272. package/dist/src/types/index.d.ts +4737 -12
  273. package/dist/src/types/index.d.ts.map +1 -1
  274. package/dist/src/types/index.js +23 -26
  275. package/dist/src/types/index.js.map +1 -1
  276. package/dist/src/types/providers.d.ts +12 -0
  277. package/dist/src/types/providers.d.ts.map +1 -1
  278. package/dist/src/types/providers.js.map +1 -1
  279. package/dist/src/util/config/load.d.ts +1 -1
  280. package/dist/src/util/config/load.d.ts.map +1 -1
  281. package/dist/src/util/config/load.js +15 -2
  282. package/dist/src/util/config/load.js.map +1 -1
  283. package/dist/src/util/index.d.ts +34 -0
  284. package/dist/src/util/index.d.ts.map +1 -1
  285. package/dist/src/validators/providers.d.ts +391 -0
  286. package/dist/src/validators/providers.d.ts.map +1 -1
  287. package/dist/src/validators/providers.js +18 -0
  288. package/dist/src/validators/providers.js.map +1 -1
  289. package/dist/src/validators/redteam.d.ts +136 -0
  290. package/dist/src/validators/redteam.d.ts.map +1 -1
  291. package/dist/test/assertions/bleu.test.d.ts +2 -0
  292. package/dist/test/assertions/bleu.test.d.ts.map +1 -0
  293. package/dist/test/assertions/bleu.test.js +162 -0
  294. package/dist/test/assertions/bleu.test.js.map +1 -0
  295. package/dist/test/assertions/index.test.js +276 -297
  296. package/dist/test/assertions/index.test.js.map +1 -1
  297. package/dist/test/assertions/json.test.d.ts +2 -0
  298. package/dist/test/assertions/json.test.d.ts.map +1 -0
  299. package/dist/test/assertions/json.test.js +36 -0
  300. package/dist/test/assertions/json.test.js.map +1 -0
  301. package/dist/test/assertions/sql.test.d.ts +2 -0
  302. package/dist/test/assertions/sql.test.d.ts.map +1 -0
  303. package/dist/test/assertions/sql.test.js +280 -0
  304. package/dist/test/assertions/sql.test.js.map +1 -0
  305. package/dist/test/commands/eval/filterTests.test.js +30 -0
  306. package/dist/test/commands/eval/filterTests.test.js.map +1 -1
  307. package/dist/test/factories/evalFactory.d.ts +155 -1
  308. package/dist/test/factories/evalFactory.d.ts.map +1 -1
  309. package/dist/test/fetch.test.js +17 -0
  310. package/dist/test/fetch.test.js.map +1 -1
  311. package/dist/test/onboarding.test.js +126 -1
  312. package/dist/test/onboarding.test.js.map +1 -1
  313. package/dist/test/providers/anthropic.test.js +120 -0
  314. package/dist/test/providers/anthropic.test.js.map +1 -1
  315. package/dist/test/providers/azure.test.js +22 -25
  316. package/dist/test/providers/azure.test.js.map +1 -1
  317. package/dist/test/providers/bedrock.test.js +178 -55
  318. package/dist/test/providers/bedrock.test.js.map +1 -1
  319. package/dist/test/providers/index.test.js +7 -7
  320. package/dist/test/providers/index.test.js.map +1 -1
  321. package/dist/test/providers/portkey.test.d.ts +2 -0
  322. package/dist/test/providers/portkey.test.d.ts.map +1 -0
  323. package/dist/test/providers/portkey.test.js +46 -0
  324. package/dist/test/providers/portkey.test.js.map +1 -0
  325. package/dist/test/redteam/commands/init.test.d.ts +2 -0
  326. package/dist/test/redteam/commands/init.test.d.ts.map +1 -0
  327. package/dist/test/redteam/commands/init.test.js +109 -0
  328. package/dist/test/redteam/commands/init.test.js.map +1 -0
  329. package/dist/test/redteam/plugins/pluginDocumentation.test.js +4 -1
  330. package/dist/test/redteam/plugins/pluginDocumentation.test.js.map +1 -1
  331. package/dist/test/redteam/providers/goat.test.js +1 -1
  332. package/dist/test/redteam/providers/goat.test.js.map +1 -1
  333. package/dist/test/redteam/providers/iterativeTree.test.js +8 -3
  334. package/dist/test/redteam/providers/iterativeTree.test.js.map +1 -1
  335. package/dist/test/util/config/load.test.js +44 -1
  336. package/dist/test/util/config/load.test.js.map +1 -1
  337. package/dist/tsconfig.tsbuildinfo +1 -1
  338. package/package.json +19 -17
  339. package/dist/src/providers/azureopenai.d.ts.map +0 -1
  340. package/dist/src/providers/azureopenai.js.map +0 -1
  341. package/dist/src/providers/azureopenaiUtil.d.ts.map +0 -1
  342. package/dist/src/providers/azureopenaiUtil.js.map +0 -1
  343. package/dist/src/redteam/eval/excessive-agency/llm_rubric-20240617.json +0 -10
  344. package/dist/src/redteam/eval/excessive-agency/llm_rubric-20240618.json +0 -10
  345. package/dist/src/redteam/eval/harmful/llm_rubric-20240723.json +0 -10
  346. package/dist/src/redteam/eval/harmful/llm_rubric-20240724.json +0 -10
  347. package/dist/test/is-sql-tests/node-sql-parser.test.d.ts +0 -2
  348. package/dist/test/is-sql-tests/node-sql-parser.test.d.ts.map +0 -1
  349. package/dist/test/is-sql-tests/node-sql-parser.test.js +0 -179
  350. package/dist/test/is-sql-tests/node-sql-parser.test.js.map +0 -1
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.handleIsValidOpenAiToolsCall = exports.handleIsValidOpenAiFunctionCall = void 0;
4
+ const openaiUtil_1 = require("../providers/openaiUtil");
5
+ const handleIsValidOpenAiFunctionCall = ({ assertion, output, provider, test, }) => {
6
+ const functionOutput = output;
7
+ if (typeof functionOutput !== 'object' ||
8
+ typeof functionOutput.name !== 'string' ||
9
+ typeof functionOutput.arguments !== 'string') {
10
+ return {
11
+ pass: false,
12
+ score: 0,
13
+ reason: `OpenAI did not return a valid-looking function call: ${JSON.stringify(functionOutput)}`,
14
+ assertion,
15
+ };
16
+ }
17
+ try {
18
+ (0, openaiUtil_1.validateFunctionCall)(functionOutput, provider.config.functions, test.vars);
19
+ return {
20
+ pass: true,
21
+ score: 1,
22
+ reason: 'Assertion passed',
23
+ assertion,
24
+ };
25
+ }
26
+ catch (err) {
27
+ return {
28
+ pass: false,
29
+ score: 0,
30
+ reason: err.message,
31
+ assertion,
32
+ };
33
+ }
34
+ };
35
+ exports.handleIsValidOpenAiFunctionCall = handleIsValidOpenAiFunctionCall;
36
+ const handleIsValidOpenAiToolsCall = ({ assertion, output, provider, test, }) => {
37
+ const toolsOutput = output;
38
+ if (!Array.isArray(toolsOutput) ||
39
+ toolsOutput.length === 0 ||
40
+ typeof toolsOutput[0].function.name !== 'string' ||
41
+ typeof toolsOutput[0].function.arguments !== 'string') {
42
+ return {
43
+ pass: false,
44
+ score: 0,
45
+ reason: `OpenAI did not return a valid-looking tools response: ${JSON.stringify(toolsOutput)}`,
46
+ assertion,
47
+ };
48
+ }
49
+ try {
50
+ toolsOutput.forEach((toolOutput) => (0, openaiUtil_1.validateFunctionCall)(toolOutput.function, provider.config.tools?.map((tool) => tool.function), test.vars));
51
+ return {
52
+ pass: true,
53
+ score: 1,
54
+ reason: 'Assertion passed',
55
+ assertion,
56
+ };
57
+ }
58
+ catch (err) {
59
+ return {
60
+ pass: false,
61
+ score: 0,
62
+ reason: err.message,
63
+ assertion,
64
+ };
65
+ }
66
+ };
67
+ exports.handleIsValidOpenAiToolsCall = handleIsValidOpenAiToolsCall;
68
+ //# sourceMappingURL=openai.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.js","sourceRoot":"","sources":["../../../src/assertions/openai.ts"],"names":[],"mappings":";;;AACA,wDAA+D;AAIxD,MAAM,+BAA+B,GAAG,CAAC,EAC9C,SAAS,EACT,MAAM,EACN,QAAQ,EACR,IAAI,GACY,EAAiB,EAAE;IACnC,MAAM,cAAc,GAAG,MAA6C,CAAC;IACrE,IACE,OAAO,cAAc,KAAK,QAAQ;QAClC,OAAO,cAAc,CAAC,IAAI,KAAK,QAAQ;QACvC,OAAO,cAAc,CAAC,SAAS,KAAK,QAAQ,EAC5C,CAAC;QACD,OAAO;YACL,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,CAAC;YACR,MAAM,EAAE,wDAAwD,IAAI,CAAC,SAAS,CAC5E,cAAc,CACf,EAAE;YACH,SAAS;SACV,CAAC;IACJ,CAAC;IACD,IAAI,CAAC;QACH,IAAA,iCAAoB,EAClB,cAAc,EACb,QAAyC,CAAC,MAAM,CAAC,SAAS,EAC3D,IAAI,CAAC,IAAI,CACV,CAAC;QACF,OAAO;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,CAAC;YACR,MAAM,EAAE,kBAAkB;YAC1B,SAAS;SACV,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO;YACL,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,CAAC;YACR,MAAM,EAAG,GAAa,CAAC,OAAO;YAC9B,SAAS;SACV,CAAC;IACJ,CAAC;AACH,CAAC,CAAC;AAzCW,QAAA,+BAA+B,mCAyC1C;AAEK,MAAM,4BAA4B,GAAG,CAAC,EAC3C,SAAS,EACT,MAAM,EACN,QAAQ,EACR,IAAI,GACY,EAAiB,EAAE;IACnC,MAAM,WAAW,GAAG,MAGjB,CAAC;IACJ,IACE,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC;QAC3B,WAAW,CAAC,MAAM,KAAK,CAAC;QACxB,OAAO,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,KAAK,QAAQ;QAChD,OAAO,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,KAAK,QAAQ,EACrD,CAAC;QACD,OAAO;YACL,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,CAAC;YACR,MAAM,EAAE,yDAAyD,IAAI,CAAC,SAAS,CAC7E,WAAW,CACZ,EAAE;YACH,SAAS;SACV,CAAC;IACJ,CAAC;IAED,IAAI,CAAC;QACH,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE,CACjC,IAAA,iCAAoB,EAClB,UAAU,CAAC,QAAQ,EAClB,QAAyC,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,EACrF,IAAI,CAAC,IAAI,CACV,CACF,CAAC;QACF,OAAO;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,CAAC;YACR,MAAM,EAAE,kBAAkB;YAC1B,SAAS;SACV,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO;YACL,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,CAAC;YACR,MAAM,EAAG,GAAa,CAAC,OAAO;YAC9B,SAAS;SACV,CAAC;IACJ,CAAC;AACH,CAAC,CAAC;AAhDW,QAAA,4BAA4B,gCAgDvC"}
@@ -0,0 +1,4 @@
1
+ import type { AssertionParams, GradingResult } from '../types';
2
+ export declare function handlePerplexity({ logProbs, assertion }: AssertionParams): GradingResult;
3
+ export declare function handlePerplexityScore({ logProbs, assertion }: AssertionParams): GradingResult;
4
+ //# sourceMappingURL=perplexity.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"perplexity.d.ts","sourceRoot":"","sources":["../../../src/assertions/perplexity.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE/D,wBAAgB,gBAAgB,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,eAAe,GAAG,aAAa,CAiBxF;AAED,wBAAgB,qBAAqB,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,eAAe,GAAG,aAAa,CAsB7F"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.handlePerplexity = handlePerplexity;
4
+ exports.handlePerplexityScore = handlePerplexityScore;
5
+ function handlePerplexity({ logProbs, assertion }) {
6
+ if (!logProbs || logProbs.length === 0) {
7
+ throw new Error('Perplexity assertion does not support providers that do not return logProbs');
8
+ }
9
+ const sumLogProbs = logProbs.reduce((acc, logProb) => acc + logProb, 0);
10
+ const avgLogProb = sumLogProbs / logProbs.length;
11
+ const perplexity = Math.exp(-avgLogProb);
12
+ const pass = assertion.threshold ? perplexity <= assertion.threshold : true;
13
+ return {
14
+ pass,
15
+ score: pass ? 1 : 0,
16
+ reason: pass
17
+ ? 'Assertion passed'
18
+ : `Perplexity ${perplexity.toFixed(2)} is greater than threshold ${assertion.threshold}`,
19
+ assertion,
20
+ };
21
+ }
22
+ function handlePerplexityScore({ logProbs, assertion }) {
23
+ if (!logProbs || logProbs.length === 0) {
24
+ throw new Error('perplexity-score assertion does not support providers that do not return logProbs');
25
+ }
26
+ const sumLogProbs = logProbs.reduce((acc, logProb) => acc + logProb, 0);
27
+ const avgLogProb = sumLogProbs / logProbs.length;
28
+ const perplexity = Math.exp(-avgLogProb);
29
+ const perplexityNorm = 1 / (1 + perplexity);
30
+ const pass = assertion.threshold ? perplexityNorm >= assertion.threshold : true;
31
+ return {
32
+ pass,
33
+ score: perplexityNorm,
34
+ reason: pass
35
+ ? 'Assertion passed'
36
+ : `Perplexity score ${perplexityNorm.toFixed(2)} is less than threshold ${assertion.threshold}`,
37
+ assertion,
38
+ };
39
+ }
40
+ //# sourceMappingURL=perplexity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"perplexity.js","sourceRoot":"","sources":["../../../src/assertions/perplexity.ts"],"names":[],"mappings":";;AAEA,4CAiBC;AAED,sDAsBC;AAzCD,SAAgB,gBAAgB,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAmB;IACvE,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvC,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;IACjG,CAAC;IACD,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC;IACxE,MAAM,UAAU,GAAG,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC;IACjD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC;IAEzC,MAAM,IAAI,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,IAAI,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC;IAC5E,OAAO;QACL,IAAI;QACJ,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnB,MAAM,EAAE,IAAI;YACV,CAAC,CAAC,kBAAkB;YACpB,CAAC,CAAC,cAAc,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,8BAA8B,SAAS,CAAC,SAAS,EAAE;QAC1F,SAAS;KACV,CAAC;AACJ,CAAC;AAED,SAAgB,qBAAqB,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAmB;IAC5E,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvC,MAAM,IAAI,KAAK,CACb,mFAAmF,CACpF,CAAC;IACJ,CAAC;IACD,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC;IACxE,MAAM,UAAU,GAAG,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC;IACjD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC;IACzC,MAAM,cAAc,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC;IAE5C,MAAM,IAAI,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,cAAc,IAAI,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC;IAChF,OAAO;QACL,IAAI;QACJ,KAAK,EAAE,cAAc;QACrB,MAAM,EAAE,IAAI;YACV,CAAC,CAAC,kBAAkB;YACpB,CAAC,CAAC,oBAAoB,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,2BAC3C,SAAS,CAAC,SACZ,EAAE;QACN,SAAS;KACV,CAAC;AACJ,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { AssertionParams } from '../types';
2
+ import { type GradingResult } from '../types';
3
+ export declare const handlePython: ({ assertion, renderedValue, valueFromScript, context, output, }: AssertionParams) => Promise<GradingResult>;
4
+ //# sourceMappingURL=python.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"python.d.ts","sourceRoot":"","sources":["../../../src/assertions/python.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAChD,OAAO,EAAE,KAAK,aAAa,EAAmB,MAAM,UAAU,CAAC;AAE/D,eAAO,MAAM,YAAY,oEAMtB,eAAe,KAAG,OAAO,CAAC,aAAa,CA0GzC,CAAC"}
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.handlePython = void 0;
7
+ const tiny_invariant_1 = __importDefault(require("tiny-invariant"));
8
+ const wrapper_1 = require("../python/wrapper");
9
+ const types_1 = require("../types");
10
+ const handlePython = async ({ assertion, renderedValue, valueFromScript, context, output, }) => {
11
+ (0, tiny_invariant_1.default)(typeof renderedValue === 'string', 'python assertion must have a string value');
12
+ let pass;
13
+ let score;
14
+ try {
15
+ let result;
16
+ if (typeof valueFromScript === 'undefined') {
17
+ const isMultiline = renderedValue.includes('\n');
18
+ let indentStyle = ' ';
19
+ if (isMultiline) {
20
+ // Detect the indentation style of the first indented line
21
+ const match = renderedValue.match(/^(?!\s*$)\s+/m);
22
+ if (match) {
23
+ indentStyle = match[0];
24
+ }
25
+ }
26
+ const pythonScript = `import json
27
+
28
+ def main(output, context):
29
+ ${isMultiline
30
+ ? renderedValue
31
+ .split('\n')
32
+ .map((line) => `${indentStyle}${line}`)
33
+ .join('\n')
34
+ : ` return ${renderedValue}`}
35
+ `;
36
+ result = await (0, wrapper_1.runPythonCode)(pythonScript, 'main', [output, context]);
37
+ }
38
+ else {
39
+ result = valueFromScript;
40
+ }
41
+ if ((typeof result === 'boolean' && result) ||
42
+ (typeof result === 'string' && result.toLowerCase() === 'true')) {
43
+ pass = true;
44
+ score = 1.0;
45
+ }
46
+ else if ((typeof result === 'boolean' && !result) ||
47
+ (typeof result === 'string' && result.toLowerCase() === 'false')) {
48
+ pass = false;
49
+ score = 0.0;
50
+ }
51
+ else if (typeof result === 'string' && result.startsWith('{')) {
52
+ let parsed;
53
+ try {
54
+ parsed = JSON.parse(result);
55
+ }
56
+ catch (err) {
57
+ throw new Error(`Invalid JSON: ${err} when parsing result: ${result}`);
58
+ }
59
+ if (!(0, types_1.isGradingResult)(parsed)) {
60
+ throw new Error(`Python assertion must return a boolean, number, or {pass, score, reason} object. Got instead: ${result}`);
61
+ }
62
+ return parsed;
63
+ }
64
+ else if (typeof result === 'object') {
65
+ if (!(0, types_1.isGradingResult)(result)) {
66
+ throw new Error(`Python assertion must return a boolean, number, or {pass, score, reason} object. Got instead:\n${JSON.stringify(result, null, 2)}`);
67
+ }
68
+ const pythonGradingResult = result;
69
+ if (assertion.threshold && pythonGradingResult.score < assertion.threshold) {
70
+ pythonGradingResult.pass = false;
71
+ pythonGradingResult.reason = `Python score ${pythonGradingResult.score} is less than threshold ${assertion.threshold}`;
72
+ }
73
+ return {
74
+ ...pythonGradingResult,
75
+ assertion,
76
+ };
77
+ }
78
+ else {
79
+ score = Number.parseFloat(String(result));
80
+ pass = assertion.threshold ? score >= assertion.threshold : score > 0;
81
+ if (Number.isNaN(score)) {
82
+ throw new Error(`Python assertion must return a boolean, number, or {pass, score, reason} object. Instead got:\n${result}`);
83
+ }
84
+ if (typeof assertion.threshold !== 'undefined' && score < assertion.threshold) {
85
+ pass = false;
86
+ }
87
+ }
88
+ }
89
+ catch (err) {
90
+ return {
91
+ pass: false,
92
+ score: 0,
93
+ reason: `Python code execution failed: ${err.message}`,
94
+ assertion,
95
+ };
96
+ }
97
+ return {
98
+ pass,
99
+ score,
100
+ reason: pass
101
+ ? 'Assertion passed'
102
+ : `Python code returned ${pass ? 'true' : 'false'}\n${assertion.value}`,
103
+ assertion,
104
+ };
105
+ };
106
+ exports.handlePython = handlePython;
107
+ //# sourceMappingURL=python.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"python.js","sourceRoot":"","sources":["../../../src/assertions/python.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { AssertionParams, GradingResult } from '../types';
2
+ export declare const handleRedteam: ({ assertion, baseType, test, prompt, outputString, provider, renderedValue, }: AssertionParams) => Promise<GradingResult>;
3
+ //# sourceMappingURL=redteam.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redteam.d.ts","sourceRoot":"","sources":["../../../src/assertions/redteam.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE/D,eAAO,MAAM,aAAa,kFAQvB,eAAe,KAAG,OAAO,CAAC,aAAa,CAwBzC,CAAC"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.handleRedteam = void 0;
7
+ const tiny_invariant_1 = __importDefault(require("tiny-invariant"));
8
+ const graders_1 = require("../redteam/graders");
9
+ const handleRedteam = async ({ assertion, baseType, test, prompt, outputString, provider, renderedValue, }) => {
10
+ const grader = (0, graders_1.getGraderById)(assertion.type);
11
+ (0, tiny_invariant_1.default)(grader, `Unknown promptfoo grader: ${baseType}`);
12
+ (0, tiny_invariant_1.default)(prompt, `Promptfoo grader ${baseType} must have a prompt`);
13
+ const { grade, rubric, suggestions } = await grader.getResult(prompt, outputString, test, provider, renderedValue);
14
+ return {
15
+ assertion: {
16
+ ...assertion,
17
+ value: rubric,
18
+ },
19
+ ...grade,
20
+ suggestions,
21
+ metadata: {
22
+ // Pass through all test metadata for redteam
23
+ ...test.metadata,
24
+ ...grade.metadata,
25
+ },
26
+ };
27
+ };
28
+ exports.handleRedteam = handleRedteam;
29
+ //# sourceMappingURL=redteam.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redteam.js","sourceRoot":"","sources":["../../../src/assertions/redteam.ts"],"names":[],"mappings":";;;;;;AAAA,oEAAuC;AACvC,gDAAmD;AAG5C,MAAM,aAAa,GAAG,KAAK,EAAE,EAClC,SAAS,EACT,QAAQ,EACR,IAAI,EACJ,MAAM,EACN,YAAY,EACZ,QAAQ,EACR,aAAa,GACG,EAA0B,EAAE;IAC5C,MAAM,MAAM,GAAG,IAAA,uBAAa,EAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAC7C,IAAA,wBAAS,EAAC,MAAM,EAAE,6BAA6B,QAAQ,EAAE,CAAC,CAAC;IAC3D,IAAA,wBAAS,EAAC,MAAM,EAAE,oBAAoB,QAAQ,qBAAqB,CAAC,CAAC;IACrE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,MAAM,CAAC,SAAS,CAC3D,MAAM,EACN,YAAY,EACZ,IAAI,EACJ,QAAQ,EACR,aAAa,CACd,CAAC;IACF,OAAO;QACL,SAAS,EAAE;YACT,GAAG,SAAS;YACZ,KAAK,EAAE,MAAM;SACd;QACD,GAAG,KAAK;QACR,WAAW;QACX,QAAQ,EAAE;YACR,6CAA6C;YAC7C,GAAG,IAAI,CAAC,QAAQ;YAChB,GAAG,KAAK,CAAC,QAAQ;SAClB;KACF,CAAC;AACJ,CAAC,CAAC;AAhCW,QAAA,aAAa,iBAgCxB"}
@@ -0,0 +1,3 @@
1
+ import type { AssertionParams, GradingResult } from '../types';
2
+ export declare const handleRegex: ({ assertion, renderedValue, outputString, inverse, }: AssertionParams) => GradingResult;
3
+ //# sourceMappingURL=regex.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"regex.d.ts","sourceRoot":"","sources":["../../../src/assertions/regex.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE/D,eAAO,MAAM,WAAW,yDAKrB,eAAe,KAAG,aAuBpB,CAAC"}
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.handleRegex = void 0;
7
+ const tiny_invariant_1 = __importDefault(require("tiny-invariant"));
8
+ const handleRegex = ({ assertion, renderedValue, outputString, inverse, }) => {
9
+ (0, tiny_invariant_1.default)(renderedValue, '"regex" assertion type must have a string value');
10
+ (0, tiny_invariant_1.default)(typeof renderedValue === 'string', '"regex" assertion type must have a string value');
11
+ let regex;
12
+ try {
13
+ regex = new RegExp(renderedValue);
14
+ }
15
+ catch (error) {
16
+ return {
17
+ pass: false,
18
+ score: 0,
19
+ reason: `Invalid regex pattern: ${error instanceof Error ? error.message : 'unknown error'}`,
20
+ assertion,
21
+ };
22
+ }
23
+ const pass = regex.test(outputString) !== inverse;
24
+ return {
25
+ pass,
26
+ score: pass ? 1 : 0,
27
+ reason: pass
28
+ ? 'Assertion passed'
29
+ : `Expected output to ${inverse ? 'not ' : ''}match regex "${renderedValue}"`,
30
+ assertion,
31
+ };
32
+ };
33
+ exports.handleRegex = handleRegex;
34
+ //# sourceMappingURL=regex.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"regex.js","sourceRoot":"","sources":["../../../src/assertions/regex.ts"],"names":[],"mappings":";;;;;;AAAA,oEAAuC;AAGhC,MAAM,WAAW,GAAG,CAAC,EAC1B,SAAS,EACT,aAAa,EACb,YAAY,EACZ,OAAO,GACS,EAAiB,EAAE;IACnC,IAAA,wBAAS,EAAC,aAAa,EAAE,iDAAiD,CAAC,CAAC;IAC5E,IAAA,wBAAS,EAAC,OAAO,aAAa,KAAK,QAAQ,EAAE,iDAAiD,CAAC,CAAC;IAChG,IAAI,KAAa,CAAC;IAClB,IAAI,CAAC;QACH,KAAK,GAAG,IAAI,MAAM,CAAC,aAAa,CAAC,CAAC;IACpC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO;YACL,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,CAAC;YACR,MAAM,EAAE,0BAA0B,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,EAAE;YAC5F,SAAS;SACV,CAAC;IACJ,CAAC;IACD,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,OAAO,CAAC;IAClD,OAAO;QACL,IAAI;QACJ,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnB,MAAM,EAAE,IAAI;YACV,CAAC,CAAC,kBAAkB;YACpB,CAAC,CAAC,sBAAsB,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,gBAAgB,aAAa,GAAG;QAC/E,SAAS;KACV,CAAC;AACJ,CAAC,CAAC;AA5BW,QAAA,WAAW,eA4BtB"}
@@ -0,0 +1,3 @@
1
+ import type { AssertionParams, GradingResult } from '../types';
2
+ export declare function handleRougeScore({ baseType, assertion, renderedValue, outputString, inverse, }: AssertionParams): GradingResult;
3
+ //# sourceMappingURL=rouge.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rouge.d.ts","sourceRoot":"","sources":["../../../src/assertions/rouge.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE/D,wBAAgB,gBAAgB,CAAC,EAC/B,QAAQ,EACR,SAAS,EACT,aAAa,EACb,YAAY,EACZ,OAAO,GACR,EAAE,eAAe,GAAG,aAAa,CAkBjC"}
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.handleRougeScore = handleRougeScore;
30
+ const rouge = __importStar(require("js-rouge"));
31
+ const tiny_invariant_1 = __importDefault(require("tiny-invariant"));
32
+ function handleRougeScore({ baseType, assertion, renderedValue, outputString, inverse, }) {
33
+ (0, tiny_invariant_1.default)(typeof renderedValue === 'string', '"rouge" assertion type must be a string value');
34
+ const fnName = baseType[baseType.length - 1];
35
+ const rougeMethod = rouge[fnName];
36
+ const score = rougeMethod(outputString, renderedValue, {});
37
+ const pass = score >= (assertion.threshold || 0.75) != inverse;
38
+ return {
39
+ pass,
40
+ score: inverse ? 1 - score : score,
41
+ reason: pass
42
+ ? `${baseType.toUpperCase()} score ${score.toFixed(2)} is greater than or equal to threshold ${assertion.threshold || 0.75}`
43
+ : `${baseType.toUpperCase()} score ${score.toFixed(2)} is less than threshold ${assertion.threshold || 0.75}`,
44
+ assertion,
45
+ };
46
+ }
47
+ //# sourceMappingURL=rouge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rouge.js","sourceRoot":"","sources":["../../../src/assertions/rouge.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,4CAwBC;AA5BD,gDAAkC;AAClC,oEAAuC;AAGvC,SAAgB,gBAAgB,CAAC,EAC/B,QAAQ,EACR,SAAS,EACT,aAAa,EACb,YAAY,EACZ,OAAO,GACS;IAChB,IAAA,wBAAS,EAAC,OAAO,aAAa,KAAK,QAAQ,EAAE,+CAA+C,CAAC,CAAC;IAC9F,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAoB,CAAC;IAChE,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;IAClC,MAAM,KAAK,GAAG,WAAW,CAAC,YAAY,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;IAC3D,MAAM,IAAI,GAAG,KAAK,IAAI,CAAC,SAAS,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,OAAO,CAAC;IAC/D,OAAO;QACL,IAAI;QACJ,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK;QAClC,MAAM,EAAE,IAAI;YACV,CAAC,CAAC,GAAG,QAAQ,CAAC,WAAW,EAAE,UAAU,KAAK,CAAC,OAAO,CAC9C,CAAC,CACF,0CAA0C,SAAS,CAAC,SAAS,IAAI,IAAI,EAAE;YAC1E,CAAC,CAAC,GAAG,QAAQ,CAAC,WAAW,EAAE,UAAU,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,2BACjD,SAAS,CAAC,SAAS,IAAI,IACzB,EAAE;QACN,SAAS;KACV,CAAC;AACJ,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { AssertionParams, GradingResult } from '../types';
2
+ export declare const handleSimilar: ({ assertion, renderedValue, outputString, inverse, test, }: AssertionParams) => Promise<GradingResult>;
3
+ //# sourceMappingURL=similar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"similar.d.ts","sourceRoot":"","sources":["../../../src/assertions/similar.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE/D,eAAO,MAAM,aAAa,+DAMvB,eAAe,KAAG,OAAO,CAAC,aAAa,CA2CzC,CAAC"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.handleSimilar = void 0;
7
+ const tiny_invariant_1 = __importDefault(require("tiny-invariant"));
8
+ const matchers_1 = require("../matchers");
9
+ const handleSimilar = async ({ assertion, renderedValue, outputString, inverse, test, }) => {
10
+ (0, tiny_invariant_1.default)(typeof renderedValue === 'string' || Array.isArray(renderedValue), 'Similarity assertion type must have a string or array of strings value');
11
+ if (Array.isArray(renderedValue)) {
12
+ let minScore = Infinity;
13
+ for (const value of renderedValue) {
14
+ const result = await (0, matchers_1.matchesSimilarity)(value, outputString, assertion.threshold || 0.75, inverse, test.options);
15
+ if (result.pass) {
16
+ return {
17
+ assertion,
18
+ ...result,
19
+ };
20
+ }
21
+ if (result.score < minScore) {
22
+ minScore = result.score;
23
+ }
24
+ }
25
+ return {
26
+ assertion,
27
+ pass: false,
28
+ score: minScore,
29
+ reason: `None of the provided values met the similarity threshold`,
30
+ };
31
+ }
32
+ else {
33
+ return {
34
+ assertion,
35
+ ...(await (0, matchers_1.matchesSimilarity)(renderedValue, outputString, assertion.threshold || 0.75, inverse, test.options)),
36
+ };
37
+ }
38
+ };
39
+ exports.handleSimilar = handleSimilar;
40
+ //# sourceMappingURL=similar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"similar.js","sourceRoot":"","sources":["../../../src/assertions/similar.ts"],"names":[],"mappings":";;;;;;AAAA,oEAAuC;AACvC,0CAAgD;AAGzC,MAAM,aAAa,GAAG,KAAK,EAAE,EAClC,SAAS,EACT,aAAa,EACb,YAAY,EACZ,OAAO,EACP,IAAI,GACY,EAA0B,EAAE;IAC5C,IAAA,wBAAS,EACP,OAAO,aAAa,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,EACjE,wEAAwE,CACzE,CAAC;IACF,IAAI,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;QACjC,IAAI,QAAQ,GAAG,QAAQ,CAAC;QACxB,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;YAClC,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAiB,EACpC,KAAK,EACL,YAAY,EACZ,SAAS,CAAC,SAAS,IAAI,IAAI,EAC3B,OAAO,EACP,IAAI,CAAC,OAAO,CACb,CAAC;YACF,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;gBAChB,OAAO;oBACL,SAAS;oBACT,GAAG,MAAM;iBACV,CAAC;YACJ,CAAC;YACD,IAAI,MAAM,CAAC,KAAK,GAAG,QAAQ,EAAE,CAAC;gBAC5B,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC;YAC1B,CAAC;QACH,CAAC;QACD,OAAO;YACL,SAAS;YACT,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,0DAA0D;SACnE,CAAC;IACJ,CAAC;SAAM,CAAC;QACN,OAAO;YACL,SAAS;YACT,GAAG,CAAC,MAAM,IAAA,4BAAiB,EACzB,aAAa,EACb,YAAY,EACZ,SAAS,CAAC,SAAS,IAAI,IAAI,EAC3B,OAAO,EACP,IAAI,CAAC,OAAO,CACb,CAAC;SACH,CAAC;IACJ,CAAC;AACH,CAAC,CAAC;AAjDW,QAAA,aAAa,iBAiDxB"}
@@ -0,0 +1,4 @@
1
+ import type { AssertionParams, GradingResult } from '../types';
2
+ export declare const handleIsSql: ({ assertion, renderedValue, outputString, inverse, }: AssertionParams) => Promise<GradingResult>;
3
+ export declare const handleContainsSql: (assertionParams: AssertionParams) => Promise<GradingResult>;
4
+ //# sourceMappingURL=sql.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql.d.ts","sourceRoot":"","sources":["../../../src/assertions/sql.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAG/D,eAAO,MAAM,WAAW,yDAKrB,eAAe,KAAG,OAAO,CAAC,aAAa,CAyEzC,CAAC;AAEF,eAAO,MAAM,iBAAiB,oBACX,eAAe,KAC/B,OAAO,CAAC,aAAa,CAOvB,CAAC"}
@@ -0,0 +1,98 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.handleContainsSql = exports.handleIsSql = void 0;
27
+ const utils_1 = require("./utils");
28
+ const handleIsSql = async ({ assertion, renderedValue, outputString, inverse, }) => {
29
+ let pass = false;
30
+ let databaseType = 'MySQL';
31
+ let whiteTableList;
32
+ let whiteColumnList;
33
+ if (renderedValue && typeof renderedValue === 'object') {
34
+ const value = renderedValue;
35
+ databaseType = value.databaseType || 'MySQL';
36
+ whiteTableList = value.allowedTables;
37
+ whiteColumnList = value.allowedColumns;
38
+ }
39
+ if (renderedValue && typeof renderedValue !== 'object') {
40
+ throw new Error('is-sql assertion must have a object value.');
41
+ }
42
+ const { Parser: SqlParser } = await Promise.resolve().then(() => __importStar(require('node-sql-parser'))).catch(() => {
43
+ throw new Error('node-sql-parser is not installed. Please install it first');
44
+ });
45
+ const sqlParser = new SqlParser();
46
+ const opt = { database: databaseType };
47
+ const failureReasons = [];
48
+ try {
49
+ sqlParser.astify(outputString, opt);
50
+ pass = !inverse;
51
+ }
52
+ catch {
53
+ pass = inverse;
54
+ failureReasons.push(`SQL statement does not conform to the provided ${databaseType} database syntax.`);
55
+ }
56
+ if (whiteTableList) {
57
+ opt.type = 'table';
58
+ try {
59
+ sqlParser.whiteListCheck(outputString, whiteTableList, opt);
60
+ }
61
+ catch (err) {
62
+ pass = inverse;
63
+ const error = err;
64
+ failureReasons.push(`SQL validation failed: ${error.message}.`);
65
+ }
66
+ }
67
+ if (whiteColumnList) {
68
+ opt.type = 'column';
69
+ try {
70
+ sqlParser.whiteListCheck(outputString, whiteColumnList, opt);
71
+ }
72
+ catch (err) {
73
+ pass = inverse;
74
+ const error = err;
75
+ failureReasons.push(`SQL validation failed: ${error.message}.`);
76
+ }
77
+ }
78
+ if (inverse && pass === false && failureReasons.length === 0) {
79
+ failureReasons.push('The output SQL statement is valid');
80
+ }
81
+ return {
82
+ pass,
83
+ score: pass ? 1 : 0,
84
+ reason: pass ? 'Assertion passed' : failureReasons.join(' '),
85
+ assertion,
86
+ };
87
+ };
88
+ exports.handleIsSql = handleIsSql;
89
+ const handleContainsSql = async (assertionParams) => {
90
+ const match = (0, utils_1.coerceString)(assertionParams.outputString).match(/```(?:sql)?([^`]+)```/);
91
+ if (match) {
92
+ const sqlCode = match[1].trim();
93
+ return (0, exports.handleIsSql)({ ...assertionParams, outputString: sqlCode });
94
+ }
95
+ return (0, exports.handleIsSql)(assertionParams);
96
+ };
97
+ exports.handleContainsSql = handleContainsSql;
98
+ //# sourceMappingURL=sql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql.js","sourceRoot":"","sources":["../../../src/assertions/sql.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { AssertionParams, GradingResult } from '../types';
2
+ export declare const handleStartsWith: ({ assertion, renderedValue, outputString, inverse, }: AssertionParams) => GradingResult;
3
+ //# sourceMappingURL=startsWith.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"startsWith.d.ts","sourceRoot":"","sources":["../../../src/assertions/startsWith.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE/D,eAAO,MAAM,gBAAgB,yDAK1B,eAAe,KAAG,aAepB,CAAC"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.handleStartsWith = void 0;
7
+ const tiny_invariant_1 = __importDefault(require("tiny-invariant"));
8
+ const handleStartsWith = ({ assertion, renderedValue, outputString, inverse, }) => {
9
+ (0, tiny_invariant_1.default)(renderedValue, '"starts-with" assertion type must have a string value');
10
+ (0, tiny_invariant_1.default)(typeof renderedValue === 'string', '"starts-with" assertion type must have a string value');
11
+ const pass = outputString.startsWith(String(renderedValue)) !== inverse;
12
+ return {
13
+ pass,
14
+ score: pass ? 1 : 0,
15
+ reason: pass
16
+ ? 'Assertion passed'
17
+ : `Expected output to ${inverse ? 'not ' : ''}start with "${renderedValue}"`,
18
+ assertion,
19
+ };
20
+ };
21
+ exports.handleStartsWith = handleStartsWith;
22
+ //# sourceMappingURL=startsWith.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"startsWith.js","sourceRoot":"","sources":["../../../src/assertions/startsWith.ts"],"names":[],"mappings":";;;;;;AAAA,oEAAuC;AAGhC,MAAM,gBAAgB,GAAG,CAAC,EAC/B,SAAS,EACT,aAAa,EACb,YAAY,EACZ,OAAO,GACS,EAAiB,EAAE;IACnC,IAAA,wBAAS,EAAC,aAAa,EAAE,uDAAuD,CAAC,CAAC;IAClF,IAAA,wBAAS,EACP,OAAO,aAAa,KAAK,QAAQ,EACjC,uDAAuD,CACxD,CAAC;IACF,MAAM,IAAI,GAAG,YAAY,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,KAAK,OAAO,CAAC;IACxE,OAAO;QACL,IAAI;QACJ,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnB,MAAM,EAAE,IAAI;YACV,CAAC,CAAC,kBAAkB;YACpB,CAAC,CAAC,sBAAsB,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,eAAe,aAAa,GAAG;QAC9E,SAAS;KACV,CAAC;AACJ,CAAC,CAAC;AApBW,QAAA,gBAAgB,oBAoB3B"}
@@ -1,4 +1,5 @@
1
1
  import { type Assertion, type TestCase } from '../types';
2
2
  export declare function getFinalTest(test: TestCase, assertion: Assertion): Readonly<TestCase>;
3
3
  export declare function processFileReference(fileRef: string): object | string;
4
+ export declare function coerceString(value: string | object): string;
4
5
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/assertions/utils.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,QAAQ,EAAE,MAAM,UAAU,CAAC;AAIzD,wBAAgB,YAAY,CAAC,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,sBAUhE;AAED,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAYrE"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/assertions/utils.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,QAAQ,EAAE,MAAM,UAAU,CAAC;AAIzD,wBAAgB,YAAY,CAAC,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,sBAUhE;AAED,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAYrE;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAK3D"}