BenchBox Testing Guide¶
This guide summarizes the testing infrastructure and provides guidance on running different test tiers based on your development needs and available dependencies.
Quick Start¶
The test suite is organized into tiers for different development workflows:
Fast Unit Tests (~30 seconds, no external dependencies):
make test-fast
# or
uv run -- python -m pytest -m fast
Integration Tests (~5 minutes, requires local databases):
make test-integration
# or
uv run -- python -m pytest -m "integration and not live_integration"
E2E Tests (validates complete CLI workflows):
make test-e2e-quick # Dry-run mode, fast
# or
uv run -- python -m pytest -m e2e_quick
# Full E2E with local platforms
uv run -- python -m pytest tests/e2e/ -v
Full Suite (requires all dependencies):
make test-all
# or
uv run -- python -m pytest
Test Organization¶
The suite contains 3576+ tests organized into:
Unit tests (
tests/unit/): Fast component tests with no external dependenciesIntegration tests (
tests/integration/): Database integration and component interactionE2E tests (
tests/e2e/): Complete CLI workflow validation (125+ tests)Example tests (
tests/examples/): Validate example scripts work correctly
Platform Smoke Suite¶
Run all smoke checks:
make test-smoke
# or
uv run -- python -m pytest -m platform_smoke
Run specific platform smoke tests:
# Local adapters (DuckDB/SQLite)
uv run -- python -m pytest tests/integration/platforms/test_local_platforms_smoke.py
# Cloud adapters with stubbed clients
# Databricks
uv run -- python -m pytest tests/integration/platforms/test_databricks_smoke.py
# BigQuery
uv run -- python -m pytest tests/integration/platforms/test_bigquery_smoke.py
# Redshift
uv run -- python -m pytest tests/integration/platforms/test_redshift_smoke.py
# Snowflake
uv run -- python -m pytest tests/integration/platforms/test_snowflake_smoke.py
Each test file installs lightweight client stubs automatically so you can run the suite without provisioning real services. Failures generally indicate a behavioral regression in the corresponding adapter.
E2E Test Suite¶
The E2E test suite (tests/e2e/) provides comprehensive validation of CLI workflows:
Test Module |
Coverage |
|---|---|
|
CLI option validation (–benchmark, –scale, –phases, etc.) |
|
Error messages and exit codes for invalid inputs |
|
Result file schema and content validation |
|
Full execution on DuckDB, SQLite, DataFusion |
|
Dry-run tests for Snowflake, BigQuery, etc. |
|
DataFrame platforms (Polars, Pandas, Dask) |
Run E2E tests:
# Quick E2E (dry-run mode)
uv run -- python -m pytest -m e2e_quick
# Local platform tests (full execution)
uv run -- python -m pytest -m e2e_local
# All E2E tests
uv run -- python -m pytest tests/e2e/ -v
See E2E Testing Guide for detailed documentation.
CLI Dry-Run Coverage¶
The CLI tests exercise benchbox run --dry-run across all platforms.
Cloud platform dry-run tests use stubs and require no credentials:
uv run -- python -m pytest tests/e2e/test_cloud_platforms.py -v
The ClickHouse dry-run uses a temporary stub of the chdb package; no manual
installation is required for the smoke test.
Optional Dependencies¶
Some tests require optional dependencies that are not installed by default. These tests will be automatically skipped with clear messages when dependencies are unavailable.
TPC Binary Dependencies¶
TPC-H Queries: Some tests require the qgen binary from TPC-H sources.
Location:
benchbox/_sources/tpc-h/qgen/Installation: Download from tpc.org and compile following
docs/development/tpc-compilation-guide.mdTests affected: Query generation and validation tests
TPC-DS Data Generation: Some tests require dsdgen binary from TPC-DS sources.
Location:
benchbox/_sources/tpc-ds/tools/Installation: Download from tpc.org and compile
Tests affected: Example tests that generate TPC-DS data (e.g.,
test_duckdb_tpcds_power_runs)
Cloud Platform Dependencies¶
Tests for cloud platforms require their respective SDKs:
BigQuery:
google-cloud-bigquerypackageDatabricks:
databricks-sql-connectorpackageSnowflake:
snowflake-connector-pythonpackageRedshift:
redshift-connectorpackageClickHouse:
clickhouse-driverorchdbpackage
Cloud platform tests use stubbed clients for smoke tests but require real credentials for full integration tests.
Running Tests With Optional Dependencies¶
To run tests that require specific dependencies:
# Install cloud platform extras
uv pip install -e ".[bigquery,databricks,snowflake]"
# Run BigQuery tests
make test-bigquery
# or
uv run -- python -m pytest -m bigquery
# Run all tests including those requiring TPC binaries
uv run -- python -m pytest --run-optional
Test Status¶
Current test suite status:
✅ CLI Exporter Tests: 30/30 passing (
tests/unit/cli/test_cli_output.py)✅ Result Schema Tests: 12/12 passing (
tests/unit/core/test_result_schema.py)✅ Test Collection: 3576 tests collected with 0 errors
⚠️ Full Suite: Some tests skipped when optional dependencies unavailable
For questions or issues, see the troubleshooting section in docs/development/adding-new-platforms.md.