Skip to content

Commit

Permalink
Add pytests githubaction (#254)
Browse files Browse the repository at this point in the history
* Add tests workflow

* Add fake test
  • Loading branch information
amandine-sahl authored Oct 10, 2023
1 parent 0c67a59 commit 125fd6e
Show file tree
Hide file tree
Showing 4 changed files with 131 additions and 0 deletions.
120 changes: 120 additions & 0 deletions .github/workflows/pytest.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
name: pytest

on:
push:
branches:
- master
- hotfixes
- develop
- workshop
pull_request:
branches:
- master
- hotfixes
- develop
- workshop

jobs:
build:

runs-on: ubuntu-latest

strategy:
fail-fast: false
matrix:
include:
- name: "Debian 10"
python-version: "3.7"
postgres-version: 11
postgis-version: 2.5
- name: "Debian 11"
python-version: "3.9"
postgres-version: 13
postgis-version: 3.2

name: ${{ matrix.name }}

services:
postgres:
image: postgis/postgis:${{ matrix.postgres-version }}-${{ matrix.postgis-version }}
env:
POSTGRES_DB: geonature2db
POSTGRES_PASSWORD: geonatpasswd
POSTGRES_USER: geonatadmin
ports:
- 5432:5432
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
redis:
image: redis
ports:
- 6379:6379
options: >-
--health-cmd "redis-cli ping"
--health-interval 10s
--health-timeout 5s
--health-retries 5
steps:
- name: Add postgis_raster database extension
if: ${{ matrix.postgis-version >= 3 }}
run: |
psql -h localhost -U geonatadmin -d geonature2db -tc 'CREATE EXTENSION "postgis_raster";'
env:
PGPASSWORD: geonatpasswd
- name: Add database extensions
run: |
psql -h localhost -U geonatadmin -d geonature2db -tc 'CREATE EXTENSION "hstore";'
psql -h localhost -U geonatadmin -d geonature2db -tc 'CREATE EXTENSION "uuid-ossp";'
psql -h localhost -U geonatadmin -d geonature2db -tc 'CREATE EXTENSION "pg_trgm";'
psql -h localhost -U geonatadmin -d geonature2db -tc 'CREATE EXTENSION "unaccent";'
env:
PGPASSWORD: geonatpasswd
- uses: actions/checkout@v2
with:
submodules: recursive
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v2
with:
python-version: ${{ matrix.python-version }}
- name: Install GDAL
run: |
sudo apt update
sudo apt install -y libgdal-dev
- name: Install dependencies
run: |
python -m pip install --upgrade pip
python -m pip install \
-e ..[tests] \
-r requirements-dev.txt
working-directory: ./dependencies/GeoNature/backend
- name: Install database
run: |
geonature db upgrade geonature@head -x local-srid=2154
geonature db autoupgrade -x local-srid=2154
geonature taxref import-v15 --skip-bdc-statuts
geonature db upgrade geonature-samples@head
geonature db upgrade nomenclatures_taxonomie_data@head
geonature db upgrade ref_geo_fr_departments@head
geonature db upgrade ref_geo_fr_municipalities@head
geonature db upgrade ref_geo_inpn_grids_10@head
env:
GEONATURE_CONFIG_FILE: dependencies/GeoNature/config/test_config.toml
- name: Install import module database
run: |
geonature upgrade-modules-db MONITORINGS
env:
GEONATURE_CONFIG_FILE: dependencies/GeoNature/config/test_config.toml
- name: Test with pytest
run: |
pytest -v --cov --cov-report xml
env:
GEONATURE_CONFIG_FILE: dependencies/GeoNature/config/test_config.toml
- name: Upload coverage to Codecov
if: ${{ matrix.name == 'Debian 11' }}
uses: codecov/codecov-action@v2
with:
flags: pytest
4 changes: 4 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
[submodule "dependencies/GeoNature"]
path = dependencies/GeoNature
url = [email protected]:PnX-SI/GeoNature.git
branch = develop
6 changes: 6 additions & 0 deletions backend/gn_module_monitoring/tests/test_true.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import pytest


class Tests:
def test_true_is_true(self):
assert True == True
1 change: 1 addition & 0 deletions dependencies/GeoNature
Submodule GeoNature added at 7ee68c

0 comments on commit 125fd6e

Please sign in to comment.