Skip to content

fix: get_num_geometries failing on empty geom #181

fix: get_num_geometries failing on empty geom

fix: get_num_geometries failing on empty geom #181

Workflow file for this run

name: CI
on:
push:
branches: [master]
pull_request:
workflow_dispatch:
# cancel running jobs on new commit to PR
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}
jobs:
rustfmt:
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: 1.70.0
override: true
components: rustfmt
- run: cargo fmt -- --check
- run: cd sys && cargo fmt -- --check
clippy:
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: nightly
override: true
components: clippy
- name: Install dependencies
run: |
sudo apt update
sudo apt install -y libgeos-dev
- run: cargo clippy -- -D warnings
- run: cd sys && cargo clippy -- -D warnings
check_static:
name: Check static feature
runs-on: ubuntu-20.04
env:
LD_LIBRARY_PATH: /usr/local/lib
steps:
- uses: actions/checkout@v2
with:
submodules: "true"
- name: Install toolchain
uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: 1.70.0
override: true
- name: Build static geos crate
run: cargo build --features static
check:
name: Check ${{ matrix.toolchain }} / ${{ matrix.geos }} - ${{ matrix.triple.target }}
runs-on: ubuntu-20.04
env:
LD_LIBRARY_PATH: /usr/local/lib
GEOS_LIB_DIR: "/usr/lib/x86_64-linux-gnu"
GEOS_VERSION: ${{ matrix.geos }}
strategy:
fail-fast: false
matrix:
toolchain:
- 1.70.0
- nightly
geos: ["3.6.5", "3.7.5", "3.8.3", "3.9.3", "3.10.3", "3.11.0"]
include:
- geos: "3.7.5"
version_feature: "v3_7_0"
- geos: "3.8.3"
version_feature: "v3_8_0"
- geos: "3.9.3"
version_feature: "v3_9_0"
- geos: "3.10.3"
version_feature: "v3_10_0"
- geos: "3.11.0"
version_feature: "v3_11_0"
steps:
- uses: actions/checkout@v2
with:
submodules: "true"
- name: Install toolchain
uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: ${{ matrix.toolchain }}
override: true
- name: Install dependencies
run: |
sudo apt update
sudo apt install build-essential ccache ninja-build pkg-config valgrind
sudo /usr/sbin/update-ccache-symlinks
- name: Prepare ccache
run: ccache --clear --set-config cache_dir=~/.ccache
- name: Cache ccache
uses: actions/cache@v2
env:
cache-name: ccache-v1
with:
path: ~/.ccache
key: ${{ env.cache-name }}-${{ matrix.os }}-${{ github.job }}-${{ github.ref }}-${{ github.sha }}-${{ github.head_ref }}
restore-keys: |
${{ env.cache-name }}-${{ matrix.os }}-${{ github.job }}-${{ github.ref }}-${{ github.sha }}
${{ env.cache-name }}-${{ matrix.os }}-${{ github.job }}-${{ github.ref }}
${{ env.cache-name }}-${{ matrix.os }}-${{ github.job }}
- name: Clear ccache statistics
run: |
ccache --zero-stats --set-config cache_dir=~/.ccache
ccache --max-size=2G --set-config cache_dir=~/.ccache
ccache --show-stats --set-config cache_dir=~/.ccache
- name: Install GEOS
run: |
cd sys/geos-src/source
git fetch --unshallow --tags origin
git checkout "tags/${{ matrix.geos }}"
mkdir build
cd build
cmake -G Ninja -DCMAKE_CXX_COMPILER_LAUNCHER=ccache -DCMAKE_C_COMPILER_LAUNCHER=ccache -DCMAKE_BUILD_TYPE=Release ..
sudo ninja install
- name: Build geos crate
run: |
cargo build
cargo build --features 'geo,json'
- name: Build geos crate for GEOS version > 3.6
if: ${{ matrix.version_feature }}
run: |
cargo build --features ${{ matrix.version_feature }}
cargo build --features '${{ matrix.version_feature }},geo,json'
- name: Run geos tests
run: |
cargo test
cargo test --features 'geo,json'
- name: Run geos tests for GEOS version > 3.6
if: ${{ matrix.version_feature }}
run: |
cargo test --features ${{ matrix.version_feature }}
cargo test --features '${{ matrix.version_feature }},geo,json'
- name: Check doc generation
run: |
cargo doc --features dox
cargo doc
- name: Run examples
run: |
cargo run --example verbose_example
cargo run --example prepared_geom
cargo run --features geo --example prepared_geom
cargo run --example from_geo
cargo run --features geo --example from_geo
- name: Check memory leaks
# run valgrind to check that there are no memoryleaks
# Note: cargo seems to randomly name the executable, so we use find to find all the tests
#
# As long as leaks come from "geos::geom::GeometryFactory::getDefaultInstance", then
# it's fine (singleton).
run: |
find ./target/debug/deps -name "geos*" -type f -executable | xargs -n 1 valgrind --leak-check=full --error-exitcode=42 --show-leak-kinds=all
valgrind --leak-check=full --error-exitcode=42 ./target/debug/examples/from_geo
valgrind --leak-check=full --error-exitcode=42 ./target/debug/examples/verbose_example
valgrind --leak-check=full --error-exitcode=42 ./target/debug/examples/prepared_geom