Find original test suites of each DBMS at: Original Test Suites
They are downloaded from:
- DuckDB: DuckDB Test SQL
- SQLite: SQLite Test Suite
- PostgreSQL: PostgreSQL Test
- ClickHouse: ClickHouse Test Queries
- db.sql: contains SQL statements for setting up database (none if doesn't need set up statements)
- test.sql: contains the test query
- result.csv: contains the query result.
-
Test cases are organized into test collections, each test collection consists of multiple test cases.
-
All test cases inside a test collection share the same db.sql file as set-up statements. (none if doesn't need set up statements)
-
Each test case consists of one test.sql file and one result.csv file.
- All query results are located at: Dialect Comparison
- Top level is the guest DBMS
- Execution of the same test case on different DBMS are stored together. File name format: {host_db}_result_{success|error}.csv
data:image/s3,"s3://crabby-images/4eea2/4eea2effa27ecb7bf8244b54f6e7f25f6f0e1299" alt="image"
To reproduce the results, follow the steps outlined in the documentation provided in each test suite repository.
# Create a Python virtual environment
python3 -m venv venv
# Activate the virtual environment
source venv/bin/activate
# Install dependencies
pip install duckdb psycopg2 clickhouse-connect docker
docker pull postgres:latest
python scripts/generate_result guest_db host_db
# e.g. to run SQLite's test cases on DuckDB:
python scripts/generate_result sqlite duck
We encountered some issues while working with ClickHouse. There were session lock issues that we couldn't resolve, and as a result, we didn't include results from ClickHouse in the report.