فهرست منبع

Merge pull request #8148 from ThomasWaldmann/gh-actions-update-1.4

github CI: misc. updates (1.4-maint)
TW 1 سال پیش
والد
کامیت
702560d9f2
5فایلهای تغییر یافته به همراه24 افزوده شده و 24 حذف شده
  1. 16 15
      .github/workflows/ci.yml
  2. 6 6
      .github/workflows/codeql-analysis.yml
  3. 1 1
      .github/workflows/windows.yml
  4. 1 1
      Brewfile
  5. 0 1
      docs/global.rst.inc

+ 16 - 15
.github/workflows/ci.yml

@@ -11,6 +11,7 @@ on:
     - '**.c'
     - '**.c'
     - '**.h'
     - '**.h'
     - '**.yml'
     - '**.yml'
+    - '**.toml'
     - '**.cfg'
     - '**.cfg'
     - '**.ini'
     - '**.ini'
     - 'requirements.d/*'
     - 'requirements.d/*'
@@ -23,6 +24,7 @@ on:
     - '**.c'
     - '**.c'
     - '**.h'
     - '**.h'
     - '**.yml'
     - '**.yml'
+    - '**.toml'
     - '**.cfg'
     - '**.cfg'
     - '**.ini'
     - '**.ini'
     - 'requirements.d/*'
     - 'requirements.d/*'
@@ -35,7 +37,7 @@ jobs:
     timeout-minutes: 5
     timeout-minutes: 5
 
 
     steps:
     steps:
-    - uses: actions/checkout@v3
+    - uses: actions/checkout@v4
     - uses: chartboost/ruff-action@v1
     - uses: chartboost/ruff-action@v1
 
 
   pytest:
   pytest:
@@ -48,38 +50,38 @@ jobs:
             - os: ubuntu-20.04
             - os: ubuntu-20.04
               python-version: '3.9'
               python-version: '3.9'
               toxenv: py39-fuse2
               toxenv: py39-fuse2
-            - os: ubuntu-20.04
+            - os: ubuntu-22.04
               python-version: '3.10'
               python-version: '3.10'
               toxenv: py310-fuse3
               toxenv: py310-fuse3
-            - os: ubuntu-20.04
+            - os: ubuntu-22.04
               python-version: '3.11'
               python-version: '3.11'
               toxenv: py311-fuse2
               toxenv: py311-fuse2
             - os: ubuntu-22.04
             - os: ubuntu-22.04
               python-version: '3.12'
               python-version: '3.12'
               toxenv: py312-fuse3
               toxenv: py312-fuse3
-            - os: macos-12
-              python-version: '3.9'
-              toxenv: py39-none  # note: no fuse testing, due to #6099, see also #6196.
+            - os: macos-14
+              python-version: '3.11'
+              toxenv: py311-none  # note: no fuse testing, due to #6099, see also #6196.
 
 
     env:
     env:
       # Configure pkg-config to use OpenSSL from Homebrew
       # Configure pkg-config to use OpenSSL from Homebrew
-      PKG_CONFIG_PATH: "/usr/local/opt/openssl@1.1/lib/pkgconfig:$PKG_CONFIG_PATH"
+      PKG_CONFIG_PATH: "/usr/local/opt/openssl@3.0/lib/pkgconfig:$PKG_CONFIG_PATH"
       TOXENV: ${{ matrix.toxenv }}
       TOXENV: ${{ matrix.toxenv }}
 
 
     runs-on: ${{ matrix.os }}
     runs-on: ${{ matrix.os }}
     timeout-minutes: 180
     timeout-minutes: 180
 
 
     steps:
     steps:
-    - uses: actions/checkout@v3
+    - uses: actions/checkout@v4
       with:
       with:
         # just fetching 1 commit is not enough for setuptools-scm, so we fetch all
         # just fetching 1 commit is not enough for setuptools-scm, so we fetch all
         fetch-depth: 0
         fetch-depth: 0
     - name: Set up Python ${{ matrix.python-version }}
     - name: Set up Python ${{ matrix.python-version }}
-      uses: actions/setup-python@v4
+      uses: actions/setup-python@v5
       with:
       with:
         python-version: ${{ matrix.python-version }}
         python-version: ${{ matrix.python-version }}
     - name: Cache pip
     - name: Cache pip
-      uses: actions/cache@v3
+      uses: actions/cache@v4
       with:
       with:
         path: ~/.cache/pip
         path: ~/.cache/pip
         key: ${{ runner.os }}-pip-${{ hashFiles('requirements.d/development.txt') }}
         key: ${{ runner.os }}-pip-${{ hashFiles('requirements.d/development.txt') }}
@@ -93,7 +95,6 @@ jobs:
         sudo apt-get update
         sudo apt-get update
         sudo apt-get install -y libssl-dev libacl1-dev liblz4-dev libzstd-dev pkg-config build-essential
         sudo apt-get install -y libssl-dev libacl1-dev liblz4-dev libzstd-dev pkg-config build-essential
         sudo apt-get install -y libxxhash-dev || true
         sudo apt-get install -y libxxhash-dev || true
-        sudo apt-get install -y libb2-dev || true
         sudo apt-get install -y libfuse-dev fuse || true  # Required for Python llfuse module
         sudo apt-get install -y libfuse-dev fuse || true  # Required for Python llfuse module
         sudo apt-get install -y libfuse3-dev fuse3 || true  # Required for Python pyfuse3 module
         sudo apt-get install -y libfuse3-dev fuse3 || true  # Required for Python pyfuse3 module
 
 
@@ -109,20 +110,20 @@ jobs:
       env:
       env:
         # we already have that in the global env, but something is broken and overwrites that.
         # we already have that in the global env, but something is broken and overwrites that.
         # so, set it here, again.
         # so, set it here, again.
