]> git.phdru.name Git - cookiecutter.git/commitdiff
CI(GHActions): Use `conda` to install older Pythons
authorOleg Broytman <phd@phdru.name>
Thu, 8 Dec 2022 15:43:19 +0000 (18:43 +0300)
committerOleg Broytman <phd@phdru.name>
Thu, 8 Dec 2022 15:43:19 +0000 (18:43 +0300)
Ubuntu >= 22 and `setup-python` dropped Pythons < 3.7.
Use `s-weigand/setup-conda` instead of `setup-python`.

project_template/.github/workflows/test-publish.yaml

index a66ab6e2cd4dc016d94dddc1359df20b576c4c89..b4c337a45913dba3d336897beb589234ad26355f 100644 (file)
@@ -7,11 +7,13 @@ on: [push, pull_request]
 
 jobs:
   run-tests:
 
 jobs:
   run-tests:
+    env:
+      not_in_conda: "['3.11', 'pypy-3.7']"
 
     strategy:
       matrix:
         os: [ubuntu-latest, macos-11, windows-latest]
 
     strategy:
       matrix:
         os: [ubuntu-latest, macos-11, windows-latest]
-        python-version: ["2.7", "3.5", "3.6", "3.7", "3.8", "3.9", "3.10", "3.11", "pypy-2.7", "pypy-3.7"]
+        python-version: ["2.7", "3.5", "3.6", "3.7", "3.8", "3.9", "3.10", "3.11", "pypy-3.7"]
         include:
         - os: ubuntu-latest
           os-name: Linux
         include:
         - os: ubuntu-latest
           os-name: Linux
@@ -29,9 +31,14 @@ jobs:
     steps:
 
       # Setup Python/pip
     steps:
 
       # Setup Python/pip
+      - uses: s-weigand/setup-conda@v1
+        with:
+          python-version: ${{ matrix.python-version }}
+        if: ${{ runner.os == 'Linux' && !contains(fromJSON(env.not_in_conda), matrix.python-version) }}
       - uses: actions/setup-python@v4
         with:
           python-version: ${{ matrix.python-version }}
       - uses: actions/setup-python@v4
         with:
           python-version: ${{ matrix.python-version }}
+        if: ${{ runner.os != 'Linux' || contains(fromJSON(env.not_in_conda), matrix.python-version) }}
       - name: Cache pip
         uses: actions/cache@v3
         with:
       - name: Cache pip
         uses: actions/cache@v3
         with:
@@ -49,7 +56,7 @@ jobs:
         run: |
           import os, sys
           if hasattr(sys, 'pypy_version_info'):
         run: |
           import os, sys
           if hasattr(sys, 'pypy_version_info'):
-            toxenv = 'pypy'
+            toxenv = 'pypy3'
           else:
             pyver = '%d%d' % tuple(sys.version_info[:2])
             toxenv = 'py%s' % pyver
           else:
             pyver = '%d%d' % tuple(sys.version_info[:2])
             toxenv = 'py%s' % pyver