Skip to content

Commit

Permalink
Simplify some CI checks (#699)
Browse files Browse the repository at this point in the history
- Closes #697 

I ended up touching the wasm and python workflows as well, mostly to
make whitespace consistent and to remove the `--all` flags from the
`cargo` commands (only used for workspaces, and its deprecated).
  • Loading branch information
gadomski authored Aug 13, 2024
1 parent 6b410dc commit 05b3c9e
Show file tree
Hide file tree
Showing 3 changed files with 54 additions and 118 deletions.
97 changes: 38 additions & 59 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,53 +11,38 @@ concurrency:
cancel-in-progress: true

jobs:
lint-test:
lint-test-all-features:
name: Lint and Test
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
submodules: "recursive"

- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt, clippy

- uses: Swatinem/rust-cache@v2

- name: Install Pixi
- uses: prefix-dev/[email protected]
with:
activate-environment: true
cache: true
cache-write: ${{ github.event_name == 'push' && github.ref_name == 'main' }}
manifest-path: build/pixi.toml
- name: Tweak environment to find GDAL
run: |
curl -fsSL https://pixi.sh/install.sh | bash
echo "$HOME/.pixi/bin" >> $GITHUB_PATH
echo "GDAL_HOME=$(pwd)/build/.pixi/envs/default" >> "$GITHUB_ENV"
echo "LD_LIBRARY_PATH=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
echo "GEOS_LIB_DIR=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
# TODO: infer from toml file/lockfile
echo "GEOS_VERSION=3.12.1" >> "$GITHUB_ENV"
echo "PKG_CONFIG_PATH=$(pwd)/build/.pixi/envs/default/lib/pkgconfig" >> "$GITHUB_ENV"
echo "LD_LIBRARY_PATH=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
- name: Fmt
run: cargo fmt -- --check
- name: Clippy
run: cargo clippy --all-features --tests -- -D warnings
- name: Check
run: cargo check --all-features --features gdal/bindgen
- name: Test
run: cargo test --all-features

- name: Install build requirements
run: |
cd build
pixi install
- name: Cargo fmt
run: cargo fmt --all -- --check

- name: "clippy --all"
run: cargo clippy --all --all-features --tests -- -D warnings

- name: "cargo check"
# No idea why the gdal/bindgen feature declared in dev dependencies
# isn't getting picked up.
run: cargo check --all --all-features --features gdal/bindgen

- name: "cargo test"
run: |
cargo test --all
cargo test --all --all-features
build:
check-features:
runs-on: ubuntu-latest
strategy:
fail-fast: false
Expand All @@ -83,7 +68,8 @@ jobs:
- uses: Swatinem/rust-cache@v2
- name: Test
run: cargo check ${{ matrix.args }}
build-with-external-dependencies:

check-features-with-external-dependencies:
runs-on: ubuntu-latest
strategy:
fail-fast: false
Expand All @@ -98,22 +84,19 @@ jobs:
submodules: "recursive"
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- name: Install Pixi
- uses: prefix-dev/[email protected]
with:
activate-environment: true
cache: true
cache-write: ${{ github.event_name == 'push' && github.ref_name == 'main' }}
manifest-path: build/pixi.toml
- name: Tweak environment to find GDAL
run: |
curl -fsSL https://pixi.sh/install.sh | bash
echo "$HOME/.pixi/bin" >> $GITHUB_PATH
echo "GDAL_HOME=$(pwd)/build/.pixi/envs/default" >> "$GITHUB_ENV"
echo "LD_LIBRARY_PATH=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
echo "GEOS_LIB_DIR=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
# TODO: infer from toml file/lockfile
echo "GEOS_VERSION=3.12.1" >> "$GITHUB_ENV"
echo "PKG_CONFIG_PATH=$(pwd)/build/.pixi/envs/default/lib/pkgconfig" >> "$GITHUB_ENV"
- name: Install build requirements
run: |
cd build
pixi install
echo "LD_LIBRARY_PATH=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
- name: Test
run: cargo build ${{ matrix.args }}
run: cargo check ${{ matrix.args }}

build-benchmarks:
runs-on: ubuntu-latest
steps:
Expand All @@ -122,20 +105,16 @@ jobs:
submodules: "recursive"
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- name: Install Pixi
- uses: prefix-dev/[email protected]
with:
activate-environment: true
cache: true
cache-write: ${{ github.event_name == 'push' && github.ref_name == 'main' }}
manifest-path: build/pixi.toml
- name: Tweak environment to find GDAL
run: |
curl -fsSL https://pixi.sh/install.sh | bash
echo "$HOME/.pixi/bin" >> $GITHUB_PATH
echo "GDAL_HOME=$(pwd)/build/.pixi/envs/default" >> "$GITHUB_ENV"
echo "LD_LIBRARY_PATH=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
echo "GEOS_LIB_DIR=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
# TODO: infer from toml file/lockfile
echo "GEOS_VERSION=3.12.1" >> "$GITHUB_ENV"
echo "PKG_CONFIG_PATH=$(pwd)/build/.pixi/envs/default/lib/pkgconfig" >> "$GITHUB_ENV"
- name: Install build requirements
run: |
cd build
pixi install
echo "LD_LIBRARY_PATH=$(pwd)/build/.pixi/envs/default/lib" >> "$GITHUB_ENV"
- name: Build benchmarks with no features
run: cargo bench --no-run
- name: Build benchmarks with all features
Expand Down
40 changes: 8 additions & 32 deletions .github/workflows/python.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,37 +17,23 @@ jobs:
defaults:
run:
working-directory: python/core

steps:
- uses: actions/checkout@v4
with:
submodules: "recursive"

- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt, clippy

- uses: Swatinem/rust-cache@v2

- name: Cargo fmt
run: cargo fmt --all -- --check

# # Note not sure why this is needed
# - name: Install protobuf
# run: |
# sudo apt-get install libprotobuf-dev protobuf-compiler

# Don't use --all-features as we don't have GDAL 3.6 available in CI
- name: "clippy --all"
run: cargo clippy --all --tests -- -D warnings

- name: "cargo check"
run: cargo check --all

- name: "cargo test"
run: |
cargo test --all
- name: Fmt
run: cargo fmt -- --check
- name: Clippy
run: cargo clippy --tests -- -D warnings
- name: Check
run: cargo check
- name: Test
run: cargo test

# lint-python:
# name: Lint Python code
Expand Down Expand Up @@ -75,49 +61,39 @@ jobs:
defaults:
run:
working-directory: python/core

steps:
- uses: actions/checkout@v4
with:
submodules: "recursive"

- name: Install Rust
uses: dtolnay/rust-toolchain@stable

- uses: Swatinem/rust-cache@v2

- name: Set up Python
id: setup-python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}

