Skip to content

feat: TPC-DS support #1

feat: TPC-DS support

feat: TPC-DS support #1

name: TPC-DS Conformance
on:
push:
branches: [ main, master ]
pull_request:
branches: [ main, master ]
env:
CARGO_TERM_COLOR: always
RUST_BACKTRACE: 1
jobs:
# Job 1: Build and test Rust code
rust-tests:
name: Rust Tests
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt, clippy
- name: Cache Rust dependencies
uses: actions/cache@v4
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
target/
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
restore-keys: |
${{ runner.os }}-cargo-
- name: Check formatting
run: cargo fmt -p tpcdsgen -- --check
- name: Run clippy
run: cargo clippy -p tpcdsgen -- -D warnings
- name: Build
run: cargo build -p tpcdsgen --verbose
- name: Run unit tests
run: cargo test -p tpcdsgen --verbose
# Job 2: Conformance testing against Java implementation
conformance-tests:
name: Conformance Tests
runs-on: ubuntu-latest
needs: rust-tests # Only run if Rust tests pass
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
- name: Set up Java
uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '11'
- name: Cache Rust dependencies
uses: actions/cache@v4
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
target/
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
restore-keys: |
${{ runner.os }}-cargo-
- name: Bootstrap Java TPC-DS implementation
run: |
cd tpcdsgen
./scripts/bootstrap-java.sh
- name: Build Rust table generators
run: |
cargo build --release -p tpcdsgen
- name: Generate test fixtures (Java reference data)
run: |
cd tpcdsgen
./scripts/generate-fixtures.sh
- name: Run conformance tests (Rust vs Java)
run: |
cd tpcdsgen
./scripts/test-all-tables.sh
- name: Upload test fixtures as artifacts
if: failure() # Upload fixtures if tests fail for debugging
uses: actions/upload-artifact@v4
with:
name: test-fixtures
path: tpcdsgen/tests/fixtures/
retention-days: 7
# Job 3: Build benchmarks (optional - only on main)
benchmarks:
name: Performance Benchmarks
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/master'
needs: conformance-tests
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
- name: Cache Rust dependencies
uses: actions/cache@v4
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
target/
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
restore-keys: |
${{ runner.os }}-cargo-
- name: Build release binaries
run: |
cargo build --release -p tpcdsgen
- name: Run benchmarks
run: |
# Generate all tables and time it using the unified CLI
mkdir -p /tmp/bench
time ./target/release/tpcdsgen --scale 1 --directory /tmp/bench
- name: Upload benchmark results
uses: actions/upload-artifact@v4
with:
name: benchmark-results
path: /tmp/bench/
retention-days: 30