examples/config-external-defaulttest/README.md
This example demonstrates how to use the file:// syntax to load defaultTest configuration from an external file.
You can run this example with:
npx promptfoo@latest init --example config-external-defaulttest
cd config-external-defaulttest
Instead of defining defaultTest inline in your main configuration file, you can reference an external YAML or JSON file. This is useful for:
external-defaulttest/
├── promptfooconfig.yaml # Main configuration file
├── shared/
│ └── defaultTest.yaml # Shared default test configuration
└── README.md # This file
# Traditional inline approach
defaultTest:
assert:
- type: cost
threshold: 0.01
- type: latency
threshold: 5000
options:
provider: openai:o4-mini
# New external file approach
defaultTest: file://shared/defaultTest.yaml
The external file (shared/defaultTest.yaml) contains the same configuration that would normally be inline.
cd examples/config-external-defaulttest
npx promptfoo@latest eval
The external defaultTest configuration will be loaded automatically and applied to all test cases that don't override the defaults.
You can also reference defaultTest files from parent directories or absolute paths:
# Reference from parent directory
defaultTest: file://../shared-configs/defaultTest.yaml
# Reference from project root
defaultTest: file://configs/testing/defaultTest.yaml