promptfoo 0.73.9 → 0.75.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/README.md +59 -1
- package/dist/package.json +5 -5
- package/dist/src/assertions/AssertionsResult.d.ts +1 -1
- package/dist/src/assertions/AssertionsResult.d.ts.map +1 -1
- package/dist/src/assertions/validateAssertions.d.ts +1 -1
- package/dist/src/assertions/validateAssertions.d.ts.map +1 -1
- package/dist/src/assertions.d.ts +2 -1
- package/dist/src/assertions.d.ts.map +1 -1
- package/dist/src/assertions.js +8 -4
- package/dist/src/assertions.js.map +1 -1
- package/dist/src/commands/cache.d.ts +1 -1
- package/dist/src/commands/cache.d.ts.map +1 -1
- package/dist/src/commands/config.d.ts +1 -1
- package/dist/src/commands/config.d.ts.map +1 -1
- package/dist/src/commands/delete.d.ts +1 -1
- package/dist/src/commands/delete.d.ts.map +1 -1
- package/dist/src/commands/eval/filterFailingTests.d.ts +1 -1
- package/dist/src/commands/eval/filterFailingTests.d.ts.map +1 -1
- package/dist/src/commands/eval/filterTests.d.ts +1 -1
- package/dist/src/commands/eval/filterTests.d.ts.map +1 -1
- package/dist/src/commands/eval.d.ts +2 -2
- package/dist/src/commands/eval.d.ts.map +1 -1
- package/dist/src/commands/eval.js.map +1 -1
- package/dist/src/commands/export.d.ts +1 -1
- package/dist/src/commands/export.d.ts.map +1 -1
- package/dist/src/commands/feedback.d.ts +1 -1
- package/dist/src/commands/feedback.d.ts.map +1 -1
- package/dist/src/commands/generate/dataset.d.ts +2 -2
- package/dist/src/commands/generate/dataset.d.ts.map +1 -1
- package/dist/src/commands/generate/redteam.d.ts +3 -3
- package/dist/src/commands/generate/redteam.d.ts.map +1 -1
- package/dist/src/commands/generate/redteam.js +52 -22
- package/dist/src/commands/generate/redteam.js.map +1 -1
- package/dist/src/commands/import.d.ts +1 -1
- package/dist/src/commands/import.d.ts.map +1 -1
- package/dist/src/commands/init.d.ts +1 -1
- package/dist/src/commands/init.d.ts.map +1 -1
- package/dist/src/commands/list.d.ts +1 -1
- package/dist/src/commands/list.d.ts.map +1 -1
- package/dist/src/commands/redteam.d.ts +2 -1
- package/dist/src/commands/redteam.d.ts.map +1 -1
- package/dist/src/commands/redteam.js +252 -188
- package/dist/src/commands/redteam.js.map +1 -1
- package/dist/src/commands/share.d.ts +1 -1
- package/dist/src/commands/share.d.ts.map +1 -1
- package/dist/src/commands/show.d.ts +1 -1
- package/dist/src/commands/show.d.ts.map +1 -1
- package/dist/src/commands/version.d.ts +1 -1
- package/dist/src/commands/version.d.ts.map +1 -1
- package/dist/src/commands/view.d.ts +1 -1
- package/dist/src/commands/view.d.ts.map +1 -1
- package/dist/src/config.d.ts +1 -1
- package/dist/src/config.d.ts.map +1 -1
- package/dist/src/config.js +5 -2
- package/dist/src/config.js.map +1 -1
- package/dist/src/configTypes.d.ts +1 -0
- package/dist/src/configTypes.d.ts.map +1 -1
- package/dist/src/database/operations.d.ts +57 -241
- package/dist/src/database/operations.d.ts.map +1 -1
- package/dist/src/database/types.d.ts +1 -1
- package/dist/src/database/types.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/globalConfig.d.ts +1 -1
- package/dist/src/globalConfig.d.ts.map +1 -1
- package/dist/src/onboarding.d.ts.map +1 -1
- package/dist/src/onboarding.js +11 -0
- package/dist/src/onboarding.js.map +1 -1
- package/dist/src/prompts/grading.js +1 -1
- package/dist/src/prompts/processors/javascript.d.ts +1 -1
- package/dist/src/prompts/processors/javascript.d.ts.map +1 -1
- package/dist/src/prompts/processors/json.d.ts +1 -1
- package/dist/src/prompts/processors/json.d.ts.map +1 -1
- package/dist/src/prompts/processors/jsonl.d.ts +1 -1
- package/dist/src/prompts/processors/jsonl.d.ts.map +1 -1
- package/dist/src/prompts/processors/python.d.ts.map +1 -1
- package/dist/src/prompts/processors/python.js.map +1 -1
- package/dist/src/prompts/processors/string.d.ts +1 -1
- package/dist/src/prompts/processors/string.d.ts.map +1 -1
- package/dist/src/prompts/processors/text.d.ts +1 -1
- package/dist/src/prompts/processors/text.d.ts.map +1 -1
- package/dist/src/prompts/processors/yaml.d.ts +1 -1
- package/dist/src/prompts/processors/yaml.d.ts.map +1 -1
- package/dist/src/prompts/utils.d.ts +1 -1
- package/dist/src/prompts/utils.d.ts.map +1 -1
- package/dist/src/providers/anthropic.js +1 -1
- package/dist/src/providers/anthropic.js.map +1 -1
- package/dist/src/providers/azureopenai.d.ts.map +1 -1
- package/dist/src/providers/azureopenai.js +6 -2
- package/dist/src/providers/azureopenai.js.map +1 -1
- package/dist/src/providers/bedrock.d.ts.map +1 -1
- package/dist/src/providers/bedrock.js +2 -2
- package/dist/src/providers/bedrock.js.map +1 -1
- package/dist/src/providers/huggingface.d.ts +1 -1
- package/dist/src/providers/huggingface.d.ts.map +1 -1
- package/dist/src/providers/manualInput.d.ts +1 -1
- package/dist/src/providers/manualInput.d.ts.map +1 -1
- package/dist/src/providers/mistral.d.ts +1 -1
- package/dist/src/providers/mistral.d.ts.map +1 -1
- package/dist/src/providers/openai.d.ts +1 -1
- package/dist/src/providers/openai.d.ts.map +1 -1
- package/dist/src/providers/openai.js +8 -3
- package/dist/src/providers/openai.js.map +1 -1
- package/dist/src/providers/shared.d.ts +1 -0
- package/dist/src/providers/shared.d.ts.map +1 -1
- package/dist/src/providers/shared.js +47 -0
- package/dist/src/providers/shared.js.map +1 -1
- package/dist/src/providers/vertex.d.ts.map +1 -1
- package/dist/src/providers/vertex.js.map +1 -1
- package/dist/src/providers.d.ts +2 -1
- package/dist/src/providers.d.ts.map +1 -1
- package/dist/src/python/pythonUtils.d.ts.map +1 -1
- package/dist/src/python/pythonUtils.js.map +1 -1
- package/dist/src/redteam/constants.d.ts +7 -6
- package/dist/src/redteam/constants.d.ts.map +1 -1
- package/dist/src/redteam/constants.js +25 -19
- package/dist/src/redteam/constants.js.map +1 -1
- package/dist/src/redteam/extraction/entities.d.ts +1 -1
- package/dist/src/redteam/extraction/entities.d.ts.map +1 -1
- package/dist/src/redteam/extraction/entities.js +1 -1
- package/dist/src/redteam/extraction/purpose.d.ts +1 -1
- package/dist/src/redteam/extraction/purpose.d.ts.map +1 -1
- package/dist/src/redteam/extraction/util.d.ts +1 -1
- package/dist/src/redteam/extraction/util.d.ts.map +1 -1
- package/dist/src/redteam/graders.d.ts +3 -0
- package/dist/src/redteam/graders.d.ts.map +1 -0
- package/dist/src/redteam/graders.js +67 -0
- package/dist/src/redteam/graders.js.map +1 -0
- package/dist/src/redteam/index.d.ts +7 -9
- package/dist/src/redteam/index.d.ts.map +1 -1
- package/dist/src/redteam/index.js +32 -150
- package/dist/src/redteam/index.js.map +1 -1
- package/dist/src/redteam/plugins/base.d.ts +22 -5
- package/dist/src/redteam/plugins/base.d.ts.map +1 -1
- package/dist/src/redteam/plugins/base.js +29 -2
- package/dist/src/redteam/plugins/base.js.map +1 -1
- package/dist/src/redteam/plugins/competitors.d.ts +8 -4
- package/dist/src/redteam/plugins/competitors.d.ts.map +1 -1
- package/dist/src/redteam/plugins/competitors.js +41 -6
- package/dist/src/redteam/plugins/competitors.js.map +1 -1
- package/dist/src/redteam/plugins/contracts.d.ts +8 -4
- package/dist/src/redteam/plugins/contracts.d.ts.map +1 -1
- package/dist/src/redteam/plugins/contracts.js +16 -6
- package/dist/src/redteam/plugins/contracts.js.map +1 -1
- package/dist/src/redteam/plugins/debugAccess.d.ts +8 -4
- package/dist/src/redteam/plugins/debugAccess.d.ts.map +1 -1
- package/dist/src/redteam/plugins/debugAccess.js +14 -6
- package/dist/src/redteam/plugins/debugAccess.js.map +1 -1
- package/dist/src/redteam/plugins/excessiveAgency.d.ts +8 -4
- package/dist/src/redteam/plugins/excessiveAgency.d.ts.map +1 -1
- package/dist/src/redteam/plugins/excessiveAgency.js +16 -6
- package/dist/src/redteam/plugins/excessiveAgency.js.map +1 -1
- package/dist/src/redteam/plugins/hallucination.d.ts +8 -4
- package/dist/src/redteam/plugins/hallucination.d.ts.map +1 -1
- package/dist/src/redteam/plugins/hallucination.js +49 -6
- package/dist/src/redteam/plugins/hallucination.js.map +1 -1
- package/dist/src/redteam/plugins/harmful.d.ts +10 -0
- package/dist/src/redteam/plugins/harmful.d.ts.map +1 -1
- package/dist/src/redteam/plugins/harmful.js +56 -5
- package/dist/src/redteam/plugins/harmful.js.map +1 -1
- package/dist/src/redteam/plugins/hijacking.d.ts +8 -4
- package/dist/src/redteam/plugins/hijacking.d.ts.map +1 -1
- package/dist/src/redteam/plugins/hijacking.js +26 -6
- package/dist/src/redteam/plugins/hijacking.js.map +1 -1
- package/dist/src/redteam/plugins/imitation.d.ts +7 -3
- package/dist/src/redteam/plugins/imitation.d.ts.map +1 -1
- package/dist/src/redteam/plugins/imitation.js +34 -6
- package/dist/src/redteam/plugins/imitation.js.map +1 -1
- package/dist/src/redteam/plugins/index.d.ts +12 -0
- package/dist/src/redteam/plugins/index.d.ts.map +1 -0
- package/dist/src/redteam/plugins/index.js +113 -0
- package/dist/src/redteam/plugins/index.js.map +1 -0
- package/dist/src/redteam/plugins/overreliance.d.ts +8 -4
- package/dist/src/redteam/plugins/overreliance.d.ts.map +1 -1
- package/dist/src/redteam/plugins/overreliance.js +43 -6
- package/dist/src/redteam/plugins/overreliance.js.map +1 -1
- package/dist/src/redteam/plugins/pii.d.ts +5 -0
- package/dist/src/redteam/plugins/pii.d.ts.map +1 -1
- package/dist/src/redteam/plugins/pii.js +55 -0
- package/dist/src/redteam/plugins/pii.js.map +1 -1
- package/dist/src/redteam/plugins/policy.d.ts +22 -0
- package/dist/src/redteam/plugins/policy.d.ts.map +1 -0
- package/dist/src/redteam/plugins/policy.js +102 -0
- package/dist/src/redteam/plugins/policy.js.map +1 -0
- package/dist/src/redteam/plugins/politics.d.ts +8 -4
- package/dist/src/redteam/plugins/politics.d.ts.map +1 -1
- package/dist/src/redteam/plugins/politics.js +14 -6
- package/dist/src/redteam/plugins/politics.js.map +1 -1
- package/dist/src/redteam/plugins/rbac.d.ts +8 -4
- package/dist/src/redteam/plugins/rbac.d.ts.map +1 -1
- package/dist/src/redteam/plugins/rbac.js +49 -6
- package/dist/src/redteam/plugins/rbac.js.map +1 -1
- package/dist/src/redteam/plugins/shellInjection.d.ts +8 -4
- package/dist/src/redteam/plugins/shellInjection.d.ts.map +1 -1
- package/dist/src/redteam/plugins/shellInjection.js +14 -6
- package/dist/src/redteam/plugins/shellInjection.js.map +1 -1
- package/dist/src/redteam/plugins/sqlInjection.d.ts +8 -4
- package/dist/src/redteam/plugins/sqlInjection.d.ts.map +1 -1
- package/dist/src/redteam/plugins/sqlInjection.js +14 -6
- package/dist/src/redteam/plugins/sqlInjection.js.map +1 -1
- package/dist/src/redteam/providers/iterative.d.ts.map +1 -1
- package/dist/src/redteam/providers/iterative.js +8 -2
- package/dist/src/redteam/providers/iterative.js.map +1 -1
- package/dist/src/redteam/strategies/base64.d.ts +3 -0
- package/dist/src/redteam/strategies/base64.d.ts.map +1 -0
- package/dist/src/redteam/strategies/base64.js +17 -0
- package/dist/src/redteam/strategies/base64.js.map +1 -0
- package/dist/src/redteam/strategies/index.d.ts +11 -0
- package/dist/src/redteam/strategies/index.d.ts.map +1 -0
- package/dist/src/redteam/strategies/index.js +84 -0
- package/dist/src/redteam/strategies/index.js.map +1 -0
- package/dist/src/redteam/strategies/injections.d.ts +1 -1
- package/dist/src/redteam/strategies/injections.d.ts.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/leetspeak.d.ts +3 -0
- package/dist/src/redteam/strategies/leetspeak.d.ts.map +1 -0
- package/dist/src/redteam/strategies/leetspeak.js +39 -0
- package/dist/src/redteam/strategies/leetspeak.js.map +1 -0
- package/dist/src/redteam/strategies/rot13.d.ts +3 -0
- package/dist/src/redteam/strategies/rot13.d.ts.map +1 -0
- package/dist/src/redteam/strategies/rot13.js +24 -0
- package/dist/src/redteam/strategies/rot13.js.map +1 -0
- package/dist/src/telemetry.d.ts +4 -0
- package/dist/src/telemetry.d.ts.map +1 -1
- package/dist/src/telemetry.js +23 -0
- package/dist/src/telemetry.js.map +1 -1
- package/dist/src/testCases.d.ts.map +1 -1
- package/dist/src/testCases.js +1 -1
- package/dist/src/testCases.js.map +1 -1
- package/dist/src/{types.d.ts → types/index.d.ts} +1465 -6482
- package/dist/src/{types.d.ts.map → types/index.d.ts.map} +1 -1
- package/dist/src/{types.js → types/index.js} +38 -172
- package/dist/src/types/index.js.map +1 -0
- package/dist/src/types/prompts.d.ts +29 -0
- package/dist/src/types/prompts.d.ts.map +1 -0
- package/dist/src/types/prompts.js +3 -0
- package/dist/src/types/prompts.js.map +1 -0
- package/dist/src/types/providers.d.ts +126 -0
- package/dist/src/types/providers.d.ts.map +1 -0
- package/dist/src/types/providers.js +11 -0
- package/dist/src/types/providers.js.map +1 -0
- package/dist/src/types/redteam.d.ts +55 -0
- package/dist/src/types/redteam.d.ts.map +1 -0
- package/dist/src/types/redteam.js +3 -0
- package/dist/src/types/redteam.js.map +1 -0
- package/dist/src/types/shared.d.ts +8 -0
- package/dist/src/types/shared.d.ts.map +1 -0
- package/dist/src/types/shared.js +3 -0
- package/dist/src/types/shared.js.map +1 -0
- package/dist/src/util/config.d.ts +2 -0
- package/dist/src/util/config.d.ts.map +1 -1
- package/dist/src/util/config.js +18 -0
- package/dist/src/util/config.js.map +1 -1
- package/dist/src/util/index.d.ts +20 -96
- package/dist/src/util/index.d.ts.map +1 -1
- package/dist/src/util/index.js +74 -66
- package/dist/src/util/index.js.map +1 -1
- package/dist/src/util/json.d.ts +14 -0
- package/dist/src/util/json.d.ts.map +1 -1
- package/dist/src/util/json.js +37 -0
- package/dist/src/util/json.js.map +1 -1
- package/dist/src/util/templates.d.ts +2 -2
- package/dist/src/util/templates.d.ts.map +1 -1
- package/dist/src/util/templates.js +2 -1
- package/dist/src/util/templates.js.map +1 -1
- package/dist/src/util/transform.d.ts +1 -1
- package/dist/src/util/transform.d.ts.map +1 -1
- package/dist/src/validators/prompts.d.ts +60 -0
- package/dist/src/validators/prompts.d.ts.map +1 -0
- package/dist/src/validators/prompts.js +32 -0
- package/dist/src/validators/prompts.js.map +1 -0
- package/dist/src/validators/providers.d.ts +1145 -0
- package/dist/src/validators/providers.d.ts.map +1 -0
- package/dist/src/validators/providers.js +133 -0
- package/dist/src/validators/providers.js.map +1 -0
- package/dist/src/validators/redteam.d.ts +531 -0
- package/dist/src/validators/redteam.d.ts.map +1 -0
- package/dist/src/{redteam/types.js → validators/redteam.js} +68 -47
- package/dist/src/validators/redteam.js.map +1 -0
- package/dist/src/validators/shared.d.ts +19 -0
- package/dist/src/validators/shared.d.ts.map +1 -0
- package/dist/src/validators/shared.js +12 -0
- package/dist/src/validators/shared.js.map +1 -0
- package/dist/src/web/nextui/404/index.html +1 -1
- package/dist/src/web/nextui/404.html +1 -1
- package/dist/src/web/nextui/_next/static/chunks/15.306496fdcef5f880.js +52 -0
- package/dist/src/web/nextui/_next/static/chunks/216-41f093798f2200fe.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/{998-eabde83617d6bc23.js → 222-8d27a2c754bc8029.js} +1 -1
- package/dist/src/web/nextui/_next/static/chunks/258-dcf9823bb9098565.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/565431e5-7b9122ac20f7a0ae.js +140 -0
- package/dist/src/web/nextui/_next/static/chunks/840.58dde6630f088da4.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/944-95d6fadc7a5d7fb2.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/a5c829b0-07a2c92898a6780c.js +14 -0
- package/dist/src/web/nextui/_next/static/chunks/app/eval/[id]/{page-3f5dd9507c5c905d.js → page-c72cfe418b720579.js} +1 -1
- package/dist/src/web/nextui/_next/static/chunks/app/eval/{page-f882912e083dbdb8.js → page-e64af76a729b3178.js} +1 -1
- package/dist/src/web/nextui/_next/static/chunks/app/{layout-881a16d7fe67581c.js → layout-fd0bafbf194c4d80.js} +1 -1
- package/dist/src/web/nextui/_next/static/chunks/app/page-81e3b8fee37eaf67.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/app/report/page-941cb8de85e2ea7b.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/fd57813c.8f0e3582250c76c5.js +1 -0
- package/dist/src/web/nextui/_next/static/chunks/webpack-22e0e23bc00c2c23.js +1 -0
- package/dist/src/web/nextui/_next/static/css/32384cb640d2265e.css +1 -0
- package/dist/src/web/nextui/auth/login/index.html +1 -1
- package/dist/src/web/nextui/auth/login/index.txt +4 -4
- package/dist/src/web/nextui/auth/signup/index.html +1 -1
- package/dist/src/web/nextui/auth/signup/index.txt +4 -4
- package/dist/src/web/nextui/datasets/index.html +1 -1
- package/dist/src/web/nextui/datasets/index.txt +4 -4
- package/dist/src/web/nextui/eval/index.html +1 -1
- package/dist/src/web/nextui/eval/index.txt +5 -5
- package/dist/src/web/nextui/index.html +1 -1
- package/dist/src/web/nextui/index.txt +4 -4
- package/dist/src/web/nextui/progress/index.html +1 -1
- package/dist/src/web/nextui/progress/index.txt +4 -4
- package/dist/src/web/nextui/prompts/index.html +1 -1
- package/dist/src/web/nextui/prompts/index.txt +4 -4
- package/dist/src/web/nextui/report/index.html +1 -1
- package/dist/src/web/nextui/report/index.txt +7 -7
- package/dist/src/web/nextui/setup/index.html +1 -1
- package/dist/src/web/nextui/setup/index.txt +5 -5
- package/dist/src/web/server.d.ts.map +1 -1
- package/dist/src/web/server.js.map +1 -1
- package/dist/test/cache.test.js.map +1 -1
- package/dist/test/config.test.js +46 -0
- package/dist/test/config.test.js.map +1 -1
- package/dist/test/evaluator.test.js +91 -7
- package/dist/test/evaluator.test.js.map +1 -1
- package/dist/test/providers.bedrock.test.js.map +1 -1
- package/dist/test/providers.shared.test.d.ts +2 -0
- package/dist/test/providers.shared.test.d.ts.map +1 -0
- package/dist/test/providers.shared.test.js +101 -0
- package/dist/test/providers.shared.test.js.map +1 -0
- package/dist/test/redteam/plugins/base.test.js +54 -8
- package/dist/test/redteam/plugins/base.test.js.map +1 -1
- package/dist/test/redteam/plugins/imitation.test.d.ts.map +1 -0
- package/dist/test/redteam/{graders → plugins}/imitation.test.js +2 -5
- package/dist/test/redteam/plugins/imitation.test.js.map +1 -0
- package/dist/test/redteam/strategies/base64.test.d.ts +2 -0
- package/dist/test/redteam/strategies/base64.test.d.ts.map +1 -0
- package/dist/test/redteam/strategies/base64.test.js +20 -0
- package/dist/test/redteam/strategies/base64.test.js.map +1 -0
- package/dist/test/redteam/strategies/leetspeak.test.d.ts +2 -0
- package/dist/test/redteam/strategies/leetspeak.test.d.ts.map +1 -0
- package/dist/test/redteam/strategies/leetspeak.test.js +28 -0
- package/dist/test/redteam/strategies/leetspeak.test.js.map +1 -0
- package/dist/test/redteam/strategies/rot13.test.d.ts +2 -0
- package/dist/test/redteam/strategies/rot13.test.d.ts.map +1 -0
- package/dist/test/redteam/strategies/rot13.test.js +36 -0
- package/dist/test/redteam/strategies/rot13.test.js.map +1 -0
- package/dist/test/redteam/validators.test.d.ts +2 -0
- package/dist/test/redteam/validators.test.d.ts.map +1 -0
- package/dist/test/redteam/{types.test.js → validators.test.js} +150 -32
- package/dist/test/redteam/validators.test.js.map +1 -0
- package/dist/test/util.config.test.js +70 -0
- package/dist/test/util.config.test.js.map +1 -1
- package/dist/test/util.json.test.js +53 -0
- package/dist/test/util.json.test.js.map +1 -1
- package/dist/test/util.test.js +50 -0
- package/dist/test/util.test.js.map +1 -1
- package/dist/test/utils.d.ts +1 -1
- package/dist/test/utils.d.ts.map +1 -1
- package/package.json +5 -5
- package/dist/src/redteam/graders/base.d.ts +0 -15
- package/dist/src/redteam/graders/base.d.ts.map +0 -1
- package/dist/src/redteam/graders/base.js +0 -35
- package/dist/src/redteam/graders/base.js.map +0 -1
- package/dist/src/redteam/graders/competitors.d.ts +0 -6
- package/dist/src/redteam/graders/competitors.d.ts.map +0 -1
- package/dist/src/redteam/graders/competitors.js +0 -43
- package/dist/src/redteam/graders/competitors.js.map +0 -1
- package/dist/src/redteam/graders/contracts.d.ts +0 -6
- package/dist/src/redteam/graders/contracts.d.ts.map +0 -1
- package/dist/src/redteam/graders/contracts.js +0 -18
- package/dist/src/redteam/graders/contracts.js.map +0 -1
- package/dist/src/redteam/graders/debugAccess.d.ts +0 -6
- package/dist/src/redteam/graders/debugAccess.d.ts.map +0 -1
- package/dist/src/redteam/graders/debugAccess.js +0 -16
- package/dist/src/redteam/graders/debugAccess.js.map +0 -1
- package/dist/src/redteam/graders/excessiveAgency.d.ts +0 -6
- package/dist/src/redteam/graders/excessiveAgency.d.ts.map +0 -1
- package/dist/src/redteam/graders/excessiveAgency.js +0 -18
- package/dist/src/redteam/graders/excessiveAgency.js.map +0 -1
- package/dist/src/redteam/graders/hallucination.d.ts +0 -6
- package/dist/src/redteam/graders/hallucination.d.ts.map +0 -1
- package/dist/src/redteam/graders/hallucination.js +0 -51
- package/dist/src/redteam/graders/hallucination.js.map +0 -1
- package/dist/src/redteam/graders/harmful.d.ts +0 -8
- package/dist/src/redteam/graders/harmful.d.ts.map +0 -1
- package/dist/src/redteam/graders/harmful.js +0 -51
- package/dist/src/redteam/graders/harmful.js.map +0 -1
- package/dist/src/redteam/graders/hijacking.d.ts +0 -6
- package/dist/src/redteam/graders/hijacking.d.ts.map +0 -1
- package/dist/src/redteam/graders/hijacking.js +0 -28
- package/dist/src/redteam/graders/hijacking.js.map +0 -1
- package/dist/src/redteam/graders/imitation.d.ts +0 -6
- package/dist/src/redteam/graders/imitation.d.ts.map +0 -1
- package/dist/src/redteam/graders/imitation.js +0 -36
- package/dist/src/redteam/graders/imitation.js.map +0 -1
- package/dist/src/redteam/graders/index.d.ts +0 -3
- package/dist/src/redteam/graders/index.d.ts.map +0 -1
- package/dist/src/redteam/graders/index.js +0 -68
- package/dist/src/redteam/graders/index.js.map +0 -1
- package/dist/src/redteam/graders/overreliance.d.ts +0 -6
- package/dist/src/redteam/graders/overreliance.d.ts.map +0 -1
- package/dist/src/redteam/graders/overreliance.js +0 -45
- package/dist/src/redteam/graders/overreliance.js.map +0 -1
- package/dist/src/redteam/graders/pii.d.ts +0 -6
- package/dist/src/redteam/graders/pii.d.ts.map +0 -1
- package/dist/src/redteam/graders/pii.js +0 -16
- package/dist/src/redteam/graders/pii.js.map +0 -1
- package/dist/src/redteam/graders/politics.d.ts +0 -6
- package/dist/src/redteam/graders/politics.d.ts.map +0 -1
- package/dist/src/redteam/graders/politics.js +0 -16
- package/dist/src/redteam/graders/politics.js.map +0 -1
- package/dist/src/redteam/graders/rbac.d.ts +0 -6
- package/dist/src/redteam/graders/rbac.d.ts.map +0 -1
- package/dist/src/redteam/graders/rbac.js +0 -16
- package/dist/src/redteam/graders/rbac.js.map +0 -1
- package/dist/src/redteam/graders/shellInjection.d.ts +0 -6
- package/dist/src/redteam/graders/shellInjection.d.ts.map +0 -1
- package/dist/src/redteam/graders/shellInjection.js +0 -16
- package/dist/src/redteam/graders/shellInjection.js.map +0 -1
- package/dist/src/redteam/graders/sqlInjection.d.ts +0 -6
- package/dist/src/redteam/graders/sqlInjection.d.ts.map +0 -1
- package/dist/src/redteam/graders/sqlInjection.js +0 -16
- package/dist/src/redteam/graders/sqlInjection.js.map +0 -1
- package/dist/src/redteam/types.d.ts +0 -215
- package/dist/src/redteam/types.d.ts.map +0 -1
- package/dist/src/redteam/types.js.map +0 -1
- package/dist/src/types.js.map +0 -1
- package/dist/src/web/nextui/_next/static/chunks/258-f5d5d6dbebb8ae22.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/347-49b79b8c81884e85.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/515-e06d044f12d8a1bd.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/app/page-7e8faab5d212f727.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/app/report/page-95d5e86c47bb3593.js +0 -1
- package/dist/src/web/nextui/_next/static/chunks/webpack-b0363d9598537efc.js +0 -1
- package/dist/src/web/nextui/_next/static/css/e17fdafd8599f69b.css +0 -1
- package/dist/test/redteam/graders/base.test.d.ts +0 -2
- package/dist/test/redteam/graders/base.test.d.ts.map +0 -1
- package/dist/test/redteam/graders/base.test.js +0 -54
- package/dist/test/redteam/graders/base.test.js.map +0 -1
- package/dist/test/redteam/graders/imitation.test.d.ts.map +0 -1
- package/dist/test/redteam/graders/imitation.test.js.map +0 -1
- package/dist/test/redteam/types.test.d.ts +0 -2
- package/dist/test/redteam/types.test.d.ts.map +0 -1
- package/dist/test/redteam/types.test.js.map +0 -1
- /package/dist/src/web/nextui/_next/static/{rXJSLz3x5ieAU1Syln-RX → 8Jt8p9IYhOnIHolJT1ONi}/_buildManifest.js +0 -0
- /package/dist/src/web/nextui/_next/static/{rXJSLz3x5ieAU1Syln-RX → 8Jt8p9IYhOnIHolJT1ONi}/_ssgManifest.js +0 -0
- /package/dist/test/redteam/{graders → plugins}/imitation.test.d.ts +0 -0
|
@@ -0,0 +1,101 @@
|
|
|
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
|
+
const fs = __importStar(require("fs"));
|
|
30
|
+
const path = __importStar(require("path"));
|
|
31
|
+
const cliState_1 = __importDefault(require("../src/cliState"));
|
|
32
|
+
const shared_1 = require("../src/providers/shared");
|
|
33
|
+
jest.mock('fs');
|
|
34
|
+
describe('maybeLoadFromExternalFile', () => {
|
|
35
|
+
const mockFileContent = 'test content';
|
|
36
|
+
const mockJsonContent = '{"key": "value"}';
|
|
37
|
+
const mockYamlContent = 'key: value';
|
|
38
|
+
beforeEach(() => {
|
|
39
|
+
jest.resetAllMocks();
|
|
40
|
+
jest.mocked(fs.existsSync).mockReturnValue(true);
|
|
41
|
+
jest.mocked(fs.readFileSync).mockReturnValue(mockFileContent);
|
|
42
|
+
});
|
|
43
|
+
it('should return the input if it is not a string', () => {
|
|
44
|
+
const input = { key: 'value' };
|
|
45
|
+
expect((0, shared_1.maybeLoadFromExternalFile)(input)).toBe(input);
|
|
46
|
+
});
|
|
47
|
+
it('should return the input if it does not start with "file://"', () => {
|
|
48
|
+
const input = 'not a file path';
|
|
49
|
+
expect((0, shared_1.maybeLoadFromExternalFile)(input)).toBe(input);
|
|
50
|
+
});
|
|
51
|
+
it('should throw an error if the file does not exist', () => {
|
|
52
|
+
jest.mocked(fs.existsSync).mockReturnValue(false);
|
|
53
|
+
expect(() => (0, shared_1.maybeLoadFromExternalFile)('file://nonexistent.txt')).toThrow('File does not exist');
|
|
54
|
+
});
|
|
55
|
+
it('should return the file contents for a non-JSON, non-YAML file', () => {
|
|
56
|
+
expect((0, shared_1.maybeLoadFromExternalFile)('file://test.txt')).toBe(mockFileContent);
|
|
57
|
+
});
|
|
58
|
+
it('should parse and return JSON content for a .json file', () => {
|
|
59
|
+
jest.mocked(fs.readFileSync).mockReturnValue(mockJsonContent);
|
|
60
|
+
expect((0, shared_1.maybeLoadFromExternalFile)('file://test.json')).toEqual({ key: 'value' });
|
|
61
|
+
});
|
|
62
|
+
it('should parse and return YAML content for a .yaml file', () => {
|
|
63
|
+
jest.mocked(fs.readFileSync).mockReturnValue(mockYamlContent);
|
|
64
|
+
expect((0, shared_1.maybeLoadFromExternalFile)('file://test.yaml')).toEqual({ key: 'value' });
|
|
65
|
+
});
|
|
66
|
+
it('should parse and return YAML content for a .yml file', () => {
|
|
67
|
+
jest.mocked(fs.readFileSync).mockReturnValue(mockYamlContent);
|
|
68
|
+
expect((0, shared_1.maybeLoadFromExternalFile)('file://test.yml')).toEqual({ key: 'value' });
|
|
69
|
+
});
|
|
70
|
+
it('should use basePath when resolving file paths', () => {
|
|
71
|
+
const basePath = '/base/path';
|
|
72
|
+
cliState_1.default.basePath = basePath;
|
|
73
|
+
jest.mocked(fs.readFileSync).mockReturnValue(mockFileContent);
|
|
74
|
+
(0, shared_1.maybeLoadFromExternalFile)('file://test.txt');
|
|
75
|
+
const expectedPath = path.resolve(basePath, 'test.txt');
|
|
76
|
+
expect(fs.existsSync).toHaveBeenCalledWith(expectedPath);
|
|
77
|
+
expect(fs.readFileSync).toHaveBeenCalledWith(expectedPath, 'utf8');
|
|
78
|
+
cliState_1.default.basePath = undefined;
|
|
79
|
+
});
|
|
80
|
+
it('should handle relative paths correctly', () => {
|
|
81
|
+
const basePath = './relative/path';
|
|
82
|
+
cliState_1.default.basePath = basePath;
|
|
83
|
+
jest.mocked(fs.readFileSync).mockReturnValue(mockFileContent);
|
|
84
|
+
(0, shared_1.maybeLoadFromExternalFile)('file://test.txt');
|
|
85
|
+
const expectedPath = path.resolve(basePath, 'test.txt');
|
|
86
|
+
expect(fs.existsSync).toHaveBeenCalledWith(expectedPath);
|
|
87
|
+
expect(fs.readFileSync).toHaveBeenCalledWith(expectedPath, 'utf8');
|
|
88
|
+
cliState_1.default.basePath = undefined;
|
|
89
|
+
});
|
|
90
|
+
it('should ignore basePath when file path is absolute', () => {
|
|
91
|
+
const basePath = '/base/path';
|
|
92
|
+
cliState_1.default.basePath = basePath;
|
|
93
|
+
jest.mocked(fs.readFileSync).mockReturnValue(mockFileContent);
|
|
94
|
+
(0, shared_1.maybeLoadFromExternalFile)('file:///absolute/path/test.txt');
|
|
95
|
+
const expectedPath = path.resolve('/absolute/path/test.txt');
|
|
96
|
+
expect(fs.existsSync).toHaveBeenCalledWith(expectedPath);
|
|
97
|
+
expect(fs.readFileSync).toHaveBeenCalledWith(expectedPath, 'utf8');
|
|
98
|
+
cliState_1.default.basePath = undefined;
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=providers.shared.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"providers.shared.test.js","sourceRoot":"","sources":["../../test/providers.shared.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const
|
|
3
|
+
const matchers_1 = require("../../../src/matchers");
|
|
4
|
+
const base_1 = require("../../../src/redteam/plugins/base");
|
|
5
|
+
const base_2 = require("../../../src/redteam/plugins/base");
|
|
7
6
|
const templates_1 = require("../../../src/util/templates");
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
jest.mock('../../../src/matchers', () => ({
|
|
8
|
+
matchesLlmRubric: jest.fn(),
|
|
9
|
+
}));
|
|
10
|
+
class TestPlugin extends base_1.PluginBase {
|
|
11
|
+
async getTemplate() {
|
|
12
|
+
return 'Test template with {{ purpose }} for {{ n }} prompts';
|
|
12
13
|
}
|
|
13
14
|
getAssertions(prompt) {
|
|
14
15
|
return [{ type: 'contains', value: prompt }];
|
|
@@ -146,4 +147,49 @@ describe('PluginBase', () => {
|
|
|
146
147
|
expect(new Set(result.map((r) => r.vars?.testVar)).size).toBe(5);
|
|
147
148
|
});
|
|
148
149
|
});
|
|
150
|
+
class TestGrader extends base_2.RedteamModelGrader {
|
|
151
|
+
constructor() {
|
|
152
|
+
super(...arguments);
|
|
153
|
+
this.id = 'test-grader';
|
|
154
|
+
this.rubric = 'Test rubric for {{ purpose }} with harm category {{ harmCategory }}';
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
describe('RedteamModelGrader', () => {
|
|
158
|
+
let grader;
|
|
159
|
+
let mockTest;
|
|
160
|
+
beforeEach(() => {
|
|
161
|
+
grader = new TestGrader();
|
|
162
|
+
mockTest = {
|
|
163
|
+
metadata: { purpose: 'test-purpose', harmCategory: 'test-harm' },
|
|
164
|
+
};
|
|
165
|
+
jest.clearAllMocks();
|
|
166
|
+
});
|
|
167
|
+
it('should throw an error if test is missing purpose metadata', async () => {
|
|
168
|
+
const testWithoutPurpose = { ...mockTest, metadata: {} };
|
|
169
|
+
await expect(grader.getResult('prompt', 'output', testWithoutPurpose)).rejects.toThrow('Test is missing purpose metadata');
|
|
170
|
+
});
|
|
171
|
+
it('should render the rubric with correct variables', async () => {
|
|
172
|
+
const mockResult = {
|
|
173
|
+
pass: true,
|
|
174
|
+
score: 1,
|
|
175
|
+
reason: 'Test passed',
|
|
176
|
+
};
|
|
177
|
+
jest.mocked(matchers_1.matchesLlmRubric).mockResolvedValue(mockResult);
|
|
178
|
+
await grader.getResult('test prompt', 'test output', mockTest);
|
|
179
|
+
expect(matchers_1.matchesLlmRubric).toHaveBeenCalledWith('Test rubric for test-purpose with harm category test-harm', 'test output', {});
|
|
180
|
+
});
|
|
181
|
+
it('should return the result from matchesLlmRubric', async () => {
|
|
182
|
+
const mockResult = {
|
|
183
|
+
pass: true,
|
|
184
|
+
score: 1,
|
|
185
|
+
reason: 'Test passed',
|
|
186
|
+
};
|
|
187
|
+
jest.mocked(matchers_1.matchesLlmRubric).mockResolvedValue(mockResult);
|
|
188
|
+
const result = await grader.getResult('test prompt', 'test output', mockTest);
|
|
189
|
+
expect(result).toEqual({
|
|
190
|
+
grade: mockResult,
|
|
191
|
+
rubric: 'Test rubric for test-purpose with harm category test-harm',
|
|
192
|
+
});
|
|
193
|
+
});
|
|
194
|
+
});
|
|
149
195
|
//# sourceMappingURL=base.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base.test.js","sourceRoot":"","sources":["../../../../test/redteam/plugins/base.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"base.test.js","sourceRoot":"","sources":["../../../../test/redteam/plugins/base.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"imitation.test.d.ts","sourceRoot":"","sources":["../../../../test/redteam/plugins/imitation.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,10 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
3
|
const matchers_1 = require("../../../src/matchers");
|
|
7
|
-
const imitation_1 =
|
|
4
|
+
const imitation_1 = require("../../../src/redteam/plugins/imitation");
|
|
8
5
|
jest.mock('../../../src/matchers', () => ({
|
|
9
6
|
matchesLlmRubric: jest.fn(),
|
|
10
7
|
}));
|
|
@@ -12,7 +9,7 @@ describe('ImitationGrader', () => {
|
|
|
12
9
|
let grader;
|
|
13
10
|
let mockTest;
|
|
14
11
|
beforeEach(() => {
|
|
15
|
-
grader = new imitation_1.
|
|
12
|
+
grader = new imitation_1.ImitationGrader();
|
|
16
13
|
mockTest = {
|
|
17
14
|
vars: { harmCategory: 'imitation' },
|
|
18
15
|
metadata: {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"imitation.test.js","sourceRoot":"","sources":["../../../../test/redteam/plugins/imitation.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base64.test.d.ts","sourceRoot":"","sources":["../../../../test/redteam/strategies/base64.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base64_1 = require("../../../src/redteam/strategies/base64");
|
|
4
|
+
describe('addBase64Encoding', () => {
|
|
5
|
+
const mockTestCases = [
|
|
6
|
+
{
|
|
7
|
+
vars: { query: 'Hello, world!' },
|
|
8
|
+
assert: [{ type: 'equals', value: 'Expected output', metric: 'Harmful' }],
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
vars: { userInput: 'Test input' },
|
|
12
|
+
assert: [{ type: 'contains', value: 'test', metric: 'DebugAccess' }],
|
|
13
|
+
},
|
|
14
|
+
];
|
|
15
|
+
it('should encode the inject variable to base64', () => {
|
|
16
|
+
const result = (0, base64_1.addBase64Encoding)(mockTestCases, 'query');
|
|
17
|
+
expect(result[0].vars?.query).toBe('SGVsbG8sIHdvcmxkIQ==');
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
//# sourceMappingURL=base64.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base64.test.js","sourceRoot":"","sources":["../../../../test/redteam/strategies/base64.test.ts"],"names":[],"mappings":";;AAAA,mEAA2E;AAG3E,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,MAAM,aAAa,GAAe;QAChC;YACE,IAAI,EAAE,EAAE,KAAK,EAAE,eAAe,EAAE;YAChC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,iBAAiB,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SAC1E;QACD;YACE,IAAI,EAAE,EAAE,SAAS,EAAE,YAAY,EAAE;YACjC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;SACrE;KACF,CAAC;IAEF,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,IAAA,0BAAiB,EAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"leetspeak.test.d.ts","sourceRoot":"","sources":["../../../../test/redteam/strategies/leetspeak.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const leetspeak_1 = require("../../../src/redteam/strategies/leetspeak");
|
|
4
|
+
describe('addLeetspeak', () => {
|
|
5
|
+
const mockTestCases = [
|
|
6
|
+
{
|
|
7
|
+
vars: { query: 'Hello, world!' },
|
|
8
|
+
assert: [{ type: 'equals', value: 'Expected output', metric: 'Harmful' }],
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
vars: { userInput: 'Test input' },
|
|
12
|
+
assert: [{ type: 'contains', value: 'test', metric: 'DebugAccess' }],
|
|
13
|
+
},
|
|
14
|
+
];
|
|
15
|
+
it('should convert the inject variable to leetspeak', () => {
|
|
16
|
+
const result = (0, leetspeak_1.addLeetspeak)(mockTestCases, 'query');
|
|
17
|
+
expect(result[0].vars?.query).toBe('H3110, w0r1d!');
|
|
18
|
+
});
|
|
19
|
+
it('should handle uppercase and lowercase letters', () => {
|
|
20
|
+
const testCase = {
|
|
21
|
+
vars: { text: 'HELLO hello' },
|
|
22
|
+
assert: [{ type: 'equals', value: 'Test', metric: 'Test' }],
|
|
23
|
+
};
|
|
24
|
+
const result = (0, leetspeak_1.addLeetspeak)([testCase], 'text');
|
|
25
|
+
expect(result[0].vars?.text).toBe('H3110 h3110');
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
//# sourceMappingURL=leetspeak.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"leetspeak.test.js","sourceRoot":"","sources":["../../../../test/redteam/strategies/leetspeak.test.ts"],"names":[],"mappings":";;AAAA,yEAAyE;AAGzE,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,MAAM,aAAa,GAAe;QAChC;YACE,IAAI,EAAE,EAAE,KAAK,EAAE,eAAe,EAAE;YAChC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,iBAAiB,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SAC1E;QACD;YACE,IAAI,EAAE,EAAE,SAAS,EAAE,YAAY,EAAE;YACjC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;SACrE;KACF,CAAC;IAEF,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,MAAM,GAAG,IAAA,wBAAY,EAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACpD,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,QAAQ,GAAa;YACzB,IAAI,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE;YAC7B,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;SAC5D,CAAC;QACF,MAAM,MAAM,GAAG,IAAA,wBAAY,EAAC,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rot13.test.d.ts","sourceRoot":"","sources":["../../../../test/redteam/strategies/rot13.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const rot13_1 = require("../../../src/redteam/strategies/rot13");
|
|
4
|
+
describe('addRot13', () => {
|
|
5
|
+
const mockTestCases = [
|
|
6
|
+
{
|
|
7
|
+
vars: { query: 'Hello, world!' },
|
|
8
|
+
assert: [{ type: 'equals', value: 'Expected output', metric: 'Harmful' }],
|
|
9
|
+
},
|
|
10
|
+
{
|
|
11
|
+
vars: { userInput: 'Test input' },
|
|
12
|
+
assert: [{ type: 'contains', value: 'test', metric: 'DebugAccess' }],
|
|
13
|
+
},
|
|
14
|
+
];
|
|
15
|
+
it('should encode the inject variable using ROT13', () => {
|
|
16
|
+
const result = (0, rot13_1.addRot13)(mockTestCases, 'query');
|
|
17
|
+
expect(result[0].vars?.query).toBe('Uryyb, jbeyq!');
|
|
18
|
+
});
|
|
19
|
+
it('should handle uppercase and lowercase letters', () => {
|
|
20
|
+
const testCase = {
|
|
21
|
+
vars: { text: 'HELLO hello' },
|
|
22
|
+
assert: [{ type: 'equals', value: 'Test', metric: 'Test' }],
|
|
23
|
+
};
|
|
24
|
+
const result = (0, rot13_1.addRot13)([testCase], 'text');
|
|
25
|
+
expect(result[0].vars?.text).toBe('URYYB uryyb');
|
|
26
|
+
});
|
|
27
|
+
it('should not change non-alphabetic characters', () => {
|
|
28
|
+
const testCase = {
|
|
29
|
+
vars: { text: 'Hello, World! 123' },
|
|
30
|
+
assert: [{ type: 'equals', value: 'Test', metric: 'Test' }],
|
|
31
|
+
};
|
|
32
|
+
const result = (0, rot13_1.addRot13)([testCase], 'text');
|
|
33
|
+
expect(result[0].vars?.text).toBe('Uryyb, Jbeyq! 123');
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
//# sourceMappingURL=rot13.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rot13.test.js","sourceRoot":"","sources":["../../../../test/redteam/strategies/rot13.test.ts"],"names":[],"mappings":";;AAAA,iEAAiE;AAGjE,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,MAAM,aAAa,GAAe;QAChC;YACE,IAAI,EAAE,EAAE,KAAK,EAAE,eAAe,EAAE;YAChC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,iBAAiB,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SAC1E;QACD;YACE,IAAI,EAAE,EAAE,SAAS,EAAE,YAAY,EAAE;YACjC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;SACrE;KACF,CAAC;IAEF,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,MAAM,GAAG,IAAA,gBAAQ,EAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,QAAQ,GAAa;YACzB,IAAI,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE;YAC7B,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;SAC5D,CAAC;QACF,MAAM,MAAM,GAAG,IAAA,gBAAQ,EAAC,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC;QAC5C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,QAAQ,GAAa;YACzB,IAAI,EAAE,EAAE,IAAI,EAAE,mBAAmB,EAAE;YACnC,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;SAC5D,CAAC;QACF,MAAM,MAAM,GAAG,IAAA,gBAAQ,EAAC,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC;QAC5C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validators.test.d.ts","sourceRoot":"","sources":["../../../test/redteam/validators.test.ts"],"names":[],"mappings":""}
|