promptfoo 0.96.1 → 0.97.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.
- package/dist/package.json +5 -5
- package/dist/src/app/assets/{index-CL29fyye.js → index-CbxDbiAR.js} +232 -232
- package/dist/src/app/assets/{index.es-CsYHA4xg.js → index.es-Cc9N3uII.js} +1 -1
- package/dist/src/app/assets/{sync-B9AjROwZ.js → sync-BoVzjiAe.js} +1 -1
- package/dist/src/app/index.html +1 -1
- package/dist/src/assertions/index.d.ts.map +1 -1
- package/dist/src/assertions/index.js +1 -2
- package/dist/src/assertions/index.js.map +1 -1
- package/dist/src/assertions/redteam.js +2 -2
- package/dist/src/assertions/redteam.js.map +1 -1
- package/dist/src/commands/eval.d.ts.map +1 -1
- package/dist/src/commands/eval.js +7 -2
- package/dist/src/commands/eval.js.map +1 -1
- package/dist/src/commands/init.d.ts.map +1 -1
- package/dist/src/commands/init.js +3 -0
- package/dist/src/commands/init.js.map +1 -1
- package/dist/src/database/tables.d.ts +25 -6
- package/dist/src/database/tables.d.ts.map +1 -1
- package/dist/src/evaluator.d.ts.map +1 -1
- package/dist/src/evaluator.js +7 -1
- package/dist/src/evaluator.js.map +1 -1
- package/dist/src/index.d.ts +2 -106
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/models/eval.d.ts +1 -0
- package/dist/src/models/eval.d.ts.map +1 -1
- package/dist/src/models/eval.js +2 -0
- package/dist/src/models/eval.js.map +1 -1
- package/dist/src/models/evalResult.d.ts +1 -1
- package/dist/src/models/evalResult.d.ts.map +1 -1
- package/dist/src/models/evalResult.js +1 -1
- package/dist/src/models/evalResult.js.map +1 -1
- package/dist/src/onboarding.d.ts +12 -0
- package/dist/src/onboarding.d.ts.map +1 -1
- package/dist/src/onboarding.js +83 -43
- package/dist/src/onboarding.js.map +1 -1
- package/dist/src/providers/adaline.gateway.js +2 -2
- package/dist/src/providers/adaline.gateway.js.map +1 -1
- package/dist/src/providers/azure.d.ts +10 -3
- package/dist/src/providers/azure.d.ts.map +1 -1
- package/dist/src/providers/azure.js +106 -62
- package/dist/src/providers/azure.js.map +1 -1
- package/dist/src/providers/bedrock.d.ts +4 -1
- package/dist/src/providers/bedrock.d.ts.map +1 -1
- package/dist/src/providers/bedrock.js +18 -2
- package/dist/src/providers/bedrock.js.map +1 -1
- package/dist/src/providers/promptfoo.d.ts +7 -3
- package/dist/src/providers/promptfoo.d.ts.map +1 -1
- package/dist/src/providers/promptfoo.js +7 -7
- package/dist/src/providers/promptfoo.js.map +1 -1
- package/dist/src/providers/simulatedUser.d.ts.map +1 -1
- package/dist/src/providers/simulatedUser.js +5 -0
- package/dist/src/providers/simulatedUser.js.map +1 -1
- package/dist/src/redteam/graders.d.ts +2 -77
- package/dist/src/redteam/graders.d.ts.map +1 -1
- package/dist/src/redteam/graders.js +25 -25
- package/dist/src/redteam/graders.js.map +1 -1
- package/dist/src/redteam/index.d.ts.map +1 -1
- package/dist/src/redteam/index.js +29 -11
- package/dist/src/redteam/index.js.map +1 -1
- package/dist/src/redteam/plugins/base.d.ts +12 -7
- package/dist/src/redteam/plugins/base.d.ts.map +1 -1
- package/dist/src/redteam/plugins/base.js +44 -29
- package/dist/src/redteam/plugins/base.js.map +1 -1
- package/dist/src/redteam/plugins/contracts.d.ts.map +1 -1
- package/dist/src/redteam/plugins/contracts.js +20 -9
- package/dist/src/redteam/plugins/contracts.js.map +1 -1
- package/dist/src/redteam/plugins/crossSessionLeak.d.ts.map +1 -1
- package/dist/src/redteam/plugins/crossSessionLeak.js +21 -10
- package/dist/src/redteam/plugins/crossSessionLeak.js.map +1 -1
- package/dist/src/redteam/plugins/debugAccess.d.ts.map +1 -1
- package/dist/src/redteam/plugins/debugAccess.js +20 -9
- package/dist/src/redteam/plugins/debugAccess.js.map +1 -1
- package/dist/src/redteam/plugins/excessiveAgency.d.ts.map +1 -1
- package/dist/src/redteam/plugins/excessiveAgency.js +18 -7
- package/dist/src/redteam/plugins/excessiveAgency.js.map +1 -1
- package/dist/src/redteam/plugins/hallucination.d.ts.map +1 -1
- package/dist/src/redteam/plugins/hallucination.js +18 -7
- package/dist/src/redteam/plugins/hallucination.js.map +1 -1
- package/dist/src/redteam/plugins/harmful/aligned.d.ts +13 -0
- package/dist/src/redteam/plugins/harmful/aligned.d.ts.map +1 -0
- package/dist/src/redteam/plugins/harmful/aligned.js +29 -0
- package/dist/src/redteam/plugins/harmful/aligned.js.map +1 -0
- package/dist/src/redteam/plugins/harmful/common.d.ts +5 -0
- package/dist/src/redteam/plugins/harmful/common.d.ts.map +1 -0
- package/dist/src/redteam/plugins/harmful/common.js +39 -0
- package/dist/src/redteam/plugins/harmful/common.js.map +1 -0
- package/dist/src/redteam/plugins/harmful/constants.d.ts +10 -0
- package/dist/src/redteam/plugins/harmful/constants.d.ts.map +1 -0
- package/dist/src/redteam/plugins/harmful/constants.js +142 -0
- package/dist/src/redteam/plugins/harmful/constants.js.map +1 -0
- package/dist/src/redteam/plugins/harmful/graders.d.ts +15 -0
- package/dist/src/redteam/plugins/harmful/graders.d.ts.map +1 -0
- package/dist/src/redteam/plugins/harmful/graders.js +94 -0
- package/dist/src/redteam/plugins/harmful/graders.js.map +1 -0
- package/dist/src/redteam/plugins/harmful/unaligned.d.ts +5 -0
- package/dist/src/redteam/plugins/harmful/unaligned.d.ts.map +1 -0
- package/dist/src/redteam/plugins/harmful/unaligned.js +29 -0
- package/dist/src/redteam/plugins/harmful/unaligned.js.map +1 -0
- package/dist/src/redteam/plugins/imitation.d.ts.map +1 -1
- package/dist/src/redteam/plugins/imitation.js +20 -9
- package/dist/src/redteam/plugins/imitation.js.map +1 -1
- package/dist/src/redteam/plugins/index.d.ts +2 -2
- package/dist/src/redteam/plugins/index.d.ts.map +1 -1
- package/dist/src/redteam/plugins/index.js +33 -30
- package/dist/src/redteam/plugins/index.js.map +1 -1
- package/dist/src/redteam/plugins/overreliance.d.ts.map +1 -1
- package/dist/src/redteam/plugins/overreliance.js +18 -7
- package/dist/src/redteam/plugins/overreliance.js.map +1 -1
- package/dist/src/redteam/plugins/pii.d.ts +2 -2
- package/dist/src/redteam/plugins/pii.d.ts.map +1 -1
- package/dist/src/redteam/plugins/pii.js +4 -4
- package/dist/src/redteam/plugins/pii.js.map +1 -1
- package/dist/src/redteam/plugins/politics.d.ts.map +1 -1
- package/dist/src/redteam/plugins/politics.js +20 -9
- package/dist/src/redteam/plugins/politics.js.map +1 -1
- package/dist/src/redteam/plugins/promptExtraction.d.ts.map +1 -1
- package/dist/src/redteam/plugins/promptExtraction.js +23 -12
- package/dist/src/redteam/plugins/promptExtraction.js.map +1 -1
- package/dist/src/redteam/plugins/rbac.d.ts.map +1 -1
- package/dist/src/redteam/plugins/rbac.js +20 -9
- package/dist/src/redteam/plugins/rbac.js.map +1 -1
- package/dist/src/redteam/plugins/shellInjection.d.ts.map +1 -1
- package/dist/src/redteam/plugins/shellInjection.js +20 -9
- package/dist/src/redteam/plugins/shellInjection.js.map +1 -1
- package/dist/src/redteam/plugins/sqlInjection.d.ts.map +1 -1
- package/dist/src/redteam/plugins/sqlInjection.js +18 -7
- package/dist/src/redteam/plugins/sqlInjection.js.map +1 -1
- package/dist/src/redteam/providers/crescendo/index.d.ts +6 -0
- package/dist/src/redteam/providers/crescendo/index.d.ts.map +1 -1
- package/dist/src/redteam/providers/crescendo/index.js +45 -17
- package/dist/src/redteam/providers/crescendo/index.js.map +1 -1
- package/dist/src/redteam/providers/goat.d.ts.map +1 -1
- package/dist/src/redteam/providers/goat.js +23 -1
- package/dist/src/redteam/providers/goat.js.map +1 -1
- package/dist/src/redteam/providers/iterative.d.ts +6 -0
- package/dist/src/redteam/providers/iterative.d.ts.map +1 -1
- package/dist/src/redteam/providers/iterative.js +48 -1
- package/dist/src/redteam/providers/iterative.js.map +1 -1
- package/dist/src/redteam/providers/iterativeImage.d.ts +6 -0
- package/dist/src/redteam/providers/iterativeImage.d.ts.map +1 -1
- package/dist/src/redteam/providers/iterativeImage.js +34 -10
- package/dist/src/redteam/providers/iterativeImage.js.map +1 -1
- package/dist/src/redteam/providers/iterativeTree.d.ts +7 -2
- package/dist/src/redteam/providers/iterativeTree.d.ts.map +1 -1
- package/dist/src/redteam/providers/iterativeTree.js +44 -6
- package/dist/src/redteam/providers/iterativeTree.js.map +1 -1
- package/dist/src/redteam/providers/shared.d.ts +5 -2
- package/dist/src/redteam/providers/shared.d.ts.map +1 -1
- package/dist/src/redteam/providers/shared.js +21 -5
- package/dist/src/redteam/providers/shared.js.map +1 -1
- package/dist/src/redteam/strategies/crescendo.d.ts +1 -1
- package/dist/src/redteam/strategies/crescendo.d.ts.map +1 -1
- package/dist/src/redteam/strategies/crescendo.js +2 -1
- package/dist/src/redteam/strategies/crescendo.js.map +1 -1
- package/dist/src/redteam/strategies/goat.d.ts.map +1 -1
- package/dist/src/redteam/strategies/goat.js +1 -0
- package/dist/src/redteam/strategies/goat.js.map +1 -1
- package/dist/src/redteam/strategies/index.js +8 -8
- package/dist/src/redteam/strategies/index.js.map +1 -1
- package/dist/src/redteam/strategies/iterative.d.ts +1 -1
- package/dist/src/redteam/strategies/iterative.d.ts.map +1 -1
- package/dist/src/redteam/strategies/iterative.js +2 -1
- package/dist/src/redteam/strategies/iterative.js.map +1 -1
- package/dist/src/redteam/strategies/multilingual.d.ts.map +1 -1
- package/dist/src/redteam/strategies/multilingual.js +1 -0
- package/dist/src/redteam/strategies/multilingual.js.map +1 -1
- package/dist/src/redteam/types.d.ts +17 -1
- package/dist/src/redteam/types.d.ts.map +1 -1
- package/dist/src/share.d.ts.map +1 -1
- package/dist/src/share.js +11 -0
- package/dist/src/share.js.map +1 -1
- package/dist/src/types/index.d.ts +590 -113
- package/dist/src/types/index.d.ts.map +1 -1
- package/dist/src/types/index.js +6 -1
- package/dist/src/types/index.js.map +1 -1
- package/dist/src/types/shared.d.ts +1 -0
- package/dist/src/types/shared.d.ts.map +1 -1
- package/dist/src/util/config/load.d.ts.map +1 -1
- package/dist/src/util/config/load.js +7 -2
- package/dist/src/util/config/load.js.map +1 -1
- package/dist/src/util/convertEvalResultsToTable.d.ts.map +1 -1
- package/dist/src/util/convertEvalResultsToTable.js +4 -8
- package/dist/src/util/convertEvalResultsToTable.js.map +1 -1
- package/dist/src/util/exportToFile/index.d.ts +1 -0
- package/dist/src/util/exportToFile/index.d.ts.map +1 -1
- package/dist/src/util/index.d.ts +10 -2
- package/dist/src/util/index.d.ts.map +1 -1
- package/dist/src/validators/providers.d.ts +15 -0
- package/dist/src/validators/providers.d.ts.map +1 -1
- package/dist/src/validators/redteam.d.ts.map +1 -1
- package/dist/src/validators/redteam.js +6 -5
- package/dist/src/validators/redteam.js.map +1 -1
- package/dist/src/validators/shared.d.ts +3 -0
- package/dist/src/validators/shared.d.ts.map +1 -1
- package/dist/src/validators/shared.js +1 -0
- package/dist/src/validators/shared.js.map +1 -1
- package/dist/test/commands/init.test.js +1 -1
- package/dist/test/evaluator.test.js +86 -32
- package/dist/test/evaluator.test.js.map +1 -1
- package/dist/test/factories/evalFactory.d.ts +17 -4
- package/dist/test/factories/evalFactory.d.ts.map +1 -1
- package/dist/test/onboarding.test.js +8 -7
- package/dist/test/onboarding.test.js.map +1 -1
- package/dist/test/providers/bedrock.test.js +1 -4
- package/dist/test/providers/bedrock.test.js.map +1 -1
- package/dist/test/redteam/plugins/base.test.js +61 -23
- package/dist/test/redteam/plugins/base.test.js.map +1 -1
- package/dist/test/redteam/plugins/harmful/aligned.test.d.ts +2 -0
- package/dist/test/redteam/plugins/harmful/aligned.test.d.ts.map +1 -0
- package/dist/test/redteam/plugins/harmful/aligned.test.js +123 -0
- package/dist/test/redteam/plugins/harmful/aligned.test.js.map +1 -0
- package/dist/test/redteam/plugins/harmful/common.test.d.ts +2 -0
- package/dist/test/redteam/plugins/harmful/common.test.d.ts.map +1 -0
- package/dist/test/redteam/plugins/harmful/common.test.js +105 -0
- package/dist/test/redteam/plugins/harmful/common.test.js.map +1 -0
- package/dist/test/redteam/plugins/harmful/unaligned.test.d.ts +2 -0
- package/dist/test/redteam/plugins/harmful/unaligned.test.d.ts.map +1 -0
- package/dist/test/redteam/plugins/harmful/unaligned.test.js +150 -0
- package/dist/test/redteam/plugins/harmful/unaligned.test.js.map +1 -0
- package/dist/test/redteam/plugins/index.test.d.ts +2 -0
- package/dist/test/redteam/plugins/index.test.d.ts.map +1 -0
- package/dist/test/redteam/plugins/index.test.js +172 -0
- package/dist/test/redteam/plugins/index.test.js.map +1 -0
- package/dist/test/redteam/providers/iterativeTree.test.js +4 -5
- package/dist/test/redteam/providers/iterativeTree.test.js.map +1 -1
- package/dist/test/share.test.js +45 -1
- package/dist/test/share.test.js.map +1 -1
- package/dist/test/util/config/load.test.js +3 -1
- package/dist/test/util/config/load.test.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -5
- package/dist/src/redteam/plugins/harmful.d.ts +0 -18
- package/dist/src/redteam/plugins/harmful.d.ts.map +0 -1
- package/dist/src/redteam/plugins/harmful.js +0 -366
- package/dist/src/redteam/plugins/harmful.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"promptfoo.d.ts","sourceRoot":"","sources":["../../../src/providers/promptfoo.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,oBAAoB,EACpB,oBAAoB,EACpB,YAAY,EAEb,MAAM,UAAU,CAAC;AAGlB,UAAU,iCAAiC;IACzC,
|
|
1
|
+
{"version":3,"file":"promptfoo.d.ts","sourceRoot":"","sources":["../../../src/providers/promptfoo.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,oBAAoB,EACpB,oBAAoB,EACpB,YAAY,EAEb,MAAM,UAAU,CAAC;AAGlB,UAAU,iCAAiC;IACzC,YAAY,EAAE,MAAM,CAAC;IACrB,CAAC,EAAE,MAAM,CAAC;IACV,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,kCAAmC,YAAW,WAAW;IACpE,YAAY,EAAE,MAAM,CAAC;IACrB,CAAC,EAAE,MAAM,CAAC;IACV,OAAO,EAAE,MAAM,CAAC;gBAEJ,OAAO,EAAE,iCAAiC;IAMtD,EAAE,IAAI,MAAM;IAIZ,QAAQ,IAAI,MAAM;IAIZ,OAAO,CACX,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,oBAAoB,EAC9B,cAAc,CAAC,EAAE,oBAAoB,GACpC,OAAO,CAAC,gBAAgB,GAAG;QAAE,MAAM,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC;CAyCrD;AAED,UAAU,8BAA8B;IACtC,GAAG,CAAC,EAAE,YAAY,CAAC;IACnB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,OAAO,CAAC;IAClB,gBAAgB,EAAE,OAAO,CAAC;IAC1B,IAAI,EAAE,WAAW,GAAG,MAAM,GAAG,WAAW,GAAG,iBAAiB,GAAG,gBAAgB,CAAC;CACjF;AAED,qBAAa,+BAAgC,YAAW,WAAW;IACjE,OAAO,CAAC,OAAO,CAAiC;gBAEpC,OAAO,EAAE,8BAA8B;IAInD,EAAE,IAAI,MAAM;IAIZ,QAAQ,IAAI,MAAM;IAIZ,OAAO,CACX,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,oBAAoB,EAC9B,cAAc,CAAC,EAAE,oBAAoB,GACpC,OAAO,CAAC,gBAAgB,CAAC;CAuC7B;AAED,UAAU,qBAAqB;IAC7B,GAAG,CAAC,EAAE,YAAY,CAAC;IACnB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,qBAAa,8BAA+B,YAAW,WAAW;IAChE,OAAO,CAAC,OAAO,CAAwB;gBAE3B,OAAO,GAAE,qBAA0B;IAI/C,EAAE,IAAI,MAAM;IAIZ,QAAQ,IAAI,MAAM;IAIZ,OAAO,CACX,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,oBAAoB,EAC9B,cAAc,CAAC,EAAE,oBAAoB,GACpC,OAAO,CAAC,gBAAgB,CAAC;CA2C7B"}
|
|
@@ -14,8 +14,9 @@ const constants_2 = require("../redteam/constants");
|
|
|
14
14
|
const shared_1 = require("./shared");
|
|
15
15
|
class PromptfooHarmfulCompletionProvider {
|
|
16
16
|
constructor(options) {
|
|
17
|
-
this.purpose = options.purpose;
|
|
18
17
|
this.harmCategory = options.harmCategory;
|
|
18
|
+
this.n = options.n;
|
|
19
|
+
this.purpose = options.purpose;
|
|
19
20
|
}
|
|
20
21
|
id() {
|
|
21
22
|
return `promptfoo:redteam:${this.harmCategory}`;
|
|
@@ -25,16 +26,15 @@ class PromptfooHarmfulCompletionProvider {
|
|
|
25
26
|
}
|
|
26
27
|
async callApi(prompt, context, callApiOptions) {
|
|
27
28
|
const body = {
|
|
28
|
-
purpose: this.purpose,
|
|
29
|
-
harmCategory: this.harmCategory,
|
|
30
29
|
email: (0, accounts_1.getUserEmail)(),
|
|
30
|
+
harmCategory: this.harmCategory,
|
|
31
|
+
n: this.n,
|
|
32
|
+
purpose: this.purpose,
|
|
31
33
|
version: constants_1.VERSION,
|
|
32
34
|
};
|
|
33
35
|
try {
|
|
34
36
|
logger_1.default.debug(`Calling promptfoo generate harmful API with body: ${JSON.stringify(body)}`);
|
|
35
37
|
// We're using the promptfoo API to avoid having users provide their own unaligned model.
|
|
36
|
-
// See here for a prompt you can use with Llama 3 base to host your own inference endpoint:
|
|
37
|
-
// https://gist.github.com/typpo/3815d97a638f1a41d28634293aff33a0
|
|
38
38
|
const response = await (0, fetch_1.fetchWithRetries)((0, envars_1.getEnvString)('PROMPTFOO_UNALIGNED_INFERENCE_ENDPOINT') ||
|
|
39
39
|
'https://api.promptfoo.dev/redteam/generateHarmful', {
|
|
40
40
|
method: 'POST',
|
|
@@ -42,14 +42,14 @@ class PromptfooHarmfulCompletionProvider {
|
|
|
42
42
|
'Content-Type': 'application/json',
|
|
43
43
|
},
|
|
44
44
|
body: JSON.stringify(body),
|
|
45
|
-
}, 10000);
|
|
45
|
+
}, 10000, 2);
|
|
46
46
|
if (!response.ok) {
|
|
47
47
|
throw new Error(`API call failed with status ${response.status}: ${await response.text()}`);
|
|
48
48
|
}
|
|
49
49
|
const data = await response.json();
|
|
50
50
|
logger_1.default.debug(`promptfoo API call response: ${JSON.stringify(data)}`);
|
|
51
51
|
return {
|
|
52
|
-
output: data.output,
|
|
52
|
+
output: [data.output].flat(),
|
|
53
53
|
};
|
|
54
54
|
}
|
|
55
55
|
catch (err) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"promptfoo.js","sourceRoot":"","sources":["../../../src/providers/promptfoo.ts"],"names":[],"mappings":";;;;;;AAAA,oCAA0C;AAC1C,4CAAuC;AACvC,sCAAyC;AACzC,oCAA4C;AAC5C,uDAAwD;AACxD,uDAA+B;AAC/B,oDAA8D;AAS9D,qCAA8C;
|
|
1
|
+
{"version":3,"file":"promptfoo.js","sourceRoot":"","sources":["../../../src/providers/promptfoo.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simulatedUser.d.ts","sourceRoot":"","sources":["../../../src/providers/simulatedUser.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,WAAW,EACX,oBAAoB,EACpB,oBAAoB,EACpB,eAAe,EACf,gBAAgB,EACjB,MAAM,UAAU,CAAC;AAIlB,MAAM,MAAM,sBAAsB,GAAG;IACnC,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,MAAM,MAAM,OAAO,GAAG;IACpB,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG,eAAe,GAAG;IACnD,MAAM,CAAC,EAAE;QACP,YAAY,CAAC,EAAE,eAAe,CAAC;QAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;CACH,CAAC;AAEF,qBAAa,aAAc,YAAW,WAAW;IAC/C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAS;gBAE7B,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,oBAAoB;IAMvD,EAAE;YAIY,iBAAiB;YAgBjB,kBAAkB;IAS1B,OAAO,CACX,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,oBAAoB,EAC9B,eAAe,CAAC,EAAE,oBAAoB,GACrC,OAAO,CAAC,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"simulatedUser.d.ts","sourceRoot":"","sources":["../../../src/providers/simulatedUser.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,WAAW,EACX,oBAAoB,EACpB,oBAAoB,EACpB,eAAe,EACf,gBAAgB,EACjB,MAAM,UAAU,CAAC;AAIlB,MAAM,MAAM,sBAAsB,GAAG;IACnC,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,MAAM,MAAM,OAAO,GAAG;IACpB,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG,eAAe,GAAG;IACnD,MAAM,CAAC,EAAE;QACP,YAAY,CAAC,EAAE,eAAe,CAAC;QAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;CACH,CAAC;AAEF,qBAAa,aAAc,YAAW,WAAW;IAC/C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAS;gBAE7B,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,oBAAoB;IAMvD,EAAE;YAIY,iBAAiB;YAgBjB,kBAAkB;IAS1B,OAAO,CACX,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,oBAAoB,EAC9B,eAAe,CAAC,EAAE,oBAAoB,GACrC,OAAO,CAAC,gBAAgB,CAAC;IAmC5B,QAAQ;CAGT"}
|
|
@@ -42,9 +42,11 @@ class SimulatedUser {
|
|
|
42
42
|
logger_1.default.debug(`Formatted user instructions: ${instructions}`);
|
|
43
43
|
let messages = [];
|
|
44
44
|
const maxTurns = this.maxTurns;
|
|
45
|
+
let numRequests = 0;
|
|
45
46
|
for (let i = 0; i < maxTurns; i++) {
|
|
46
47
|
messages = await this.sendMessageToUser(messages, userProvider);
|
|
47
48
|
messages = await this.sendMessageToAgent(messages, context.originalProvider);
|
|
49
|
+
numRequests += 1; // Only count the request to the agent.
|
|
48
50
|
const lastMessage = messages[messages.length - 1];
|
|
49
51
|
if (lastMessage.content.includes('###STOP###')) {
|
|
50
52
|
break;
|
|
@@ -54,6 +56,9 @@ class SimulatedUser {
|
|
|
54
56
|
output: messages
|
|
55
57
|
.map((message) => `${message.role === 'assistant' ? 'Assistant' : 'User'}: ${message.content}`)
|
|
56
58
|
.join('\n---\n'),
|
|
59
|
+
tokenUsage: {
|
|
60
|
+
numRequests,
|
|
61
|
+
},
|
|
57
62
|
};
|
|
58
63
|
}
|
|
59
64
|
toString() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simulatedUser.js","sourceRoot":"","sources":["../../../src/providers/simulatedUser.ts"],"names":[],"mappings":";;;;;;AAAA,oEAAuC;AACvC,uDAA+B;AAQ/B,iDAAsD;AACtD,2CAA6D;AAmB7D,MAAa,aAAa;IAKxB,YAAY,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAwB;QACrD,IAAI,CAAC,UAAU,GAAG,EAAE,IAAI,KAAK,IAAI,gBAAgB,CAAC;QAClD,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,EAAE,CAAC;QACtC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,YAAY,IAAI,kBAAkB,CAAC;IACnE,CAAC;IAED,EAAE;QACA,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAEO,KAAK,CAAC,iBAAiB,CAC7B,QAAmB,EACnB,YAA4C;QAE5C,MAAM,eAAe,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YAC/C,OAAO;gBACL,IAAI,EAAE,OAAO,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM;gBACpD,OAAO,EAAE,OAAO,CAAC,OAAO;aACzB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC;QAC7E,gBAAM,CAAC,KAAK,CAAC,SAAS,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;QACzC,OAAO,CAAC,GAAG,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;IACnE,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAC9B,QAAmB,EACnB,cAA2B;QAE3B,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACxE,gBAAM,CAAC,KAAK,CAAC,UAAU,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;QAC1C,OAAO,CAAC,GAAG,QAAQ,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,KAAK,CAAC,OAAO,CACX,MAAc,EACd,OAA8B,EAC9B,eAAsC;QAEtC,IAAA,wBAAS,EAAC,OAAO,EAAE,gBAAgB,EAAE,qCAAqC,CAAC,CAAC;QAE5E,MAAM,YAAY,GAAG,IAAA,6BAAiB,GAAE,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;QAC3F,MAAM,YAAY,GAAG,IAAI,0CAA8B,CAAC;YACtD,YAAY;SACb,CAAC,CAAC;QAEH,gBAAM,CAAC,KAAK,CAAC,gCAAgC,YAAY,EAAE,CAAC,CAAC;QAC7D,IAAI,QAAQ,GAAc,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC;YAClC,QAAQ,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;YAChE,QAAQ,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"simulatedUser.js","sourceRoot":"","sources":["../../../src/providers/simulatedUser.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,80 +1,5 @@
|
|
|
1
|
-
import { AsciiSmugglingGrader } from './plugins/asciiSmuggling';
|
|
2
1
|
import type { RedteamGraderBase } from './plugins/base';
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
import { CompetitorsGrader } from './plugins/competitors';
|
|
6
|
-
import { ContractsGrader } from './plugins/contracts';
|
|
7
|
-
import { CrossSessionLeakGrader } from './plugins/crossSessionLeak';
|
|
8
|
-
import { DebugAccessGrader } from './plugins/debugAccess';
|
|
9
|
-
import { ExcessiveAgencyGrader } from './plugins/excessiveAgency';
|
|
10
|
-
import { HallucinationGrader } from './plugins/hallucination';
|
|
11
|
-
import { HarmfulGrader, HarmfulPrivacyGrader } from './plugins/harmful';
|
|
12
|
-
import { HijackingGrader } from './plugins/hijacking';
|
|
13
|
-
import { ImitationGrader } from './plugins/imitation';
|
|
14
|
-
import { IndirectPromptInjectionGrader } from './plugins/indirectPromptInjection';
|
|
15
|
-
import { IntentGrader } from './plugins/intent';
|
|
16
|
-
import { OverrelianceGrader } from './plugins/overreliance';
|
|
17
|
-
import { PiiGrader } from './plugins/pii';
|
|
18
|
-
import { PolicyViolationGrader } from './plugins/policy';
|
|
19
|
-
import { PoliticsGrader } from './plugins/politics';
|
|
20
|
-
import { PromptExtractionGrader } from './plugins/promptExtraction';
|
|
21
|
-
import { RbacGrader } from './plugins/rbac';
|
|
22
|
-
import { ReligionGrader } from './plugins/religion';
|
|
23
|
-
import { ShellInjectionGrader } from './plugins/shellInjection';
|
|
24
|
-
import { SqlInjectionGrader } from './plugins/sqlInjection';
|
|
25
|
-
import { SsrfGrader } from './plugins/ssrf';
|
|
26
|
-
export declare const GRADERS: {
|
|
27
|
-
'promptfoo:redteam:ascii-smuggling': AsciiSmugglingGrader;
|
|
28
|
-
'promptfoo:redteam:bfla': BflaGrader;
|
|
29
|
-
'promptfoo:redteam:bola': BolaGrader;
|
|
30
|
-
'promptfoo:redteam:competitors': CompetitorsGrader;
|
|
31
|
-
'promptfoo:redteam:contracts': ContractsGrader;
|
|
32
|
-
'promptfoo:redteam:cross-session-leak': CrossSessionLeakGrader;
|
|
33
|
-
'promptfoo:redteam:debug-access': DebugAccessGrader;
|
|
34
|
-
'promptfoo:redteam:excessive-agency': ExcessiveAgencyGrader;
|
|
35
|
-
'promptfoo:redteam:hallucination': HallucinationGrader;
|
|
36
|
-
'promptfoo:redteam:harmful:chemical-biological-weapons': HarmfulGrader;
|
|
37
|
-
'promptfoo:redteam:harmful:child-exploitation': HarmfulGrader;
|
|
38
|
-
'promptfoo:redteam:harmful:copyright-violations': HarmfulGrader;
|
|
39
|
-
'promptfoo:redteam:harmful:cybercrime': HarmfulGrader;
|
|
40
|
-
'promptfoo:redteam:harmful:graphic-content': HarmfulGrader;
|
|
41
|
-
'promptfoo:redteam:harmful:harassment-bullying': HarmfulGrader;
|
|
42
|
-
'promptfoo:redteam:harmful:hate': HarmfulGrader;
|
|
43
|
-
'promptfoo:redteam:harmful:illegal-activities': HarmfulGrader;
|
|
44
|
-
'promptfoo:redteam:harmful:illegal-drugs': HarmfulGrader;
|
|
45
|
-
'promptfoo:redteam:harmful:indiscriminate-weapons': HarmfulGrader;
|
|
46
|
-
'promptfoo:redteam:harmful:insults': HarmfulGrader;
|
|
47
|
-
'promptfoo:redteam:harmful:intellectual-property': HarmfulGrader;
|
|
48
|
-
'promptfoo:redteam:harmful:misinformation-disinformation': HarmfulGrader;
|
|
49
|
-
'promptfoo:redteam:harmful:non-violent-crime': HarmfulGrader;
|
|
50
|
-
'promptfoo:redteam:harmful:privacy': HarmfulPrivacyGrader;
|
|
51
|
-
'promptfoo:redteam:harmful:profanity': HarmfulGrader;
|
|
52
|
-
'promptfoo:redteam:harmful:radicalization': HarmfulGrader;
|
|
53
|
-
'promptfoo:redteam:harmful:self-harm': HarmfulGrader;
|
|
54
|
-
'promptfoo:redteam:harmful:sex-crime': HarmfulGrader;
|
|
55
|
-
'promptfoo:redteam:harmful:sexual-content': HarmfulGrader;
|
|
56
|
-
'promptfoo:redteam:harmful:specialized-advice': HarmfulGrader;
|
|
57
|
-
'promptfoo:redteam:harmful:unsafe-practices': HarmfulGrader;
|
|
58
|
-
'promptfoo:redteam:harmful:violent-crime': HarmfulGrader;
|
|
59
|
-
'promptfoo:redteam:harmful': HarmfulGrader;
|
|
60
|
-
'promptfoo:redteam:hijacking': HijackingGrader;
|
|
61
|
-
'promptfoo:redteam:imitation': ImitationGrader;
|
|
62
|
-
'promptfoo:redteam:indirect-prompt-injection': IndirectPromptInjectionGrader;
|
|
63
|
-
'promptfoo:redteam:intent': IntentGrader;
|
|
64
|
-
'promptfoo:redteam:overreliance': OverrelianceGrader;
|
|
65
|
-
'promptfoo:redteam:pii:api-db': PiiGrader;
|
|
66
|
-
'promptfoo:redteam:pii:direct': PiiGrader;
|
|
67
|
-
'promptfoo:redteam:pii:session': PiiGrader;
|
|
68
|
-
'promptfoo:redteam:pii:social': PiiGrader;
|
|
69
|
-
'promptfoo:redteam:pii': PiiGrader;
|
|
70
|
-
'promptfoo:redteam:policy': PolicyViolationGrader;
|
|
71
|
-
'promptfoo:redteam:politics': PoliticsGrader;
|
|
72
|
-
'promptfoo:redteam:prompt-extraction': PromptExtractionGrader;
|
|
73
|
-
'promptfoo:redteam:rbac': RbacGrader;
|
|
74
|
-
'promptfoo:redteam:religion': ReligionGrader;
|
|
75
|
-
'promptfoo:redteam:shell-injection': ShellInjectionGrader;
|
|
76
|
-
'promptfoo:redteam:sql-injection': SqlInjectionGrader;
|
|
77
|
-
'promptfoo:redteam:ssrf': SsrfGrader;
|
|
78
|
-
};
|
|
2
|
+
import type { RedteamAssertionTypes } from './types';
|
|
3
|
+
export declare const GRADERS: Record<RedteamAssertionTypes, RedteamGraderBase>;
|
|
79
4
|
export declare function getGraderById(id: string): RedteamGraderBase | undefined;
|
|
80
5
|
//# sourceMappingURL=graders.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"graders.d.ts","sourceRoot":"","sources":["../../../src/redteam/graders.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"graders.d.ts","sourceRoot":"","sources":["../../../src/redteam/graders.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAwBxD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAErD,eAAO,MAAM,OAAO,EAAE,MAAM,CAAC,qBAAqB,EAAE,iBAAiB,CAoDpE,CAAC;AAEF,wBAAgB,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,iBAAiB,GAAG,SAAS,CAEvE"}
|
|
@@ -11,7 +11,7 @@ const crossSessionLeak_1 = require("./plugins/crossSessionLeak");
|
|
|
11
11
|
const debugAccess_1 = require("./plugins/debugAccess");
|
|
12
12
|
const excessiveAgency_1 = require("./plugins/excessiveAgency");
|
|
13
13
|
const hallucination_1 = require("./plugins/hallucination");
|
|
14
|
-
const
|
|
14
|
+
const graders_1 = require("./plugins/harmful/graders");
|
|
15
15
|
const hijacking_1 = require("./plugins/hijacking");
|
|
16
16
|
const imitation_1 = require("./plugins/imitation");
|
|
17
17
|
const indirectPromptInjection_1 = require("./plugins/indirectPromptInjection");
|
|
@@ -36,30 +36,30 @@ exports.GRADERS = {
|
|
|
36
36
|
'promptfoo:redteam:debug-access': new debugAccess_1.DebugAccessGrader(),
|
|
37
37
|
'promptfoo:redteam:excessive-agency': new excessiveAgency_1.ExcessiveAgencyGrader(),
|
|
38
38
|
'promptfoo:redteam:hallucination': new hallucination_1.HallucinationGrader(),
|
|
39
|
-
'promptfoo:redteam:harmful:chemical-biological-weapons': new
|
|
40
|
-
'promptfoo:redteam:harmful:child-exploitation': new
|
|
41
|
-
'promptfoo:redteam:harmful:copyright-violations': new
|
|
42
|
-
'promptfoo:redteam:harmful:cybercrime': new
|
|
43
|
-
'promptfoo:redteam:harmful:graphic-content': new
|
|
44
|
-
'promptfoo:redteam:harmful:harassment-bullying': new
|
|
45
|
-
'promptfoo:redteam:harmful:hate': new
|
|
46
|
-
'promptfoo:redteam:harmful:illegal-activities': new
|
|
47
|
-
'promptfoo:redteam:harmful:illegal-drugs': new
|
|
48
|
-
'promptfoo:redteam:harmful:indiscriminate-weapons': new
|
|
49
|
-
'promptfoo:redteam:harmful:insults': new
|
|
50
|
-
'promptfoo:redteam:harmful:intellectual-property': new
|
|
51
|
-
'promptfoo:redteam:harmful:misinformation-disinformation': new
|
|
52
|
-
'promptfoo:redteam:harmful:non-violent-crime': new
|
|
53
|
-
'promptfoo:redteam:harmful:privacy': new
|
|
54
|
-
'promptfoo:redteam:harmful:profanity': new
|
|
55
|
-
'promptfoo:redteam:harmful:radicalization': new
|
|
56
|
-
'promptfoo:redteam:harmful:self-harm': new
|
|
57
|
-
'promptfoo:redteam:harmful:sex-crime': new
|
|
58
|
-
'promptfoo:redteam:harmful:sexual-content': new
|
|
59
|
-
'promptfoo:redteam:harmful:specialized-advice': new
|
|
60
|
-
'promptfoo:redteam:harmful:unsafe-practices': new
|
|
61
|
-
'promptfoo:redteam:harmful:violent-crime': new
|
|
62
|
-
'promptfoo:redteam:harmful': new
|
|
39
|
+
'promptfoo:redteam:harmful:chemical-biological-weapons': new graders_1.HarmfulGrader(),
|
|
40
|
+
'promptfoo:redteam:harmful:child-exploitation': new graders_1.HarmfulGrader(),
|
|
41
|
+
'promptfoo:redteam:harmful:copyright-violations': new graders_1.HarmfulGrader(),
|
|
42
|
+
'promptfoo:redteam:harmful:cybercrime': new graders_1.HarmfulGrader(),
|
|
43
|
+
'promptfoo:redteam:harmful:graphic-content': new graders_1.HarmfulGrader(),
|
|
44
|
+
'promptfoo:redteam:harmful:harassment-bullying': new graders_1.HarmfulGrader(),
|
|
45
|
+
'promptfoo:redteam:harmful:hate': new graders_1.HarmfulGrader(),
|
|
46
|
+
'promptfoo:redteam:harmful:illegal-activities': new graders_1.HarmfulGrader(),
|
|
47
|
+
'promptfoo:redteam:harmful:illegal-drugs': new graders_1.HarmfulGrader(),
|
|
48
|
+
'promptfoo:redteam:harmful:indiscriminate-weapons': new graders_1.HarmfulGrader(),
|
|
49
|
+
'promptfoo:redteam:harmful:insults': new graders_1.HarmfulGrader(),
|
|
50
|
+
'promptfoo:redteam:harmful:intellectual-property': new graders_1.HarmfulGrader(),
|
|
51
|
+
'promptfoo:redteam:harmful:misinformation-disinformation': new graders_1.HarmfulGrader(),
|
|
52
|
+
'promptfoo:redteam:harmful:non-violent-crime': new graders_1.HarmfulGrader(),
|
|
53
|
+
'promptfoo:redteam:harmful:privacy': new graders_1.HarmfulPrivacyGrader(),
|
|
54
|
+
'promptfoo:redteam:harmful:profanity': new graders_1.HarmfulGrader(),
|
|
55
|
+
'promptfoo:redteam:harmful:radicalization': new graders_1.HarmfulGrader(),
|
|
56
|
+
'promptfoo:redteam:harmful:self-harm': new graders_1.HarmfulGrader(),
|
|
57
|
+
'promptfoo:redteam:harmful:sex-crime': new graders_1.HarmfulGrader(),
|
|
58
|
+
'promptfoo:redteam:harmful:sexual-content': new graders_1.HarmfulGrader(),
|
|
59
|
+
'promptfoo:redteam:harmful:specialized-advice': new graders_1.HarmfulGrader(),
|
|
60
|
+
'promptfoo:redteam:harmful:unsafe-practices': new graders_1.HarmfulGrader(),
|
|
61
|
+
'promptfoo:redteam:harmful:violent-crime': new graders_1.HarmfulGrader(),
|
|
62
|
+
'promptfoo:redteam:harmful': new graders_1.HarmfulGrader(),
|
|
63
63
|
'promptfoo:redteam:hijacking': new hijacking_1.HijackingGrader(),
|
|
64
64
|
'promptfoo:redteam:imitation': new imitation_1.ImitationGrader(),
|
|
65
65
|
'promptfoo:redteam:indirect-prompt-injection': new indirectPromptInjection_1.IndirectPromptInjectionGrader(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"graders.js","sourceRoot":"","sources":["../../../src/redteam/graders.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"graders.js","sourceRoot":"","sources":["../../../src/redteam/graders.ts"],"names":[],"mappings":";;;AAiFA,sCAEC;AAnFD,6DAAgE;AAEhE,yCAA4C;AAC5C,yCAA4C;AAC5C,uDAA0D;AAC1D,mDAAsD;AACtD,iEAAoE;AACpE,uDAA0D;AAC1D,+DAAkE;AAClE,2DAA8D;AAC9D,uDAAgF;AAChF,mDAAsD;AACtD,mDAAsD;AACtD,+EAAkF;AAClF,6CAAgD;AAChD,yDAA4D;AAC5D,uCAA0C;AAC1C,6CAAyD;AACzD,iDAAoD;AACpD,iEAAoE;AACpE,yCAA4C;AAC5C,iDAAoD;AACpD,6DAAgE;AAChE,yDAA4D;AAC5D,yCAA4C;AAG/B,QAAA,OAAO,GAAqD;IACvE,mCAAmC,EAAE,IAAI,qCAAoB,EAAE;IAC/D,wBAAwB,EAAE,IAAI,iBAAU,EAAE;IAC1C,wBAAwB,EAAE,IAAI,iBAAU,EAAE;IAC1C,+BAA+B,EAAE,IAAI,+BAAiB,EAAE;IACxD,6BAA6B,EAAE,IAAI,2BAAe,EAAE;IACpD,sCAAsC,EAAE,IAAI,yCAAsB,EAAE;IACpE,gCAAgC,EAAE,IAAI,+BAAiB,EAAE;IACzD,oCAAoC,EAAE,IAAI,uCAAqB,EAAE;IACjE,iCAAiC,EAAE,IAAI,mCAAmB,EAAE;IAC5D,uDAAuD,EAAE,IAAI,uBAAa,EAAE;IAC5E,8CAA8C,EAAE,IAAI,uBAAa,EAAE;IACnE,gDAAgD,EAAE,IAAI,uBAAa,EAAE;IACrE,sCAAsC,EAAE,IAAI,uBAAa,EAAE;IAC3D,2CAA2C,EAAE,IAAI,uBAAa,EAAE;IAChE,+CAA+C,EAAE,IAAI,uBAAa,EAAE;IACpE,gCAAgC,EAAE,IAAI,uBAAa,EAAE;IACrD,8CAA8C,EAAE,IAAI,uBAAa,EAAE;IACnE,yCAAyC,EAAE,IAAI,uBAAa,EAAE;IAC9D,kDAAkD,EAAE,IAAI,uBAAa,EAAE;IACvE,mCAAmC,EAAE,IAAI,uBAAa,EAAE;IACxD,iDAAiD,EAAE,IAAI,uBAAa,EAAE;IACtE,yDAAyD,EAAE,IAAI,uBAAa,EAAE;IAC9E,6CAA6C,EAAE,IAAI,uBAAa,EAAE;IAClE,mCAAmC,EAAE,IAAI,8BAAoB,EAAE;IAC/D,qCAAqC,EAAE,IAAI,uBAAa,EAAE;IAC1D,0CAA0C,EAAE,IAAI,uBAAa,EAAE;IAC/D,qCAAqC,EAAE,IAAI,uBAAa,EAAE;IAC1D,qCAAqC,EAAE,IAAI,uBAAa,EAAE;IAC1D,0CAA0C,EAAE,IAAI,uBAAa,EAAE;IAC/D,8CAA8C,EAAE,IAAI,uBAAa,EAAE;IACnE,4CAA4C,EAAE,IAAI,uBAAa,EAAE;IACjE,yCAAyC,EAAE,IAAI,uBAAa,EAAE;IAC9D,2BAA2B,EAAE,IAAI,uBAAa,EAAE;IAChD,6BAA6B,EAAE,IAAI,2BAAe,EAAE;IACpD,6BAA6B,EAAE,IAAI,2BAAe,EAAE;IACpD,6CAA6C,EAAE,IAAI,uDAA6B,EAAE;IAClF,0BAA0B,EAAE,IAAI,qBAAY,EAAE;IAC9C,gCAAgC,EAAE,IAAI,iCAAkB,EAAE;IAC1D,8BAA8B,EAAE,IAAI,eAAS,EAAE;IAC/C,8BAA8B,EAAE,IAAI,eAAS,EAAE;IAC/C,+BAA+B,EAAE,IAAI,eAAS,EAAE;IAChD,8BAA8B,EAAE,IAAI,eAAS,EAAE;IAC/C,uBAAuB,EAAE,IAAI,eAAS,EAAE;IACxC,0BAA0B,EAAE,IAAI,8BAAqB,EAAE;IACvD,4BAA4B,EAAE,IAAI,yBAAc,EAAE;IAClD,qCAAqC,EAAE,IAAI,yCAAsB,EAAE;IACnE,wBAAwB,EAAE,IAAI,iBAAU,EAAE;IAC1C,4BAA4B,EAAE,IAAI,yBAAc,EAAE;IAClD,mCAAmC,EAAE,IAAI,qCAAoB,EAAE;IAC/D,iCAAiC,EAAE,IAAI,iCAAkB,EAAE;IAC3D,wBAAwB,EAAE,IAAI,iBAAU,EAAE;CAC3C,CAAC;AAEF,SAAgB,aAAa,CAAC,EAAU;IACtC,OAAO,eAAO,CAAC,EAA0B,CAAC,CAAC;AAC7C,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/redteam/index.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/redteam/index.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAY,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAS7D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAyDjD;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAwBhG;AAeD;;;;GAIG;AACH,wBAAsB,UAAU,CAAC,EAC/B,QAAQ,EAAE,gBAAgB,EAC1B,SAAS,EACT,QAAQ,EACR,cAAkB,EAClB,OAAO,EACP,OAAO,EACP,QAAQ,EACR,OAAO,EAAE,eAAe,EACxB,UAAU,EACV,KAAK,GACN,EAAE,iBAAiB,GAAG,OAAO,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,SAAS,EAAE,kBAAkB,EAAE,CAAC;CACjC,CAAC,CA4QD"}
|
|
@@ -232,9 +232,16 @@ async function synthesize({ entities: entitiesOverride, injectVar, language, max
|
|
|
232
232
|
const { action } = plugins_1.Plugins.find((p) => p.key === plugin.id) || {};
|
|
233
233
|
if (action) {
|
|
234
234
|
logger_1.default.debug(`Generating tests for ${plugin.id}...`);
|
|
235
|
-
let pluginTests = await action(
|
|
236
|
-
|
|
237
|
-
|
|
235
|
+
let pluginTests = await action({
|
|
236
|
+
provider: redteamProvider,
|
|
237
|
+
purpose,
|
|
238
|
+
injectVar,
|
|
239
|
+
n: plugin.numTests,
|
|
240
|
+
delayMs: delay || 0,
|
|
241
|
+
config: {
|
|
242
|
+
language,
|
|
243
|
+
...resolvePluginConfig(plugin.config),
|
|
244
|
+
},
|
|
238
245
|
});
|
|
239
246
|
if (!Array.isArray(pluginTests) || pluginTests.length === 0) {
|
|
240
247
|
logger_1.default.warn(`Failed to generate tests for ${plugin.id}`);
|
|
@@ -245,6 +252,7 @@ async function synthesize({ entities: entitiesOverride, injectVar, language, max
|
|
|
245
252
|
metadata: {
|
|
246
253
|
...(t.metadata || {}),
|
|
247
254
|
pluginId: plugin.id,
|
|
255
|
+
pluginConfig: resolvePluginConfig(plugin.config),
|
|
248
256
|
},
|
|
249
257
|
})));
|
|
250
258
|
progressBar?.increment(plugin.numTests);
|
|
@@ -263,6 +271,7 @@ async function synthesize({ entities: entitiesOverride, injectVar, language, max
|
|
|
263
271
|
metadata: {
|
|
264
272
|
...(t.metadata || {}),
|
|
265
273
|
pluginId: plugin.id,
|
|
274
|
+
pluginConfig: resolvePluginConfig(plugin.config),
|
|
266
275
|
},
|
|
267
276
|
})));
|
|
268
277
|
logger_1.default.debug(`Added ${customTests.length} custom test cases from ${plugin.id}`);
|
|
@@ -296,14 +305,23 @@ async function synthesize({ entities: entitiesOverride, injectVar, language, max
|
|
|
296
305
|
progressBar?.update({ task: `Applying strategy: ${key}` });
|
|
297
306
|
logger_1.default.debug(`Generating ${key} tests`);
|
|
298
307
|
const strategyTestCases = await action(testCases, injectVar, strategy.config || {});
|
|
299
|
-
|
|
300
|
-
...
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
308
|
+
try {
|
|
309
|
+
newTestCases.push(...strategyTestCases
|
|
310
|
+
.filter((t) => t !== null && t !== undefined)
|
|
311
|
+
.map((t) => ({
|
|
312
|
+
...t,
|
|
313
|
+
metadata: {
|
|
314
|
+
...(t?.metadata || {}),
|
|
315
|
+
strategyId: strategy.id,
|
|
316
|
+
...(t?.metadata?.pluginId && { pluginId: t.metadata.pluginId }),
|
|
317
|
+
...(t?.metadata?.pluginConfig && { pluginConfig: t.metadata.pluginConfig }),
|
|
318
|
+
...(strategy.config && { strategyConfig: strategy.config }),
|
|
319
|
+
},
|
|
320
|
+
})));
|
|
321
|
+
}
|
|
322
|
+
catch (e) {
|
|
323
|
+
logger_1.default.warn(`Strategy ${key} did not return valid test cases: ${e}`);
|
|
324
|
+
}
|
|
307
325
|
strategyResults[key] = {
|
|
308
326
|
requested: testCases.length,
|
|
309
327
|
generated: strategyTestCases.length,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/redteam/index.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/redteam/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,14 @@
|
|
|
1
1
|
import type { ApiProvider, Assertion, AssertionValue, PluginConfig, ResultSuggestion, TestCase } from '../../types';
|
|
2
2
|
import type { AtomicTestCase, GradingResult } from '../../types';
|
|
3
|
+
/**
|
|
4
|
+
* Parses the LLM response of generated prompts into an array of objects.
|
|
5
|
+
*
|
|
6
|
+
* @param generatedPrompts - The LLM response of generated prompts.
|
|
7
|
+
* @returns An array of { prompt: string } objects. Each of these objects represents a test case.
|
|
8
|
+
*/
|
|
9
|
+
export declare function parseGeneratedPrompts(generatedPrompts: string): {
|
|
10
|
+
prompt: string;
|
|
11
|
+
}[];
|
|
3
12
|
/**
|
|
4
13
|
* Abstract base class for creating plugins that generate test cases.
|
|
5
14
|
*/
|
|
@@ -42,14 +51,10 @@ export declare abstract class RedteamPluginBase {
|
|
|
42
51
|
prompt: string;
|
|
43
52
|
}[]): TestCase[];
|
|
44
53
|
/**
|
|
45
|
-
*
|
|
46
|
-
*
|
|
47
|
-
* @
|
|
48
|
-
* @returns An array of { prompt: string } objects. Each of these objects represents a test case.
|
|
54
|
+
* Appends modifiers to the template.
|
|
55
|
+
* @param template - The template to append modifiers to.
|
|
56
|
+
* @returns The modified template.
|
|
49
57
|
*/
|
|
50
|
-
protected parseGeneratedPrompts(generatedPrompts: string): {
|
|
51
|
-
prompt: string;
|
|
52
|
-
}[];
|
|
53
58
|
private appendModifiers;
|
|
54
59
|
}
|
|
55
60
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/redteam/plugins/base.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,WAAW,EACX,SAAS,EACT,cAAc,EACd,YAAY,EACZ,gBAAgB,EAChB,QAAQ,EACT,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAQjE;;GAEG;AACH,8BAAsB,iBAAiB;IASnC,SAAS,CAAC,QAAQ,EAAE,WAAW;IAC/B,SAAS,CAAC,OAAO,EAAE,MAAM;IACzB,SAAS,CAAC,SAAS,EAAE,MAAM;IAC3B,SAAS,CAAC,MAAM,EAAE,YAAY;IAXhC;;;;;;OAMG;gBAES,QAAQ,EAAE,WAAW,EACrB,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,EACjB,MAAM,GAAE,YAAiB;IAKrC;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC;IAEjD;;;;OAIG;IACH,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,EAAE;IAE7D;;;;;OAKG;IACG,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,GAAE,MAAU,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/redteam/plugins/base.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,WAAW,EACX,SAAS,EACT,cAAc,EACd,YAAY,EACZ,gBAAgB,EAChB,QAAQ,EACT,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAQjE;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,gBAAgB,EAAE,MAAM,GAAG;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,CAuBpF;AAED;;GAEG;AACH,8BAAsB,iBAAiB;IASnC,SAAS,CAAC,QAAQ,EAAE,WAAW;IAC/B,SAAS,CAAC,OAAO,EAAE,MAAM;IACzB,SAAS,CAAC,SAAS,EAAE,MAAM;IAC3B,SAAS,CAAC,MAAM,EAAE,YAAY;IAXhC;;;;;;OAMG;gBAES,QAAQ,EAAE,WAAW,EACrB,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,EACjB,MAAM,GAAE,YAAiB;IAKrC;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC;IAEjD;;;;OAIG;IACH,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,EAAE;IAE7D;;;;;OAKG;IACG,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,GAAE,MAAU,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAmDxE;;;;OAIG;IACH,SAAS,CAAC,kBAAkB,CAAC,OAAO,EAAE;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,EAAE,GAAG,QAAQ,EAAE;IASvE;;;;OAIG;IACH,OAAO,CAAC,eAAe;CAmCxB;AAED;;;;;;;GAOG;AACH,8BAAsB,iBAAiB;IACrC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IAExB,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM;IAkB/C,cAAc,CAAC,EACb,IAAI,EACJ,SAAS,EACT,aAAa,GACd,EAAE;QACD,IAAI,EAAE,cAAc,CAAC;QACrB,SAAS,EAAE,MAAM,CAAC;QAClB,aAAa,CAAC,EAAE,cAAc,CAAC;KAChC,GAAG,gBAAgB,EAAE;IAIhB,SAAS,CACb,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,cAAc,EACpB,QAAQ,EAAE,WAAW,GAAG,SAAS,EACjC,aAAa,EAAE,cAAc,GAAG,SAAS,GACxC,OAAO,CAAC;QAAE,KAAK,EAAE,aAAa,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,gBAAgB,EAAE,CAAA;KAAE,CAAC;CAyCvF"}
|
|
@@ -4,6 +4,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.RedteamGraderBase = exports.RedteamPluginBase = void 0;
|
|
7
|
+
exports.parseGeneratedPrompts = parseGeneratedPrompts;
|
|
7
8
|
const dedent_1 = __importDefault(require("dedent"));
|
|
8
9
|
const tiny_invariant_1 = __importDefault(require("tiny-invariant"));
|
|
9
10
|
const cliState_1 = __importDefault(require("../../cliState"));
|
|
@@ -15,6 +16,34 @@ const templates_1 = require("../../util/templates");
|
|
|
15
16
|
const time_1 = require("../../util/time");
|
|
16
17
|
const shared_1 = require("../providers/shared");
|
|
17
18
|
const util_2 = require("../util");
|
|
19
|
+
/**
|
|
20
|
+
* Parses the LLM response of generated prompts into an array of objects.
|
|
21
|
+
*
|
|
22
|
+
* @param generatedPrompts - The LLM response of generated prompts.
|
|
23
|
+
* @returns An array of { prompt: string } objects. Each of these objects represents a test case.
|
|
24
|
+
*/
|
|
25
|
+
function parseGeneratedPrompts(generatedPrompts) {
|
|
26
|
+
const parsePrompt = (line) => {
|
|
27
|
+
if (!line.toLowerCase().includes('prompt:')) {
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
let prompt = (0, util_2.removePrefix)(line, 'Prompt');
|
|
31
|
+
// Handle numbered lists with various formats
|
|
32
|
+
prompt = prompt.replace(/^\d+[\.\)\-]?\s*-?\s*/, '');
|
|
33
|
+
// Handle quotes
|
|
34
|
+
prompt = prompt.replace(/^["'](.*)["']$/, '$1');
|
|
35
|
+
// Handle nested quotes
|
|
36
|
+
prompt = prompt.replace(/^'([^']*(?:'{2}[^']*)*)'$/, (_, p1) => p1.replace(/''/g, "'"));
|
|
37
|
+
prompt = prompt.replace(/^"([^"]*(?:"{2}[^"]*)*)"$/, (_, p1) => p1.replace(/""/g, '"'));
|
|
38
|
+
return prompt.trim();
|
|
39
|
+
};
|
|
40
|
+
// Split by newline or semicolon
|
|
41
|
+
const promptLines = generatedPrompts.split(/[\n;]+/);
|
|
42
|
+
return promptLines
|
|
43
|
+
.map(parsePrompt)
|
|
44
|
+
.filter((prompt) => prompt !== null)
|
|
45
|
+
.map((prompt) => ({ prompt }));
|
|
46
|
+
}
|
|
18
47
|
/**
|
|
19
48
|
* Abstract base class for creating plugins that generate test cases.
|
|
20
49
|
*/
|
|
@@ -55,6 +84,7 @@ class RedteamPluginBase {
|
|
|
55
84
|
const renderedTemplate = nunjucks.renderString(await this.getTemplate(), {
|
|
56
85
|
purpose: this.purpose,
|
|
57
86
|
n: currentBatchSize,
|
|
87
|
+
examples: this.config.examples,
|
|
58
88
|
});
|
|
59
89
|
const finalTemplate = this.appendModifiers(renderedTemplate);
|
|
60
90
|
const { output: generatedPrompts, error } = await this.provider.callApi(finalTemplate);
|
|
@@ -70,7 +100,7 @@ class RedteamPluginBase {
|
|
|
70
100
|
logger_1.default.error(`Malformed response from API provider: Expected generatedPrompts to be a string, got ${typeof generatedPrompts}: ${JSON.stringify(generatedPrompts)}`);
|
|
71
101
|
return [];
|
|
72
102
|
}
|
|
73
|
-
return
|
|
103
|
+
return parseGeneratedPrompts(generatedPrompts);
|
|
74
104
|
};
|
|
75
105
|
const allPrompts = await (0, generation_1.retryWithDeduplication)(generatePrompts, n);
|
|
76
106
|
const prompts = (0, generation_1.sampleArray)(allPrompts, n);
|
|
@@ -91,37 +121,14 @@ class RedteamPluginBase {
|
|
|
91
121
|
}));
|
|
92
122
|
}
|
|
93
123
|
/**
|
|
94
|
-
*
|
|
95
|
-
*
|
|
96
|
-
* @
|
|
97
|
-
* @returns An array of { prompt: string } objects. Each of these objects represents a test case.
|
|
124
|
+
* Appends modifiers to the template.
|
|
125
|
+
* @param template - The template to append modifiers to.
|
|
126
|
+
* @returns The modified template.
|
|
98
127
|
*/
|
|
99
|
-
parseGeneratedPrompts(generatedPrompts) {
|
|
100
|
-
const parsePrompt = (line) => {
|
|
101
|
-
if (!line.toLowerCase().includes('prompt:')) {
|
|
102
|
-
return null;
|
|
103
|
-
}
|
|
104
|
-
let prompt = (0, util_2.removePrefix)(line, 'Prompt');
|
|
105
|
-
// Handle numbered lists with various formats
|
|
106
|
-
prompt = prompt.replace(/^\d+[\.\)\-]?\s*-?\s*/, '');
|
|
107
|
-
// Handle quotes
|
|
108
|
-
prompt = prompt.replace(/^["'](.*)["']$/, '$1');
|
|
109
|
-
// Handle nested quotes
|
|
110
|
-
prompt = prompt.replace(/^'([^']*(?:'{2}[^']*)*)'$/, (_, p1) => p1.replace(/''/g, "'"));
|
|
111
|
-
prompt = prompt.replace(/^"([^"]*(?:"{2}[^"]*)*)"$/, (_, p1) => p1.replace(/""/g, '"'));
|
|
112
|
-
return prompt.trim();
|
|
113
|
-
};
|
|
114
|
-
// Split by newline or semicolon
|
|
115
|
-
const promptLines = generatedPrompts.split(/[\n;]+/);
|
|
116
|
-
return promptLines
|
|
117
|
-
.map(parsePrompt)
|
|
118
|
-
.filter((prompt) => prompt !== null)
|
|
119
|
-
.map((prompt) => ({ prompt }));
|
|
120
|
-
}
|
|
121
128
|
appendModifiers(template) {
|
|
122
129
|
// Take everything under "modifiers" config key
|
|
123
130
|
const modifiers = this.config.modifiers ?? {};
|
|
124
|
-
//
|
|
131
|
+
// `language` is a special top-level config field
|
|
125
132
|
if (this.config.language) {
|
|
126
133
|
(0, tiny_invariant_1.default)(typeof this.config.language === 'string', 'language must be a string');
|
|
127
134
|
modifiers.language = this.config.language;
|
|
@@ -186,7 +193,15 @@ class RedteamGraderBase {
|
|
|
186
193
|
tools: (0, util_1.maybeLoadFromExternalFile)(provider?.config?.tools),
|
|
187
194
|
value: renderedValue,
|
|
188
195
|
};
|
|
189
|
-
|
|
196
|
+
// Grader examples are appended to all rubrics if present.
|
|
197
|
+
const graderExamples = test.metadata?.pluginConfig?.graderExamples;
|
|
198
|
+
let graderExamplesString = '';
|
|
199
|
+
if (graderExamples && graderExamples.length > 0) {
|
|
200
|
+
graderExamplesString =
|
|
201
|
+
'\n\n' +
|
|
202
|
+
graderExamples.map((example) => `EXAMPLE OUTPUT: ${JSON.stringify(example)}`).join('\n');
|
|
203
|
+
}
|
|
204
|
+
const finalRubric = this.renderRubric(vars) + graderExamplesString;
|
|
190
205
|
const grade = await (0, matchers_1.matchesLlmRubric)(finalRubric, llmOutput, {
|
|
191
206
|
...test.options,
|
|
192
207
|
provider: await (0, shared_1.loadRedteamProvider)({
|