feat: lakefs integration #8141
Workflow file for this run
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
name: build | |
on: | |
push: | |
branches: [main, "rust-v*"] | |
pull_request: | |
branches: [main, "rust-v*"] | |
merge_group: | |
env: | |
DEFAULT_FEATURES: "azure,datafusion,s3,gcs,glue,hdfs " | |
jobs: | |
format: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install minimal stable with clippy and rustfmt | |
uses: actions-rs/toolchain@v1 | |
with: | |
profile: default | |
toolchain: '1.81' | |
override: true | |
- name: Format | |
run: cargo fmt -- --check | |
build: | |
strategy: | |
fail-fast: false | |
matrix: | |
os: | |
- ubuntu-latest | |
- windows-latest | |
runs-on: ${{ matrix.os }} | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install minimal stable with clippy and rustfmt | |
uses: actions-rs/toolchain@v1 | |
with: | |
profile: default | |
toolchain: '1.81' | |
override: true | |
- name: build and lint with clippy | |
run: cargo clippy --features ${{ env.DEFAULT_FEATURES }} --tests | |
- name: Spot-check build for native-tls features | |
run: cargo clippy --no-default-features --features azure,datafusion,s3-native-tls,gcs,glue --tests | |
- name: Check docs | |
run: cargo doc --features ${{ env.DEFAULT_FEATURES }} | |
- name: Check no default features (except rustls) | |
run: cargo check --no-default-features --features rustls | |
test: | |
strategy: | |
fail-fast: false | |
matrix: | |
os: | |
- ubuntu-latest | |
- windows-latest | |
runs-on: ${{ matrix.os }} | |
env: | |
# Disable full debug symbol generation to speed up CI build and keep memory down | |
RUSTFLAGS: -C debuginfo=line-tables-only | |
# Disable incremental builds by cargo for CI which should save disk space | |
# and hopefully avoid final link "No space left on device" | |
CARGO_INCREMENTAL: 0 | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install minimal stable with clippy and rustfmt | |
uses: actions-rs/toolchain@v1 | |
with: | |
profile: default | |
toolchain: '1.81' | |
override: true | |
- name: Run tests | |
run: cargo test --verbose --features ${{ env.DEFAULT_FEATURES }} | |
integration_test: | |
name: Integration Tests | |
runs-on: ubuntu-latest | |
env: | |
CARGO_INCREMENTAL: 0 | |
# Disable full debug symbol generation to speed up CI build and keep memory down | |
# <https://doc.rust-lang.org/cargo/reference/profiles.html> | |
RUSTFLAGS: "-C debuginfo=line-tables-only" | |
# https://github.com/rust-lang/cargo/issues/10280 | |
CARGO_NET_GIT_FETCH_WITH_CLI: "true" | |
RUST_BACKTRACE: "1" | |
RUST_LOG: debug | |
AWS_DEFAULT_REGION: "us-east-1" | |
AWS_ACCESS_KEY_ID: deltalake | |
AWS_SECRET_ACCESS_KEY: weloverust | |
AWS_ENDPOINT_URL: http://localhost:4566 | |
AWS_ALLOW_HTTP: "1" | |
AZURE_USE_EMULATOR: "1" | |
AZURE_STORAGE_ALLOW_HTTP: "1" | |
AZURITE_BLOB_STORAGE_URL: "http://localhost:10000" | |
AZURE_STORAGE_CONNECTION_STRING: "DefaultEndpointsProtocol=http;AccountName=devstoreaccount1;AccountKey=Eby8vdM02xNOcqFlqUwJPLlmEtlCDXJ1OUzFT50uSRZ6IFsuFq2UVErCz4I6tq/K1SZFPTOtr/KBHBeksoGMGw==;BlobEndpoint=http://localhost:10000/devstoreaccount1;QueueEndpoint=http://localhost:10001/devstoreaccount1;" | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install minimal stable with clippy and rustfmt | |
uses: actions-rs/toolchain@v1 | |
with: | |
profile: default | |
toolchain: '1.81' | |
override: true | |
# Install Java and Hadoop for HDFS integration tests | |
- uses: actions/setup-java@v4 | |
with: | |
distribution: "temurin" | |
java-version: "17" | |
- name: Download Hadoop | |
run: | | |
wget -q https://dlcdn.apache.org/hadoop/common/hadoop-3.4.0/hadoop-3.4.0.tar.gz | |
tar -xf hadoop-3.4.0.tar.gz -C $GITHUB_WORKSPACE | |
echo "$GITHUB_WORKSPACE/hadoop-3.4.0/bin" >> $GITHUB_PATH | |
- name: Start emulated services | |
run: docker compose up -d | |
- name: Run tests with rustls (default) | |
run: | | |
cargo test --features integration_test,${{ env.DEFAULT_FEATURES }} | |
- name: Run tests with native-tls | |
run: | | |
cargo test --no-default-features --features integration_test,s3-native-tls,datafusion | |
integration_test_lakefs: | |
name: Integration Tests (LakeFS v1.48) | |
runs-on: ubuntu-latest | |
env: | |
CARGO_INCREMENTAL: 0 | |
# Disable full debug symbol generation to speed up CI build and keep memory down | |
# <https://doc.rust-lang.org/cargo/reference/profiles.html> | |
RUSTFLAGS: "-C debuginfo=line-tables-only" | |
# https://github.com/rust-lang/cargo/issues/10280 | |
CARGO_NET_GIT_FETCH_WITH_CLI: "true" | |
RUST_BACKTRACE: "1" | |
RUST_LOG: debug | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install minimal stable with clippy and rustfmt | |
uses: actions-rs/toolchain@v1 | |
with: | |
profile: default | |
toolchain: '1.81' | |
override: true | |
- name: Download Lakectl | |
run: | | |
wget -q https://github.com/treeverse/lakeFS/releases/download/v1.48.1/lakeFS_1.48.1_Linux_x86_64.tar.gz | |
tar -xf lakeFS_1.48.1_Linux_x86_64.tar.gz -C $GITHUB_WORKSPACE | |
echo "$GITHUB_WORKSPACE" >> $GITHUB_PATH | |
- name: Start emulated services | |
run: docker compose -f docker-compose-lakefs.yml up -d | |
- name: Run tests with rustls (default) | |
run: | | |
cargo test --features integration_test_lakefs,lakefs,datafusion | |