promptfoo 0.96.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 (162) hide show
  1. package/README.md +1 -0
  2. package/dist/package.json +10 -10
  3. package/dist/src/app/assets/{index-Dwt7E2K_.js → index-CL29fyye.js} +55 -55
  4. package/dist/src/app/assets/{index.es-CooNf3HB.js → index.es-CsYHA4xg.js} +1 -1
  5. package/dist/src/app/assets/{sync-Bj1WJrHQ.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 +4 -14
  12. package/dist/src/assertions/bleu.d.ts.map +1 -1
  13. package/dist/src/assertions/bleu.js +19 -3
  14. package/dist/src/assertions/bleu.js.map +1 -1
  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.map +1 -1
  48. package/dist/src/assertions/index.js +89 -752
  49. package/dist/src/assertions/index.js.map +1 -1
  50. package/dist/src/assertions/javascript.d.ts +4 -0
  51. package/dist/src/assertions/javascript.d.ts.map +1 -0
  52. package/dist/src/assertions/javascript.js +94 -0
  53. package/dist/src/assertions/javascript.js.map +1 -0
  54. package/dist/src/assertions/json.d.ts +3 -4
  55. package/dist/src/assertions/json.d.ts.map +1 -1
  56. package/dist/src/assertions/json.js +2 -2
  57. package/dist/src/assertions/json.js.map +1 -1
  58. package/dist/src/assertions/latency.d.ts +3 -0
  59. package/dist/src/assertions/latency.d.ts.map +1 -0
  60. package/dist/src/assertions/latency.js +22 -0
  61. package/dist/src/assertions/latency.js.map +1 -0
  62. package/dist/src/assertions/levenshtein.d.ts +3 -0
  63. package/dist/src/assertions/levenshtein.d.ts.map +1 -0
  64. package/dist/src/assertions/levenshtein.js +22 -0
  65. package/dist/src/assertions/levenshtein.js.map +1 -0
  66. package/dist/src/assertions/llmRubric.d.ts +3 -0
  67. package/dist/src/assertions/llmRubric.d.ts.map +1 -0
  68. package/dist/src/assertions/llmRubric.js +22 -0
  69. package/dist/src/assertions/llmRubric.js.map +1 -0
  70. package/dist/src/assertions/modelGradedClosedQa.d.ts +3 -0
  71. package/dist/src/assertions/modelGradedClosedQa.d.ts.map +1 -0
  72. package/dist/src/assertions/modelGradedClosedQa.js +25 -0
  73. package/dist/src/assertions/modelGradedClosedQa.js.map +1 -0
  74. package/dist/src/assertions/moderation.d.ts +3 -0
  75. package/dist/src/assertions/moderation.d.ts.map +1 -0
  76. package/dist/src/assertions/moderation.js +41 -0
  77. package/dist/src/assertions/moderation.js.map +1 -0
  78. package/dist/src/assertions/openai.d.ts +5 -0
  79. package/dist/src/assertions/openai.d.ts.map +1 -0
  80. package/dist/src/assertions/openai.js +68 -0
  81. package/dist/src/assertions/openai.js.map +1 -0
  82. package/dist/src/assertions/perplexity.d.ts +3 -3
  83. package/dist/src/assertions/perplexity.d.ts.map +1 -1
  84. package/dist/src/assertions/perplexity.js +2 -2
  85. package/dist/src/assertions/perplexity.js.map +1 -1
  86. package/dist/src/assertions/python.d.ts +4 -0
  87. package/dist/src/assertions/python.d.ts.map +1 -0
  88. package/dist/src/assertions/python.js +107 -0
  89. package/dist/src/assertions/python.js.map +1 -0
  90. package/dist/src/assertions/redteam.d.ts +3 -0
  91. package/dist/src/assertions/redteam.d.ts.map +1 -0
  92. package/dist/src/assertions/redteam.js +29 -0
  93. package/dist/src/assertions/redteam.js.map +1 -0
  94. package/dist/src/assertions/regex.d.ts +3 -0
  95. package/dist/src/assertions/regex.d.ts.map +1 -0
  96. package/dist/src/assertions/regex.js +34 -0
  97. package/dist/src/assertions/regex.js.map +1 -0
  98. package/dist/src/assertions/rouge.d.ts +3 -0
  99. package/dist/src/assertions/rouge.d.ts.map +1 -0
  100. package/dist/src/assertions/rouge.js +47 -0
  101. package/dist/src/assertions/rouge.js.map +1 -0
  102. package/dist/src/assertions/similar.d.ts +3 -0
  103. package/dist/src/assertions/similar.d.ts.map +1 -0
  104. package/dist/src/assertions/similar.js +40 -0
  105. package/dist/src/assertions/similar.js.map +1 -0
  106. package/dist/src/assertions/sql.d.ts +3 -3
  107. package/dist/src/assertions/sql.d.ts.map +1 -1
  108. package/dist/src/assertions/sql.js +14 -3
  109. package/dist/src/assertions/sql.js.map +1 -1
  110. package/dist/src/assertions/startsWith.d.ts +3 -0
  111. package/dist/src/assertions/startsWith.d.ts.map +1 -0
  112. package/dist/src/assertions/startsWith.js +22 -0
  113. package/dist/src/assertions/startsWith.js.map +1 -0
  114. package/dist/src/assertions/utils.d.ts +1 -0
  115. package/dist/src/assertions/utils.d.ts.map +1 -1
  116. package/dist/src/assertions/utils.js +7 -0
  117. package/dist/src/assertions/utils.js.map +1 -1
  118. package/dist/src/assertions/webhook.d.ts +3 -0
  119. package/dist/src/assertions/webhook.d.ts.map +1 -0
  120. package/dist/src/assertions/webhook.js +55 -0
  121. package/dist/src/assertions/webhook.js.map +1 -0
  122. package/dist/src/assertions/xml.d.ts +2 -0
  123. package/dist/src/assertions/xml.d.ts.map +1 -1
  124. package/dist/src/assertions/xml.js +29 -0
  125. package/dist/src/assertions/xml.js.map +1 -1
  126. package/dist/src/fetch.d.ts.map +1 -1
  127. package/dist/src/fetch.js +8 -1
  128. package/dist/src/fetch.js.map +1 -1
  129. package/dist/src/providers/anthropic.d.ts.map +1 -1
  130. package/dist/src/providers/anthropic.js +12 -2
  131. package/dist/src/providers/anthropic.js.map +1 -1
  132. package/dist/src/providers/bedrock.js +1 -1
  133. package/dist/src/redteam/constants.d.ts +4 -3
  134. package/dist/src/redteam/constants.d.ts.map +1 -1
  135. package/dist/src/redteam/constants.js +43 -35
  136. package/dist/src/redteam/constants.js.map +1 -1
  137. package/dist/src/redteam/providers/goat.d.ts +2 -0
  138. package/dist/src/redteam/providers/goat.d.ts.map +1 -1
  139. package/dist/src/redteam/providers/goat.js +9 -2
  140. package/dist/src/redteam/providers/goat.js.map +1 -1
  141. package/dist/src/types/index.d.ts +108 -2
  142. package/dist/src/types/index.d.ts.map +1 -1
  143. package/dist/src/types/index.js +21 -26
  144. package/dist/src/types/index.js.map +1 -1
  145. package/dist/src/util/config/load.js +3 -2
  146. package/dist/src/util/config/load.js.map +1 -1
  147. package/dist/test/assertions/bleu.test.js +38 -13
  148. package/dist/test/assertions/bleu.test.js.map +1 -1
  149. package/dist/test/assertions/sql.test.js +268 -167
  150. package/dist/test/assertions/sql.test.js.map +1 -1
  151. package/dist/test/fetch.test.js +17 -0
  152. package/dist/test/fetch.test.js.map +1 -1
  153. package/dist/test/providers/anthropic.test.js +44 -5
  154. package/dist/test/providers/anthropic.test.js.map +1 -1
  155. package/dist/test/util/config/load.test.js +44 -1
  156. package/dist/test/util/config/load.test.js.map +1 -1
  157. package/dist/tsconfig.tsbuildinfo +1 -1
  158. package/package.json +10 -10
  159. package/dist/src/redteam/eval/excessive-agency/llm_rubric-20240617.json +0 -10
  160. package/dist/src/redteam/eval/excessive-agency/llm_rubric-20240618.json +0 -10
  161. package/dist/src/redteam/eval/harmful/llm_rubric-20240723.json +0 -10
  162. package/dist/src/redteam/eval/harmful/llm_rubric-20240724.json +0 -10
package/README.md CHANGED
@@ -151,6 +151,7 @@ Deterministic eval metrics
151
151
  | `levenshtein` | Levenshtein distance is below a threshold |
152
152
  | `latency` | Latency is below a threshold (milliseconds) |
153
153
  | `perplexity` | Perplexity is below a threshold |
154
+ | `perplexity-score` | Normalized perplexity |
154
155
  | `cost` | Cost is below a threshold (for models with cost info such as GPT) |
155
156
  | `is-valid-openai-function-call` | Ensure that the function call matches the function's JSON schema |
156
157
  | `is-valid-openai-tools-call` | Ensure that all tool calls match the tools JSON schema |
package/dist/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "promptfoo",
3
3
  "description": "LLM eval & testing toolkit",
4
4
  "author": "Ian Webster",
5
- "version": "0.96.0",
5
+ "version": "0.96.1",
6
6
  "license": "MIT",
7
7
  "type": "commonjs",
8
8
  "repository": {
@@ -82,13 +82,13 @@
82
82
  "puppeteer-extra-plugin-stealth": "^2.11.2"
83
83
  },
84
84
  "devDependencies": {
85
- "@aws-sdk/client-bedrock-runtime": "^3.686.0",
86
- "@aws-sdk/credential-provider-sso": "^3.686.0",
85
+ "@aws-sdk/client-bedrock-runtime": "^3.687.0",
86
+ "@aws-sdk/credential-provider-sso": "^3.687.0",
87
87
  "@azure/identity": "^4.5.0",
88
88
  "@eslint/js": "^9.14.0",
89
89
  "@libsql/client": "^0.14.0",
90
90
  "@swc/cli": "^0.5.0",
91
- "@swc/core": "^1.8.0",
91
+ "@swc/core": "^1.9.1",
92
92
  "@swc/jest": "^0.2.37",
93
93
  "@trivago/prettier-plugin-sort-imports": "^4.3.0",
94
94
  "@types/async": "^3.2.24",
@@ -116,7 +116,7 @@
116
116
  "drizzle-kit": "^0.26.2",
117
117
  "esbuild": "^0.24.0",
118
118
  "eslint": "^9.14.0",
119
- "eslint-plugin-jest": "^28.8.3",
119
+ "eslint-plugin-jest": "^28.9.0",
120
120
  "eslint-plugin-react-hooks": "^5.1.0-rc.0",
121
121
  "eslint-plugin-react-refresh": "^0.4.14",
122
122
  "eslint-plugin-unicorn": "^56.0.0",
@@ -124,7 +124,7 @@
124
124
  "jest": "^29.7.0",
125
125
  "jest-watch-typeahead": "^2.2.2",
126
126
  "madge": "^8.0.0",
127
- "nock": "^13.5.5",
127
+ "nock": "^13.5.6",
128
128
  "nodemon": "^3.1.7",
129
129
  "prettier": "^3.3.3",
130
130
  "shx": "^0.3.4",
@@ -147,7 +147,7 @@
147
147
  "@adaline/together-ai": "0.8.0",
148
148
  "@adaline/types": "0.15.0",
149
149
  "@adaline/vertex": "0.8.1",
150
- "@anthropic-ai/sdk": "^0.32.0",
150
+ "@anthropic-ai/sdk": "^0.32.1",
151
151
  "@apidevtools/json-schema-ref-parser": "^11.7.2",
152
152
  "@emotion/react": "^11.13.3",
153
153
  "@emotion/styled": "^11.13.0",
@@ -177,15 +177,15 @@
177
177
  "fast-xml-parser": "^4.5.0",
178
178
  "fastest-levenshtein": "^1.0.16",
179
179
  "glob": "^10.4.3",
180
- "groq-sdk": "^0.7.0",
180
+ "groq-sdk": "^0.8.0",
181
181
  "http-z": "^7.1.1",
182
182
  "inquirer": "^11.1.0",
183
183
  "js-rouge": "3.0.0",
184
184
  "js-yaml": "^4.1.0",
185
- "mathjs": "^13.2.0",
185
+ "mathjs": "^13.2.1",
186
186
  "node-cache": "^5.1.2",
187
187
  "nunjucks": "^3.2.4",
188
- "openai": "^4.70.2",
188
+ "openai": "^4.71.1",
189
189
  "opener": "^1.5.2",
190
190
  "proxy-agent": "^6.4.0",
191
191
  "python-shell": "^5.0.0",