- name: Install and configure Poetry
uses: snok/install-poetry@v1
with:
version: 1.8.2
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true

- name: Check Poetry lockfile up to date
run: |
poetry check --lock
- name: Load cached venv
id: cached-poetry-dependencies
uses: actions/cache@v4
with:
path: python/core/.venv
key: venv-${{ runner.os }}-${{ steps.setup-python.outputs.python-version }}-${{ hashFiles('**/poetry.lock') }}

- name: Install dependencies
if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true'
run: poetry install --no-interaction --no-root

- name: Install root project
run: poetry install --no-interaction

- name: Run python tests
run: |
poetry run maturin develop
Expand Down
35 changes: 8 additions & 27 deletions .github/workflows/wasm.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,62 +17,43 @@ jobs:
defaults:
run:
working-directory: js

steps:
- uses: actions/checkout@v4

- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt, clippy

- uses: Swatinem/rust-cache@v2

- name: Cargo fmt
run: cargo fmt --all -- --check

- name: "clippy --all"
run: cargo clippy --all --all-features --tests -- -D warnings

- name: "cargo check"
run: |
cargo check --all
cargo check --all --all-features
- name: "cargo test"
run: |
cargo test --all
cargo test --all --all-features
- name: Fmt
run: cargo fmt -- --check
- name: Clippy
run: cargo clippy --all-features --tests -- -D warnings
- name: Check
run: cargo check --all-features
- name: Test
run: cargo test --all-features

node-test:
name: Node Tests
runs-on: ubuntu-latest
defaults:
run:
working-directory: js

steps:
- uses: actions/checkout@v4

- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt, clippy

- name: Install wasm-pack
run: curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh

- uses: Swatinem/rust-cache@v2

- uses: actions/setup-node@v2
with:
node-version: "20"

- name: Build bundle
run: yarn build:test

- name: Install dev dependencies
run: yarn install

- name: Run Node tests
run: yarn test

0 comments on commit 05b3c9e

Please sign in to comment.