-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add sqlite test files, progress bar, and automatic postgres container…
… management into sqllogictests (#13936) * Fix md5 return_type to only return Utf8 as per current code impl. * Add support for sqlite test files to sqllogictest * Force version 0.24.0 of sqllogictest dependency until issue with labels is fixed. * Removed workaround for bug that was fixed. * Git submodule update ... err update, link to sqlite tests. * Git submodule update * Readd submodule --------- Co-authored-by: Andrew Lamb <[email protected]>
- Loading branch information
Showing
8 changed files
with
611 additions
and
101 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Submodule datafusion-testing
added at
e2e320
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -28,13 +28,14 @@ This crate is a submodule of DataFusion that contains an implementation of [sqll | |
## Overview | ||
|
||
This crate uses [sqllogictest-rs](https://github.com/risinglightdb/sqllogictest-rs) to parse and run `.slt` files in the | ||
[`test_files`](test_files) directory of this crate. | ||
[`test_files`](test_files) directory of this crate or the [`data/sqlite`](sqlite) | ||
directory of the datafusion-testing crate. | ||
|
||
## Testing setup | ||
|
||
1. `rustup update stable` DataFusion uses the latest stable release of rust | ||
2. `git submodule init` | ||
3. `git submodule update` | ||
3. `git submodule update --init --remote --recursive` | ||
|
||
## Running tests: TLDR Examples | ||
|
||
|
@@ -160,7 +161,7 @@ cargo test --test sqllogictests -- information | |
Test files that start with prefix `pg_compat_` verify compatibility | ||
with Postgres by running the same script files both with DataFusion and with Postgres | ||
|
||
In order to run the sqllogictests running against a previously running Postgres instance, do: | ||
In order to have the sqllogictest run against an existing running Postgres instance, do: | ||
|
||
```shell | ||
PG_COMPAT=true PG_URI="postgresql://[email protected]/postgres" cargo test --features=postgres --test sqllogictests | ||
|
@@ -172,7 +173,7 @@ The environment variables: | |
2. `PG_URI` contains a `libpq` style connection string, whose format is described in | ||
[the docs](https://docs.rs/tokio-postgres/latest/tokio_postgres/config/struct.Config.html#url) | ||
|
||
One way to create a suitable a posgres container in docker is to use | ||
One way to create a suitable a postgres container in docker is to use | ||
the [Official Image](https://hub.docker.com/_/postgres) with a command | ||
such as the following. Note the collation **must** be set to `C` otherwise | ||
`ORDER BY` will not match DataFusion and the tests will diff. | ||
|
@@ -185,6 +186,15 @@ docker run \ | |
postgres | ||
``` | ||
|
||
If you do not want to create a new postgres database and you have docker | ||
installed you can skip providing a PG_URI env variable and the sqllogictest | ||
runner will automatically create a temporary postgres docker container. | ||
For example: | ||
|
||
```shell | ||
PG_COMPAT=true cargo test --features=postgres --test sqllogictests | ||
``` | ||
|
||
## Running Tests: `tpch` | ||
|
||
Test files in `tpch` directory runs against the `TPCH` data set (SF = | ||
|
@@ -205,6 +215,34 @@ Then you need to add `INCLUDE_TPCH=true` to run tpch tests: | |
INCLUDE_TPCH=true cargo test --test sqllogictests | ||
``` | ||
|
||
## Running Tests: `sqlite` | ||
|
||
Test files in `data/sqlite` directory of the datafusion-testing crate were | ||
sourced from the [sqlite test suite](https://www.sqlite.org/sqllogictest/dir?ci=tip) and have been cleansed and updated to | ||
run within DataFusion's sqllogictest runner. | ||
|
||
To run the sqlite tests you need to increase the rust stack size and add | ||
`INCLUDE_SQLITE=true` to run the sqlite tests: | ||
|
||
```shell | ||
export RUST_MIN_STACK=30485760; | ||
INCLUDE_SQLITE=true cargo test --test sqllogictests | ||
``` | ||
|
||
Note that there are well over 5 million queries in these tests and running the | ||
sqlite tests will take a long time. You may wish to run them in release-nonlto mode: | ||
|
||
```shell | ||
INCLUDE_SQLITE=true cargo test --profile release-nonlto --test sqllogictests | ||
``` | ||
|
||
The sqlite tests can also be run with the postgres runner to verify compatibility: | ||
|
||
```shell | ||
export RUST_MIN_STACK=30485760; | ||
PG_COMPAT=true INCLUDE_SQLITE=true cargo test --features=postgres --test sqllogictests | ||
``` | ||
|
||
## Updating tests: Completion Mode | ||
|
||
In test script completion mode, `sqllogictests` reads a prototype script and runs the statements and queries against the | ||
|
Oops, something went wrong.