From 9305f60d24f742d0a1c044f3d6cd6feab0a377d3 Mon Sep 17 00:00:00 2001 From: Matthew Feickert Date: Wed, 21 Sep 2022 16:49:12 -0500 Subject: [PATCH 1/4] test: Move pytest options into pyproject.toml --- pyproject.toml | 16 ++++++++++++++++ setup.cfg | 4 ---- 2 files changed, 16 insertions(+), 4 deletions(-) create mode 100644 pyproject.toml diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 00000000..456e710a --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,16 @@ +[tool.pytest.ini_options] +minversion = "6.0" +xfail_strict = true +addopts = [ + "-ra", + "--cov=hepdata_lib", + "--cov-branch", + "--showlocals", + "--strict-markers", + "--strict-config", + "--cov-report=term-missing", + "--cov-report=xml", + "--cov-report=html", +] +log_cli_level = "info" +testpaths = "tests" diff --git a/setup.cfg b/setup.cfg index 27cc3bcc..fa47581f 100644 --- a/setup.cfg +++ b/setup.cfg @@ -7,7 +7,3 @@ universal=1 [aliases] test=pytest - -[tool:pytest] -addopts = --cov=hepdata_lib - From 4542683c7dbc7d4979aa2ffd9bfeae023d9edfb1 Mon Sep 17 00:00:00 2001 From: Matthew Feickert Date: Wed, 21 Sep 2022 16:50:22 -0500 Subject: [PATCH 2/4] ci: Update CI to use modern actions and Python commands * Add workflow dispatch option to run on demand. * Test against Python 3.8 which is the version of Python the ROOT binary was compiled against given the output of `root-config --python-version`. * Update all GitHub Actions. * Avoid deprecated direct calls to `python setup.py` and use local pip installs. * Use 'python -m pytest' to add current working directory to sys.path as src/ dir layout not used. - c.f. https://docs.pytest.org/en/7.1.x/explanation/pythonpath.html * Run on push events only if to master to let coverage from PRs report properly. * Use Codecov for reporting coverage. - Update badge in README to use Codecov - Add Codecov config file --- .github/workflows/tests.yml | 152 ++++++++++++++++++++++-------------- README.md | 2 +- codecov.yml | 5 ++ 3 files changed, 99 insertions(+), 60 deletions(-) create mode 100644 codecov.yml diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 58585eee..459a968e 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -1,71 +1,105 @@ name: tests #Running tests on all branches -on: [push,pull_request] +on: + push: + pull_request: + branches: + - master + workflow_dispatch: jobs: # This is a job for linux python3 tests linuxpy3: - runs-on: [ubuntu-20.04] - steps: - - uses: actions/checkout@v2 - # Install dependencies - - name: Install python dependencies - run: | - curl https://bootstrap.pypa.io/get-pip.py > get-pip.py - python3 get-pip.py - python3 -m pip install pylint==2.9.6 pytest_pylint configparser astroid pyyml papermill nbconvert jupyter pytest pytest-cov - - name: Fixup ImageMagick - run: | - sudo sed -i '/.*PDF.*/ s/none/read | write/g' /etc/ImageMagick*/policy.xml - ls /etc/ImageMagick*/policy.xml - cat /etc/ImageMagick*/policy.xml - sudo apt update - sudo apt install ghostscript - echo "---GS---" - which gs - echo "--------" - - name: Install ROOT - run: | - wget -q https://root.cern/download/root_v6.24.00.Linux-ubuntu20-x86_64-gcc9.3.tar.gz - tar xf *tar.gz - source root/bin/thisroot.sh - # Run pytest - - name: Run pytest - run: | - source root/bin/thisroot.sh - python3 -m pip install -e . - python3 setup.py test - - # Save notebooks - - name: Save notebooks - if: ${{ always() }} - run: | - python3 -m jupyter kernelspec list - python3 -m jupyter nbconvert --ExecutePreprocessor.timeout=600 --ExecutePreprocessor.allow_errors=True --to html --execute examples/*.ipynb - - # Upload notebooks - - name: Upload notebooks - if: ${{ always() }} - uses: actions/upload-artifact@v2 - with: - name: notebooks py3 - path: examples/*.html + # Setup the Python that the ROOT binary was built against + runs-on: ${{ matrix.os }} + # On push events run the CI only on master by default, but run on any branch if the commit message contains '[ci all]' + if: >- + github.event_name != 'push' + || (github.event_name == 'push' && github.ref == 'refs/heads/master') + || (github.event_name == 'push' && github.ref != 'refs/heads/master' && contains(github.event.head_commit.message, '[ci all]')) + strategy: + matrix: + os: [ubuntu-latest] + python-version: ["3.8"] + + steps: + - uses: actions/checkout@v3 + + - name: Set up Python + uses: actions/setup-python@v4 + with: + python-version: ${{ matrix.python-version }} + + # Install dependencies + - name: Install python dependencies + run: | + python -m pip install --upgrade pip setuptools wheel + python -m pip install --upgrade \ + 'pylint==2.9.6' \ + pytest_pylint \ + configparser \ + astroid \ + pyyml \ + papermill \ + nbconvert \ + jupyter \ + pytest \ + pytest-cov + + - name: Install hepdata_lib + run: python -m pip install .[test] + + - name: Fixup ImageMagick + run: | + sudo sed -i '/.*PDF.*/ s/none/read | write/g' /etc/ImageMagick*/policy.xml + ls /etc/ImageMagick*/policy.xml + cat /etc/ImageMagick*/policy.xml + sudo apt update + sudo apt install ghostscript + echo "---GS---" + which gs + echo "--------" + + - name: Install ROOT + run: | + wget -q https://root.cern/download/root_v6.24.00.Linux-ubuntu20-x86_64-gcc9.3.tar.gz + tar xf *tar.gz + source root/bin/thisroot.sh + root-config --python-version + + # Use python -m pytest to add current working dir as src/ dir layout not used + - name: Run pytest + run: | + source root/bin/thisroot.sh + python -m pytest tests + + - name: Report contrib coverage with Codecov + uses: codecov/codecov-action@v3 + with: + files: ./coverage.xml + flags: unittests-${{ matrix.python-version }} + + - name: Save notebooks + if: ${{ always() }} + run: | + python -m jupyter kernelspec list + python -m jupyter nbconvert --ExecutePreprocessor.timeout=600 --ExecutePreprocessor.allow_errors=True --to html --execute examples/*.ipynb + + - name: Upload notebooks + if: ${{ always() }} + uses: actions/upload-artifact@v3 + with: + name: notebooks py3 + path: examples/*.html + + - name: Run pylint + if: ${{ always() }} + run: | + python -m pylint hepdata_lib/*.py + python -m pylint tests/*.py --rcfile=tests/pylintrc - # Run pylint - - name: Run pylint - if: ${{ always() }} - run: | - python3 -m pip install -e . - python3 -m pylint hepdata_lib/*.py - python3 -m pylint tests/*.py --rcfile=tests/pylintrc - - name: Upload coverage data to coveralls.io - run: | - python -m pip install coveralls==2.2 - coveralls --service=github - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # This is a job for macOS python3 tests # macospy3: # runs-on: macos-latest diff --git a/README.md b/README.md index 45c19954..04be1da6 100644 --- a/README.md +++ b/README.md @@ -3,7 +3,7 @@ [![DOI](https://zenodo.org/badge/129248575.svg)](https://zenodo.org/badge/latestdoi/129248575) [![PyPI version](https://badge.fury.io/py/hepdata-lib.svg)](https://badge.fury.io/py/hepdata-lib) [![Actions Status](https://github.com/HEPData/hepdata_lib/workflows/tests/badge.svg)](https://github.com/HEPData/hepdata_lib/actions) -[![Coverage Status](https://coveralls.io/repos/github/HEPData/hepdata_lib/badge.svg?branch=master)](https://coveralls.io/github/HEPData/hepdata_lib?branch=master) +[![Coverage Status](https://codecov.io/gh/HEPData/hepdata_lib/graph/badge.svg?branch=master)](https://codecov.io/gh/HEPData/hepdata_lib?branch=master) [![Documentation Status](https://readthedocs.org/projects/hepdata-lib/badge/)](http://hepdata-lib.readthedocs.io/) [![Docker image](https://github.com/HEPData/hepdata_lib/actions/workflows/docker.yml/badge.svg)](https://github.com/HEPData/hepdata_lib/pkgs/container/hepdata_lib) diff --git a/codecov.yml b/codecov.yml new file mode 100644 index 00000000..914f8609 --- /dev/null +++ b/codecov.yml @@ -0,0 +1,5 @@ +coverage: + status: + project: + default: + threshold: 0.2% From 04faf9d9e1b012427892b3de519d976ca504b9d6 Mon Sep 17 00:00:00 2001 From: Matthew Feickert Date: Thu, 22 Sep 2022 14:49:56 -0500 Subject: [PATCH 3/4] build: Remove test=pytest alias as invoking setup.py directly is deprecate --- setup.cfg | 3 --- 1 file changed, 3 deletions(-) diff --git a/setup.cfg b/setup.cfg index fa47581f..9886c7c6 100644 --- a/setup.cfg +++ b/setup.cfg @@ -4,6 +4,3 @@ # need to generate separate wheels for each Python version that you # support. universal=1 - -[aliases] -test=pytest From c7261c0f9d0d8077414ef5e8dea49fec0e5e4ebc Mon Sep 17 00:00:00 2001 From: Matthew Feickert Date: Fri, 23 Sep 2022 23:38:53 -0500 Subject: [PATCH 4/4] fixup: Remove 'contrib' typo from copy-and-paste --- .github/workflows/tests.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 459a968e..7def92da 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -75,7 +75,7 @@ jobs: source root/bin/thisroot.sh python -m pytest tests - - name: Report contrib coverage with Codecov + - name: Report coverage with Codecov uses: codecov/codecov-action@v3 with: files: ./coverage.xml