ci.yml 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. # badge: https://github.com/borgbackup/borg/workflows/CI/badge.svg?branch=master
  2. name: CI
  3. on:
  4. push:
  5. branches: [ 1.2-maint ]
  6. paths:
  7. - '**.py'
  8. - '**.pyx'
  9. - '**.c'
  10. - '**.h'
  11. - '**.yml'
  12. - '**.cfg'
  13. - '**.ini'
  14. - 'requirements.d/*'
  15. - '!docs/**'
  16. pull_request:
  17. branches: [ 1.2-maint ]
  18. paths:
  19. - '**.py'
  20. - '**.pyx'
  21. - '**.c'
  22. - '**.h'
  23. - '**.yml'
  24. - '**.cfg'
  25. - '**.ini'
  26. - 'requirements.d/*'
  27. - '!docs/**'
  28. jobs:
  29. lint:
  30. runs-on: ubuntu-20.04
  31. timeout-minutes: 10
  32. steps:
  33. - uses: actions/checkout@v3
  34. - name: Set up Python
  35. uses: actions/setup-python@v4
  36. with:
  37. python-version: 3.8
  38. - name: Lint with flake8
  39. run: |
  40. pip install flake8
  41. flake8 src scripts conftest.py
  42. pytest:
  43. needs: lint
  44. strategy:
  45. fail-fast: false
  46. matrix:
  47. include:
  48. - os: ubuntu-20.04
  49. python-version: '3.8'
  50. toxenv: py38-fuse2
  51. - os: ubuntu-20.04
  52. python-version: '3.9'
  53. toxenv: py39-fuse3
  54. - os: ubuntu-20.04
  55. python-version: '3.10'
  56. toxenv: py310-fuse3
  57. - os: ubuntu-20.04
  58. python-version: '3.11'
  59. toxenv: py311-fuse2
  60. - os: ubuntu-22.04
  61. python-version: '3.12-dev'
  62. toxenv: py312-fuse3
  63. - os: macos-12
  64. python-version: '3.8'
  65. toxenv: py38-none # note: no fuse testing, due to #6099, see also #6196.
  66. env:
  67. # Configure pkg-config to use OpenSSL from Homebrew
  68. PKG_CONFIG_PATH: "/usr/local/opt/openssl@1.1/lib/pkgconfig:$PKG_CONFIG_PATH"
  69. TOXENV: ${{ matrix.toxenv }}
  70. runs-on: ${{ matrix.os }}
  71. timeout-minutes: 40
  72. steps:
  73. - uses: actions/checkout@v3
  74. with:
  75. # just fetching 1 commit is not enough for setuptools-scm, so we fetch all
  76. fetch-depth: 0
  77. - name: Set up Python ${{ matrix.python-version }}
  78. uses: actions/setup-python@v4
  79. with:
  80. python-version: ${{ matrix.python-version }}
  81. - name: Cache pip
  82. uses: actions/cache@v3
  83. with:
  84. path: ~/.cache/pip
  85. key: ${{ runner.os }}-pip-${{ hashFiles('requirements.d/development.txt') }}
  86. restore-keys: |
  87. ${{ runner.os }}-pip-
  88. ${{ runner.os }}-
  89. - name: Install Linux packages
  90. if: ${{ runner.os == 'Linux' }}
  91. run: |
  92. sudo apt-get update
  93. sudo apt-get install -y libssl-dev libacl1-dev liblz4-dev libzstd-dev pkg-config build-essential
  94. sudo apt-get install -y libxxhash-dev || true
  95. sudo apt-get install -y libb2-dev || true
  96. sudo apt-get install -y libfuse-dev fuse || true # Required for Python llfuse module
  97. sudo apt-get install -y libfuse3-dev fuse3 || true # Required for Python pyfuse3 module
  98. - name: Install macOS packages
  99. if: ${{ runner.os == 'macOS' }}
  100. run: |
  101. brew install pkg-config || brew upgrade pkg-config
  102. brew install zstd || brew upgrade zstd
  103. brew install lz4 || brew upgrade lz4
  104. brew install openssl@1.1 || brew upgrade openssl@1.1
  105. - name: Install Python requirements
  106. run: |
  107. python -m pip install --upgrade pip setuptools wheel
  108. pip install -r requirements.d/development.txt
  109. - name: Install borgbackup
  110. env:
  111. # we already have that in the global env, but something is broken and overwrites that.
  112. # so, set it here, again.
  113. PKG_CONFIG_PATH: "/usr/local/opt/openssl@1.1/lib/pkgconfig:$PKG_CONFIG_PATH"
  114. run: |
  115. # pip install -e .
  116. python setup.py -v develop
  117. - name: run pytest via tox
  118. env:
  119. # we already have that in the global env, but something is broken and overwrites that.
  120. # so, set it here, again.
  121. PKG_CONFIG_PATH: "/usr/local/opt/openssl@1.1/lib/pkgconfig:$PKG_CONFIG_PATH"
  122. run: |
  123. # do not use fakeroot, but run as root. avoids the dreaded EISDIR sporadic failures. see #2482.
  124. #sudo -E bash -c "tox -e py"
  125. tox --skip-missing-interpreters
  126. - name: Upload coverage to Codecov
  127. uses: codecov/codecov-action@v1
  128. env:
  129. OS: ${{ runner.os }}
  130. python: ${{ matrix.python-version }}
  131. with:
  132. token: ${{ secrets.CODECOV_TOKEN }}
  133. env_vars: OS, python