| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you under the Apache License, Version 2.0 (the |
| # "License"); you may not use this file except in compliance |
| # with the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, |
| # software distributed under the License is distributed on an |
| # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| # KIND, either express or implied. See the License for the |
| # specific language governing permissions and limitations |
| # under the License. |
| |
| name: Rust |
| |
| concurrency: |
| group: ${{ github.repository }}-${{ github.head_ref || github.sha }}-${{ github.workflow }} |
| cancel-in-progress: true |
| |
| on: |
| push: |
| branches-ignore: |
| - 'gh-readonly-queue/**' |
| paths-ignore: |
| - "docs/**" |
| - "**.md" |
| - ".github/ISSUE_TEMPLATE/**" |
| - ".github/pull_request_template.md" |
| pull_request: |
| paths-ignore: |
| - "docs/**" |
| - "**.md" |
| - ".github/ISSUE_TEMPLATE/**" |
| - ".github/pull_request_template.md" |
| merge_group: |
| # manual trigger |
| # https://docs.github.com/en/actions/managing-workflow-runs/manually-running-a-workflow |
| workflow_dispatch: |
| |
| jobs: |
| # Check crate compiles and base cargo check passes |
| linux-build-lib: |
| name: linux build test |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Rust Dependency Cache |
| uses: Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5 # v2.8.2 |
| with: |
| shared-key: "amd-ci-check" # this job uses it's own cache becase check has a separate cache and we need it to be fast as it blocks other jobs |
| save-if: ${{ github.ref_name == 'main' }} |
| - name: Prepare cargo build |
| run: | |
| # Adding `--locked` here to assert that the `Cargo.lock` file is up to |
| # date with the manifest. When this fails, please make sure to commit |
| # the changes to `Cargo.lock` after building with the updated manifest. |
| cargo check --profile ci --workspace --all-targets --features integration-tests --locked |
| |
| # Check datafusion-common features |
| # |
| # Ensure via `cargo check` that the crate can be built with a |
| # subset of the features packages enabled. |
| linux-datafusion-common-features: |
| name: cargo check datafusion-common features |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Check datafusion-common (default features) |
| run: cargo check --profile ci --all-targets -p datafusion-common |
| # |
| # Note: Only check libraries (not --all-targets) to cover end user APIs |
| # |
| - name: Check datafusion-common (no-default-features) |
| run: cargo check --profile ci --no-default-features -p datafusion-common |
| # Note: don't check other feature flags as datafusion-common is not typically used standalone |
| |
| # Check datafusion-substrait features |
| # |
| # Ensure via `cargo check` that the crate can be built with a |
| # subset of the features packages enabled. |
| linux-datafusion-substrait-features: |
| name: cargo check datafusion-substrait features |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Rust Dependency Cache |
| uses: Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5 # v2.8.2 |
| with: |
| save-if: false # set in linux-test |
| shared-key: "amd-ci" |
| - name: Check datafusion-substrait (default features) |
| run: cargo check --profile ci --all-targets -p datafusion-substrait |
| # |
| # Note: Only check libraries (not --all-targets) to cover end user APIs |
| # |
| - name: Check datafusion-substrait (no-default-features) |
| run: cargo check --profile ci --no-default-features -p datafusion-substrait |
| - name: Check datafusion-substrait (physical) |
| run: cargo check --profile ci --no-default-features -p datafusion-substrait --features=physical |
| - name: Install cmake |
| run: | |
| # note the builder setup runs apt-get update / installs protobuf compiler |
| apt-get install -y cmake |
| - name: Check datafusion-substrait (protoc) |
| run: cargo check --profile ci --no-default-features -p datafusion-substrait --features=protoc |
| |
| # Check datafusion-proto features |
| # |
| # Ensure via `cargo check` that the crate can be built with a |
| # subset of the features packages enabled. |
| linux-datafusion-proto-features: |
| name: cargo check datafusion-proto features |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Check datafusion-proto (default features) |
| run: cargo check --profile ci --all-targets -p datafusion-proto |
| # |
| # Note: Only check libraries (not --all-targets) to cover end user APIs |
| # |
| - name: Check datafusion-proto (no-default-features) |
| run: cargo check --profile ci --no-default-features -p datafusion-proto |
| - name: Check datafusion-proto (json) |
| run: cargo check --profile ci --no-default-features -p datafusion-proto --features=json |
| - name: Check datafusion-proto (parquet) |
| run: cargo check --profile ci --no-default-features -p datafusion-proto --features=parquet |
| - name: Check datafusion-proto (avro) |
| run: cargo check --profile ci --no-default-features -p datafusion-proto --features=avro |
| |
| |
| # Check datafusion crate features |
| # |
| # Ensure via `cargo check` that the crate can be built with a |
| # subset of the features packages enabled. |
| linux-cargo-check-datafusion: |
| name: cargo check datafusion features |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Rust Dependency Cache |
| uses: Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5 # v2.8.2 |
| with: |
| save-if: false # set in linux-test |
| shared-key: "amd-ci" |
| - name: Check datafusion (default features) |
| run: cargo check --profile ci --all-targets -p datafusion |
| # |
| # Note: Only check libraries (not --all-targets) to cover end user APIs |
| # |
| - name: Check datafusion (no-default-features) |
| run: cargo check --profile ci --no-default-features -p datafusion |
| - name: Check datafusion (nested_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=nested_expressions |
| - name: Check datafusion (array_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=array_expressions |
| - name: Check datafusion (avro) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=avro |
| - name: Check datafusion (backtrace) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=backtrace |
| - name: Check datafusion (compression) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=compression |
| - name: Check datafusion (crypto_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=crypto_expressions |
| - name: Check datafusion (datetime_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=datetime_expressions |
| - name: Check datafusion (encoding_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=encoding_expressions |
| - name: Check datafusion (force_hash_collisions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=force_hash_collisions |
| - name: Check datafusion (math_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=math_expressions |
| - name: Check datafusion (parquet) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=parquet |
| - name: Check datafusion (regex_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=regex_expressions |
| - name: Check datafusion (recursive_protection) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=recursive_protection |
| - name: Check datafusion (serde) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=serde |
| - name: Check datafusion (sql) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=sql |
| - name: Check datafusion (string_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=string_expressions |
| - name: Check datafusion (unicode_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=unicode_expressions |
| - name: Check parquet encryption (parquet_encryption) |
| run: cargo check --profile ci --no-default-features -p datafusion --features=parquet_encryption |
| |
| # Check datafusion-functions crate features |
| # |
| # Ensure via `cargo check` that the crate can be built with a |
| # subset of the features packages enabled. |
| linux-cargo-check-datafusion-functions: |
| name: cargo check datafusion-functions features |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Check datafusion-functions (default features) |
| run: cargo check --profile ci --all-targets -p datafusion-functions |
| # |
| # Note: Only check libraries (not --all-targets) to cover end user APIs |
| # |
| - name: Check datafusion-functions (no-default-features) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions |
| - name: Check datafusion-functions (crypto_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions --features=crypto_expressions |
| - name: Check datafusion-functions (datetime_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions --features=datetime_expressions |
| - name: Check datafusion-functions (encoding_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions --features=encoding_expressions |
| - name: Check datafusion-functions (math_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions --features=math_expressions |
| - name: Check datafusion-functions (regex_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions --features=regex_expressions |
| - name: Check datafusion-functions (string_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions --features=string_expressions |
| - name: Check datafusion-functions (unicode_expressions) |
| run: cargo check --profile ci --no-default-features -p datafusion-functions --features=unicode_expressions |
| |
| # Library and integration tests |
| linux-test: |
| name: cargo test (amd64) |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| volumes: |
| - /usr/local:/host/usr/local |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Rust Dependency Cache |
| uses: Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5 # v2.8.2 |
| with: |
| save-if: ${{ github.ref_name == 'main' }} |
| shared-key: "amd-ci" |
| - name: Run tests (excluding doctests and datafusion-cli) |
| env: |
| RUST_BACKTRACE: 1 |
| run: | |
| cargo test \ |
| --profile ci \ |
| --exclude datafusion-examples \ |
| --exclude ffi_example_table_provider \ |
| --exclude datafusion-benchmarks \ |
| --exclude datafusion-cli \ |
| --workspace \ |
| --lib \ |
| --tests \ |
| --bins \ |
| --features serde,avro,json,backtrace,integration-tests,parquet_encryption |
| - name: Verify Working Directory Clean |
| run: git diff --exit-code |
| # Check no temporary directories created during test. |
| # `false/` folder is excuded for rust cache. |
| - name: Verify Working Directory Clean (No Untracked Files) |
| run: | |
| STATUS="$(git status --porcelain | sed -e '/^?? false\/$/d' -e '/^?? false$/d')" |
| if [ -n "$STATUS" ]; then |
| echo "$STATUS" |
| exit 1 |
| fi |
| |
| # datafusion-cli tests |
| linux-test-datafusion-cli: |
| name: cargo test datafusion-cli (amd64) |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| run: rustup toolchain install stable |
| - name: Rust Dependency Cache |
| uses: Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5 # v2.8.2 |
| with: |
| save-if: false # set in linux-test |
| shared-key: "amd-ci" |
| - name: Run tests (excluding doctests) |
| env: |
| RUST_BACKTRACE: 1 |
| AWS_ENDPOINT: http://127.0.0.1:9000 |
| AWS_ACCESS_KEY_ID: TEST-DataFusionLogin |
| AWS_SECRET_ACCESS_KEY: TEST-DataFusionPassword |
| TEST_STORAGE_INTEGRATION: 1 |
| AWS_ALLOW_HTTP: true |
| run: cargo test --features backtrace --profile ci -p datafusion-cli --lib --tests --bins |
| - name: Verify Working Directory Clean |
| run: git diff --exit-code |
| |
| |
| linux-test-example: |
| name: cargo examples (amd64) |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Rust Dependency Cache |
| uses: Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5 # v2.8.2 |
| with: |
| save-if: ${{ github.ref_name == 'main' }} |
| shared-key: "amd-ci-linux-test-example" |
| - name: Run examples |
| run: | |
| # test datafusion-sql examples |
| cargo run --profile ci --example sql |
| # test datafusion-examples |
| ci/scripts/rust_example.sh |
| - name: Verify Working Directory Clean |
| run: git diff --exit-code |
| |
| # Run `cargo test doc` (test documentation examples) |
| linux-test-doc: |
| name: cargo test doc (amd64) |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Run doctests |
| run: cargo test --profile ci --doc --features avro,json |
| - name: Verify Working Directory Clean |
| run: git diff --exit-code |
| |
| # Run `cargo doc` to ensure the rustdoc is clean |
| linux-rustdoc: |
| name: cargo doc |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Run cargo doc |
| run: ci/scripts/rust_docs.sh |
| |
| linux-wasm-pack: |
| name: build and run with wasm-pack |
| runs-on: ubuntu-24.04 |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup for wasm32 |
| run: | |
| rustup target add wasm32-unknown-unknown |
| - name: Install dependencies |
| run: | |
| sudo apt-get update -qq |
| sudo apt-get install -y -qq clang |
| - name: Setup wasm-pack |
| uses: taiki-e/install-action@386d9ef5a1dde23219d42c562ab251ed9ce92f98 # v2.67.9 |
| with: |
| tool: wasm-pack |
| - name: Run tests with headless mode |
| working-directory: ./datafusion/wasmtest |
| run: | |
| # debuginfo=none because CI tests weren't completing successfully after this upstream PR: |
| # https://github.com/wasm-bindgen/wasm-bindgen/pull/4635 |
| RUSTFLAGS='--cfg getrandom_backend="wasm_js" -C debuginfo=none' wasm-pack test --headless --firefox |
| RUSTFLAGS='--cfg getrandom_backend="wasm_js" -C debuginfo=none' wasm-pack test --headless --chrome --chromedriver $CHROMEWEBDRIVER/chromedriver |
| |
| # verify that the benchmark queries return the correct results |
| verify-benchmark-results: |
| name: verify benchmark results (amd64) |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Generate benchmark data and expected query results |
| run: | |
| mkdir -p datafusion/sqllogictest/test_files/tpch/data |
| git clone https://github.com/databricks/tpch-dbgen.git |
| cd tpch-dbgen |
| make |
| ./dbgen -f -s 0.1 |
| mv *.tbl ../datafusion/sqllogictest/test_files/tpch/data |
| - name: Verify that benchmark queries return expected results |
| run: | |
| # increase stack size to fix stack overflow |
| export RUST_MIN_STACK=20971520 |
| export TPCH_DATA=`realpath datafusion/sqllogictest/test_files/tpch/data` |
| cargo test plan_q --package datafusion-benchmarks --profile ci --features=ci -- --test-threads=1 |
| INCLUDE_TPCH=true cargo test --features backtrace,parquet_encryption --profile ci --package datafusion-sqllogictest --test sqllogictests |
| - name: Verify Working Directory Clean |
| run: git diff --exit-code |
| |
| sqllogictest-postgres: |
| name: "Run sqllogictest with Postgres runner" |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| services: |
| postgres: |
| image: postgres:15 |
| env: |
| POSTGRES_PASSWORD: postgres |
| POSTGRES_DB: db_test |
| POSTGRES_INITDB_ARGS: --encoding=UTF-8 --lc-collate=C --lc-ctype=C |
| ports: |
| - 5432:5432 |
| options: >- |
| --health-cmd pg_isready |
| --health-interval 10s |
| --health-timeout 5s |
| --health-retries 5 |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Run sqllogictest |
| run: | |
| cd datafusion/sqllogictest |
| PG_COMPAT=true PG_URI="postgresql://postgres:postgres@$POSTGRES_HOST:$POSTGRES_PORT/db_test" cargo test --features backtrace --profile ci --features=postgres --test sqllogictests |
| env: |
| # use postgres for the host here because we have specified a container for the job |
| POSTGRES_HOST: postgres |
| POSTGRES_PORT: ${{ job.services.postgres.ports[5432] }} |
| |
| sqllogictest-substrait: |
| name: "Run sqllogictest in Substrait round-trip mode" |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Run sqllogictest |
| # TODO: Right now several tests are failing in Substrait round-trip mode, so this |
| # command cannot be run for all the .slt files. Run it for just one that works (limit.slt) |
| # until most of the tickets in https://github.com/apache/datafusion/issues/16248 are addressed |
| # and this command can be run without filters. |
| run: cargo test --test sqllogictests -- --substrait-round-trip limit.slt |
| |
| # Temporarily commenting out the Windows flow, the reason is enormously slow running build |
| # Waiting for new Windows 2025 github runner |
| # Details: https://github.com/apache/datafusion/issues/13726 |
| # |
| # windows: |
| # name: cargo test (win64) |
| # runs-on: windows-latest |
| # steps: |
| # - uses: actions/checkout@v4 |
| # with: |
| # submodules: true |
| # - name: Setup Rust toolchain |
| # uses: ./.github/actions/setup-windows-builder |
| # - name: Run tests (excluding doctests) |
| # shell: bash |
| # run: | |
| # export PATH=$PATH:$HOME/d/protoc/bin |
| # cargo test --lib --tests --bins --features avro,json,backtrace |
| |
| macos-aarch64: |
| name: cargo test (macos-aarch64) |
| runs-on: macos-14 |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-macos-aarch64-builder |
| - name: Run tests (excluding doctests) |
| shell: bash |
| run: cargo test --profile ci --exclude datafusion-cli --workspace --lib --tests --bins --features avro,json,backtrace,integration-tests |
| |
| vendor: |
| name: Verify Vendored Code |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Run gen |
| run: ./regen.sh |
| working-directory: ./datafusion/proto |
| - name: Verify workspace clean (if this fails, run ./datafusion/proto/regen.sh and check in results) |
| run: git diff --exit-code |
| |
| check-fmt: |
| name: Check cargo fmt |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Run |
| run: | |
| echo '' > datafusion/proto/src/generated/datafusion.rs |
| ci/scripts/rust_fmt.sh |
| |
| # Coverage job disabled due to |
| # https://github.com/apache/datafusion/issues/3678 |
| |
| # coverage: |
| # name: coverage |
| # runs-on: ubuntu-latest |
| # steps: |
| # - uses: actions/checkout@v4 |
| # with: |
| # submodules: true |
| # - name: Install protobuf compiler |
| # shell: bash |
| # run: | |
| # mkdir -p $HOME/d/protoc |
| # cd $HOME/d/protoc |
| # export PROTO_ZIP="protoc-21.4-linux-x86_64.zip" |
| # curl -LO https://github.com/protocolbuffers/protobuf/releases/download/v21.4/$PROTO_ZIP |
| # unzip $PROTO_ZIP |
| # export PATH=$PATH:$HOME/d/protoc/bin |
| # protoc --version |
| # - name: Setup Rust toolchain |
| # run: | |
| # rustup toolchain install stable |
| # rustup default stable |
| # rustup component add rustfmt clippy |
| # - name: Cache Cargo |
| # uses: actions/cache@v4 |
| # with: |
| # path: /home/runner/.cargo |
| # # this key is not equal because the user is different than on a container (runner vs github) |
| # key: cargo-coverage-cache3- |
| # - name: Run coverage |
| # run: | |
| # export PATH=$PATH:$HOME/d/protoc/bin |
| # rustup toolchain install stable |
| # rustup default stable |
| # cargo install --version 0.20.1 cargo-tarpaulin |
| # cargo tarpaulin --all --out Xml |
| # - name: Report coverage |
| # continue-on-error: true |
| # run: bash <(curl -s https://codecov.io/bash) |
| |
| clippy: |
| name: clippy |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Install Clippy |
| run: rustup component add clippy |
| - name: Rust Dependency Cache |
| uses: Swatinem/rust-cache@779680da715d629ac1d338a641029a2f4372abb5 # v2.8.2 |
| with: |
| save-if: ${{ github.ref_name == 'main' }} |
| shared-key: "amd-ci-clippy" |
| - name: Run clippy |
| run: ci/scripts/rust_clippy.sh |
| |
| cargo-toml-formatting-checks: |
| name: check Cargo.toml formatting |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - name: Install taplo |
| run: cargo +stable install taplo-cli --version ^0.9 --locked |
| # if you encounter an error, try running 'taplo format' to fix the formatting automatically. |
| - name: Check Cargo.toml formatting |
| run: taplo format --check |
| |
| config-docs-check: |
| name: check configs.md and ***_functions.md is up-to-date |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| with: |
| rust-version: stable |
| - uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 |
| with: |
| node-version: "20" |
| - name: Check if configs.md has been modified |
| run: | |
| # If you encounter an error, run './dev/update_config_docs.sh' and commit |
| ./dev/update_config_docs.sh |
| git diff --exit-code |
| - name: Check if any of the ***_functions.md has been modified |
| run: | |
| # If you encounter an error, run './dev/update_function_docs.sh' and commit |
| ./dev/update_function_docs.sh |
| git diff --exit-code |
| |
| examples-docs-check: |
| name: check example README is up-to-date |
| needs: linux-build-lib |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| with: |
| submodules: true |
| fetch-depth: 1 |
| |
| - name: Run examples docs check script |
| run: | |
| bash ci/scripts/check_examples_docs.sh |
| |
| # Verify MSRV for the crates which are directly used by other projects: |
| # - datafusion |
| # - datafusion-substrait |
| # - datafusion-proto |
| # - datafusion-cli |
| msrv: |
| name: Verify MSRV (Min Supported Rust Version) |
| runs-on: ubuntu-latest |
| container: |
| image: amd64/rust |
| steps: |
| - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 |
| - name: Setup Rust toolchain |
| uses: ./.github/actions/setup-builder |
| - name: Install cargo-msrv |
| uses: taiki-e/install-action@386d9ef5a1dde23219d42c562ab251ed9ce92f98 # v2.67.9 |
| with: |
| tool: cargo-msrv |
| |
| - name: Check datafusion |
| working-directory: datafusion/core |
| run: | |
| # If you encounter an error with any of the commands below it means |
| # your code or some crate in the dependency tree has a higher MSRV |
| # (Min Supported Rust Version) than the one specified in the |
| # `rust-version` key of `Cargo.toml`. |
| # |
| # To reproduce: |
| # 1. Install the version of Rust that is failing. |
| # 2. Run the command that failed with that version. |
| # |
| # Example: |
| # # MSRV looks like "1.80.0" and is specified in Cargo.toml. We can read the value with the following command: |
| # msrv="$(cargo metadata --format-version=1 | jq '.packages[] | select( .name == "datafusion" ) | .rust_version' -r)" |
| # echo "MSRV: ${msrv}" |
| # rustup install "${msrv}" |
| # cargo "+${msrv}" check |
| # |
| # To resolve, either: |
| # 1. Change your code to use older Rust features, |
| # 2. Revert dependency update |
| # 3. Update the MSRV version in `Cargo.toml` |
| # |
| # Please see the DataFusion Rust Version Compatibility Policy before |
| # updating Cargo.toml. You may have to update the code instead. |
| # https://github.com/apache/datafusion/blob/main/README.md#rust-version-compatibility-policy |
| cargo msrv --output-format json --log-target stdout verify |
| - name: Check datafusion-substrait |
| working-directory: datafusion/substrait |
| run: cargo msrv --output-format json --log-target stdout verify |
| - name: Check datafusion-proto |
| working-directory: datafusion/proto |
| run: cargo msrv --output-format json --log-target stdout verify |