python.yml 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. # sync with https://github.com/fphammerle/ical2vdir/blob/master/.github/workflows/python.yml
  2. # https://help.github.com/en/actions/reference/workflow-syntax-for-github-actions
  3. # shown in badge
  4. # https://help.github.com/en/actions/automating-your-workflow-with-github-actions/configuring-a-workflow#adding-a-workflow-status-badge-to-your-repository
  5. name: tests
  6. on:
  7. push:
  8. pull_request:
  9. schedule:
  10. - cron: '0 20 * * 5'
  11. jobs:
  12. tests:
  13. runs-on: ubuntu-18.04
  14. strategy:
  15. matrix:
  16. python-version:
  17. - 3.5
  18. - 3.6
  19. - 3.7
  20. - 3.8
  21. pandas-version:
  22. - '' # locked version
  23. - 0.21.*
  24. - 0.22.*
  25. - 0.23.*
  26. - 0.24.*
  27. - 0.25.*
  28. - 1.1.*
  29. exclude:
  30. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/683777317#L208
  31. # https://github.com/pandas-dev/pandas/commit/18efcb27361478daa3118079ecb166c733691ecb#diff-2eeaed663bd0d25b7e608891384b7298R814
  32. - python-version: 3.5
  33. pandas-version: 1.1.*
  34. - python-version: 3.7
  35. pandas-version: 0.21.*
  36. - python-version: 3.7
  37. pandas-version: 0.22.*
  38. # > /tmp/pip-install-g4jx0np4/numpy/_configtest.c:6: undefined reference to `exp'
  39. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/683704331#L437
  40. - python-version: 3.8
  41. pandas-version: 0.21.*
  42. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/683704330#L437
  43. - python-version: 3.8
  44. pandas-version: 0.22.*
  45. # no python-version3.8 wheels for pandas v0.24.2 & v0.23.4 available
  46. # https://travis-ci.org/github/fphammerle/freesurfer-stats/builds/701952350
  47. # build takes longer than 10min
  48. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/702077404#L199
  49. - python-version: 3.8
  50. pandas-version: 0.23.*
  51. - python-version: 3.8
  52. pandas-version: 0.24.*
  53. fail-fast: false
  54. steps:
  55. - uses: actions/checkout@v1
  56. - uses: actions/setup-python@v1
  57. with:
  58. python-version: ${{ matrix.python-version }}
  59. - run: pip install --upgrade pipenv==2020.8.13
  60. - run: pipenv install --python "$PYTHON_VERSION" --deploy --dev
  61. env:
  62. PYTHON_VERSION: ${{ matrix.python-version }}
  63. # `pipenv install --selective-upgrade "pandas==$PANDAS_VERSION"` was not effective
  64. - run: '[ -z "$PANDAS_VERSION" ] || pipenv run pip install "pandas==$PANDAS_VERSION"'
  65. env:
  66. PANDAS_VERSION: ${{ matrix.pandas-version }}
  67. - run: pipenv graph
  68. - run: pipenv run pytest --cov="$(cat *.egg-info/top_level.txt)" --cov-report=term-missing --cov-fail-under=100
  69. - run: pipenv run pylint --load-plugins=pylint_import_requirements "$(cat *.egg-info/top_level.txt)"
  70. # https://github.com/PyCQA/pylint/issues/352
  71. # disable parse-error due to:
  72. # > tests/resources/__init__.py:1:0: F0010: error while code parsing: Unable to load file tests/resources/__init__.py:
  73. # > [Errno 2] No such file or directory: 'tests/resources/__init__.py' (parse-error)
  74. - run: pipenv run pylint --disable=parse-error tests/*
  75. # >=1.9.0 to detect branch name
  76. # https://github.com/coveralls-clients/coveralls-python/pull/207
  77. # https://github.com/coverallsapp/github-action/issues/4#issuecomment-547036866
  78. # 1.11.0 https://github.com/coveralls-clients/coveralls-python/issues/219
  79. - run: pip install 'coveralls>=1.9.0,<2,!=1.11.0'
  80. # https://github.com/coverallsapp/github-action/issues/30
  81. # https://github.com/coverallsapp/github-action/issues/4#issuecomment-529399410
  82. - run: coveralls
  83. env:
  84. COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}