-        PKG_CONFIG_PATH: "/usr/local/opt/openssl@1.1/lib/pkgconfig:$PKG_CONFIG_PATH"
+        PKG_CONFIG_PATH: "/usr/local/opt/openssl@3.0/lib/pkgconfig:$PKG_CONFIG_PATH"
       run: |
       run: |
-        pip install -e .
+        pip install -ve .
     - name: run pytest via tox
     - name: run pytest via tox
       env:
       env:
         # we already have that in the global env, but something is broken and overwrites that.
         # we already have that in the global env, but something is broken and overwrites that.
         # so, set it here, again.
         # so, set it here, again.
-        PKG_CONFIG_PATH: "/usr/local/opt/openssl@1.1/lib/pkgconfig:$PKG_CONFIG_PATH"
+        PKG_CONFIG_PATH: "/usr/local/opt/openssl@3.0/lib/pkgconfig:$PKG_CONFIG_PATH"
       run: |
       run: |
         # do not use fakeroot, but run as root. avoids the dreaded EISDIR sporadic failures. see #2482.
         # do not use fakeroot, but run as root. avoids the dreaded EISDIR sporadic failures. see #2482.
         #sudo -E bash -c "tox -e py"
         #sudo -E bash -c "tox -e py"
         tox --skip-missing-interpreters
         tox --skip-missing-interpreters
     - name: Upload coverage to Codecov
     - name: Upload coverage to Codecov
-      uses: codecov/codecov-action@v1
+      uses: codecov/codecov-action@v4
       env:
       env:
         OS: ${{ runner.os }}
         OS: ${{ runner.os }}
         python: ${{ matrix.python-version }}
         python: ${{ matrix.python-version }}

+ 6 - 6
.github/workflows/codeql-analysis.yml

@@ -14,7 +14,7 @@ on:
 jobs:
 jobs:
   analyze:
   analyze:
     name: Analyze
     name: Analyze
-    runs-on: ubuntu-20.04
+    runs-on: ubuntu-22.04
     permissions:
     permissions:
       actions: read
       actions: read
       contents: read
       contents: read
@@ -29,16 +29,16 @@ jobs:
 
 
     steps:
     steps:
     - name: Checkout repository
     - name: Checkout repository
-      uses: actions/checkout@v3
+      uses: actions/checkout@v4
       with:
       with:
         # just fetching 1 commit is not enough for setuptools-scm, so we fetch all
         # just fetching 1 commit is not enough for setuptools-scm, so we fetch all
         fetch-depth: 0
         fetch-depth: 0
     - name: Set up Python
     - name: Set up Python
-      uses: actions/setup-python@v4
+      uses: actions/setup-python@v5
       with:
       with:
-        python-version: 3.9
+        python-version: 3.11
     - name: Cache pip
     - name: Cache pip
-      uses: actions/cache@v3
+      uses: actions/cache@v4
       with:
       with:
         path: ~/.cache/pip
         path: ~/.cache/pip
         key: ${{ runner.os }}-pip-${{ hashFiles('requirements.d/development.txt') }}
         key: ${{ runner.os }}-pip-${{ hashFiles('requirements.d/development.txt') }}
@@ -64,6 +64,6 @@ jobs:
         python3 -m venv ../borg-env
         python3 -m venv ../borg-env
         source ../borg-env/bin/activate
         source ../borg-env/bin/activate
         pip3 install -r requirements.d/development.txt
         pip3 install -r requirements.d/development.txt
-        pip3 install -e .
+        pip3 install -ve .
     - name: Perform CodeQL Analysis
     - name: Perform CodeQL Analysis
       uses: github/codeql-action/analyze@v2
       uses: github/codeql-action/analyze@v2

+ 1 - 1
.github/workflows/windows.yml

@@ -8,7 +8,7 @@ jobs:
       run:
       run:
         shell: msys2 {0}
         shell: msys2 {0}
     steps:
     steps:
-      - uses: actions/checkout@v3
+      - uses: actions/checkout@v4
         with:
         with:
           fetch-depth: 0
           fetch-depth: 0
       - uses: msys2/setup-msys2@v2
       - uses: msys2/setup-msys2@v2

+ 1 - 1
Brewfile

@@ -2,7 +2,7 @@ brew 'pkg-config'
 brew 'zstd'
 brew 'zstd'
 brew 'lz4'
 brew 'lz4'
 brew 'xxhash'
 brew 'xxhash'
-brew 'openssl@1.1'
+brew 'openssl@3.0'
 
 
 # osxfuse (aka macFUSE) is only required for "borg mount",
 # osxfuse (aka macFUSE) is only required for "borg mount",
 # but won't work on github actions' workers.
 # but won't work on github actions' workers.

+ 0 - 1
docs/global.rst.inc

@@ -15,7 +15,6 @@
 .. _libattr: https://savannah.nongnu.org/projects/attr/
 .. _libattr: https://savannah.nongnu.org/projects/attr/
 .. _liblz4: https://github.com/Cyan4973/lz4
 .. _liblz4: https://github.com/Cyan4973/lz4
 .. _libzstd: https://github.com/facebook/zstd
 .. _libzstd: https://github.com/facebook/zstd
-.. _libb2: https://github.com/BLAKE2/libb2
 .. _OpenSSL: https://www.openssl.org/
 .. _OpenSSL: https://www.openssl.org/
 .. _`Python 3`: https://www.python.org/
 .. _`Python 3`: https://www.python.org/
 .. _Buzhash: https://en.wikipedia.org/wiki/Buzhash
 .. _Buzhash: https://en.wikipedia.org/wiki/Buzhash