name: run-e2e
description: Run E2E tests locally using the new-e2e framework with Pulumi-based infrastructure
allowed-tools: Bash, Read, Glob, Grep
argument-hint: " [--run TestName] [--keep-stack] [--configparams key=value]"
model: sonnet
Run E2E tests from test/new-e2e/tests/ using dda inv new-e2e-tests.run.
Instructions
Parse
$ARGUMENTSto determine what to run. The user may provide:- A test directory path (e.g.,
windows/install-test,agent-platform/upgrade,containers) - A test function name (e.g.,
TestInstall,TestUpgrade) - Flags to pass through (see below)
- A combination of the above
- A test directory path (e.g.,
Resolve the test target:
- The invoke task automatically prepends
test/new-e2e/to targets, so targets must be relative to that directory (e.g.,./tests/agent-subcommands/flare, NOT./test/new-e2e/tests/...) - If the user gives a directory like
agent-subcommands/flare, use./tests/agent-subcommands/flareas--targets - If the user gives a partial name, search for matching directories under
test/new-e2e/tests/using Glob, then strip thetest/new-e2e/prefix for the target - If the user gives a test function name (starts with
Test), find which package contains it using Grep undertest/new-e2e/tests/, then set--targetsto the package path (relative totest/new-e2e/) and--runto the test name - If ambiguous, list the matching options and ask the user to pick one
- The invoke task automatically prepends
Build the command:
dda inv new-e2e-tests.run --targets=./tests/<path> [flags]IMPORTANT:
--targetspaths are relative totest/new-e2e/. Do NOT includetest/new-e2e/in the target path.Supported flags (pass through from
$ARGUMENTS):--run <regex>— Only run tests matching this regex--skip <regex>— Skip tests matching this regex--keep-stack— Keep infrastructure up after test (for debugging)--configparams <key=value>— Override Pulumi ConfigMap parameters--agent-image <image:tag>— Use a specific agent image--cluster-agent-image <image:tag>— Use a specific cluster agent image--stack-name-suffix <suffix>— Add suffix to stack name (useful for stuck stacks)--verbose/--no-verbose— Toggle verbose output (default: verbose)--max-retries <n>— Retry failed tests up to n times--flavor <flavor>— Package flavor (e.g., "datadog-agent")--cache— Enable test cache (disabled by default)
Before running, confirm the full command with the user.
Run the command with a 60-minute timeout (infrastructure provisioning can take a while). Use
run_in_backgroundfor the Bash tool since e2e tests are long-running.After completion, summarize the results: which tests passed, which failed, and any useful error output.
Prerequisites
The following must be configured before running e2e tests:
pulumiCLI installed~/.test_infra_config.yamlexists with proper configuration
If any prerequisite is missing, inform the user what needs to be set up.
Available Test Suites
Tests are organized under test/new-e2e/tests/, running ls test/new-e2e/tests should give the list of test packages
Issues when running tests
If the test was previously executed and that the infra is in a weird state, that Pulumi is not aware of, trying to rerun the test with the same stack can lead to strange error, like resource being replaced, while they should not exist at all yet.
To avoid that issue it is possible to execute the test with a stack with a different name, using --stack-name-suffix
Examples
# Run all tests in a directory
dda inv new-e2e-tests.run --targets=./tests/windows/install-test
# Run a specific test
dda inv new-e2e-tests.run --targets=./tests/agent-platform/tests/upgrade --run TestUpgrade
# Keep stack for debugging
dda inv new-e2e-tests.run --targets=./tests/containers --run TestContainerLinux --keep-stack
# Run with specific agent image
dda inv new-e2e-tests.run --targets=./tests/agent-platform/tests --agent-image "my-registry/agent:latest"
# Run with stack name suffix
dda inv new-e2e-tests.run --targets=./tests/windows/install-test --stack-name-suffix 2
## Usage
- `/run-e2e windows/install-test` — Run all Windows install tests
- `/run-e2e windows/install-test --run TestInstall` — Run only TestInstall
- `/run-e2e TestUpgrade` — Auto-find and run TestUpgrade
- `/run-e2e agent-platform --keep-stack` — Run with stack kept alive
## Output
Show the user the full command before running, then report test results when done.