python.yml 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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. code-format:
  13. runs-on: ubuntu-18.04
  14. strategy:
  15. matrix:
  16. python-version:
  17. - 3.8
  18. steps:
  19. - uses: actions/checkout@v1
  20. - uses: actions/setup-python@v1
  21. with:
  22. python-version: ${{ matrix.python-version }}
  23. - run: pip install --upgrade pipenv==2020.8.13
  24. - run: pipenv install --python "$PYTHON_VERSION" --deploy --dev
  25. env:
  26. PYTHON_VERSION: ${{ matrix.python-version }}
  27. - run: pipenv graph
  28. - run: pipenv run black --check .
  29. tests:
  30. runs-on: ubuntu-18.04
  31. strategy:
  32. matrix:
  33. python-version:
  34. - 3.5
  35. - 3.6
  36. - 3.7
  37. - 3.8
  38. pandas-version:
  39. - '' # locked version
  40. - 0.21.*
  41. - 0.22.*
  42. - 0.23.*
  43. - 0.24.*
  44. - 0.25.*
  45. - 1.1.* # python3.6
  46. - 1.*
  47. exclude:
  48. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/683777317#L208
  49. # https://github.com/pandas-dev/pandas/commit/18efcb27361478daa3118079ecb166c733691ecb#diff-2eeaed663bd0d25b7e608891384b7298R814
  50. - python-version: 3.5
  51. pandas-version: 1.*
  52. - python-version: 3.5
  53. pandas-version: 1.1.*
  54. # https://github.com/pandas-dev/pandas/commit/83807088329b2a7e6422e0d0ba460870a265d3d2#diff-60f61ab7a8d1910d86d9fda2261620314edcae5894d5aaa236b821c7256badd7R768
  55. - python-version: 3.6
  56. pandas-version: 1.*
  57. - python-version: 3.7
  58. pandas-version: 0.21.*
  59. - python-version: 3.7
  60. pandas-version: 0.22.*
  61. # > astroid.exceptions.AttributeInferenceError: '_constructor_expanddim' not found on <ClassDef.Series l.139 at 0x7f314baa6410>.
  62. # https://github.com/fphammerle/freesurfer-volume-reader/runs/1937182916
  63. - python-version: 3.7
  64. pandas-version: 1.1.*
  65. # >/tmp/pip-install-g4jx0np4/numpy/_configtest.c:6: undefined reference to `exp'
  66. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/683704331#L437
  67. - python-version: 3.8
  68. pandas-version: 0.21.*
  69. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/683704330#L437
  70. - python-version: 3.8
  71. pandas-version: 0.22.*
  72. # no python3.8 wheels for pandas v0.24.2 & v0.23.4 available
  73. # https://travis-ci.org/github/fphammerle/freesurfer-stats/builds/701952350
  74. # build takes longer than 10min
  75. # https://travis-ci.org/github/fphammerle/freesurfer-stats/jobs/702077404#L199
  76. - python-version: 3.8
  77. pandas-version: 0.23.*
  78. - python-version: 3.8
  79. pandas-version: 0.24.*
  80. # > astroid.exceptions.AttributeInferenceError: '_constructor_expanddim' not found on <ClassDef.Series l.139 at 0x7f314baa6410>.
  81. # https://github.com/fphammerle/freesurfer-volume-reader/runs/1937182916
  82. - python-version: 3.8
  83. pandas-version: 1.1.*
  84. fail-fast: false
  85. steps:
  86. - uses: actions/checkout@v1
  87. - uses: actions/setup-python@v1
  88. with:
  89. python-version: ${{ matrix.python-version }}
  90. - run: pip install --upgrade pipenv==2020.8.13
  91. - run: pipenv install --python "$PYTHON_VERSION" --deploy --dev
  92. env:
  93. PYTHON_VERSION: ${{ matrix.python-version }}
  94. # `pipenv install --selective-upgrade "pandas==$PANDAS_VERSION"` was not effective
  95. - run: '[ -z "$PANDAS_VERSION" ] || pipenv run pip install "pandas==$PANDAS_VERSION"'
  96. env:
  97. PANDAS_VERSION: ${{ matrix.pandas-version }}
  98. - run: pipenv graph
  99. - run: pipenv run pytest --cov="$(cat *.egg-info/top_level.txt)" --cov-report=term-missing --cov-fail-under=100
  100. - run: pipenv run pylint --load-plugins=pylint_import_requirements "$(cat *.egg-info/top_level.txt)"
  101. # https://github.com/PyCQA/pylint/issues/352
  102. # disable parse-error due to:
  103. # > tests/resources/__init__.py:1:0: F0010: error while code parsing: Unable to load file tests/resources/__init__.py:
  104. # > [Errno 2] No such file or directory: 'tests/resources/__init__.py' (parse-error)
  105. - run: pipenv run pylint --disable=parse-error tests/*
  106. - run: pipenv run mypy "$(cat *.egg-info/top_level.txt)" tests
  107. # >=1.9.0 to detect branch name
  108. # https://github.com/coveralls-clients/coveralls-python/pull/207
  109. # https://github.com/coverallsapp/github-action/issues/4#issuecomment-547036866
  110. # 1.11.0 https://github.com/coveralls-clients/coveralls-python/issues/219
  111. - run: pip install 'coveralls>=1.9.0,<2,!=1.11.0'
  112. # https://github.com/coverallsapp/github-action/issues/30
  113. # https://github.com/coverallsapp/github-action/issues/4#issuecomment-529399410
  114. - run: coveralls
  115. env:
  116. COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}