Skip to content

Continuous Integration #844

Continuous Integration

Continuous Integration #844

Workflow file for this run

name: Continuous Integration
on:
push:
branches:
- '*'
pull_request:
branches:
- '*'
schedule:
- cron: '59 23 * * *'
workflow_dispatch:
inputs:
version:
description: Manual Unittest Run
default: test
required: false
jobs:
unittests:
env:
RUN_TEST: pytest giddy --cov giddy -v -n auto -r a --cov-config .coveragerc --cov-report xml --color yes --cov-append --cov-report term-missing
name: ${{ matrix.os }}, ${{ matrix.environment-file }}
runs-on: ${{ matrix.os }}
timeout-minutes: 60
strategy:
matrix:
os: [ubuntu-latest]
environment-file:
- ci/37.yaml
- ci/38.yaml
- ci/39.yaml
- ci/310.yaml
- ci/310-DEV.yaml
- ci/310-DEV_shapely_dev.yaml
include:
- environment-file: ci/310.yaml
os: macos-latest
- environment-file: ci/310.yaml
os: windows-latest
fail-fast: false
steps:
- name: checkout repo
uses: actions/checkout@v3
- name: setup micromamba
uses: mamba-org/provision-with-micromamba@main
with:
environment-file: ${{ matrix.environment-file }}
micromamba-version: 'latest'
channel-priority: 'flexible'
- name: install bleeding edge libpysal, esda, mapclassify & splot (Ubuntu / Python 3.10)
shell: bash -l {0}
run: |
pip install git+https://github.com/pysal/libpysal.git@main
pip install git+https://github.com/pysal/esda.git@main
pip install git+https://github.com/pysal/mapclassify.git@main
pip install git+https://github.com/pysal/splot.git@main
if: matrix.os == 'ubuntu-latest' && contains(matrix.environment-file, 'DEV')
- name: environment info
shell: bash -l {0}
run: |
micromamba info
micromamba list
- name: spatial versions (if geopandas is installed)
shell: bash -l {0}
run: 'python -c "import geopandas; geopandas.show_versions();"'
if: contains(matrix.environment-file, 'DEV')
- name: run tests - bash
shell: bash -l {0}
run: ${{ env.RUN_TEST }}
if: matrix.os != 'windows-latest'
- name: run tests - powershell
shell: powershell
run: ${{ env.RUN_TEST }}
if: matrix.os == 'windows-latest'
- name: codecov
uses: codecov/codecov-action@v3
with:
token: ${{ secrets.CODECOV_TOKEN }}
file: ./coverage.xml
name: giddy-codecov