summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBernát Gábor <bgabor8@bloomberg.net>2020-10-01 11:50:48 +0100
committerGitHub <noreply@github.com>2020-10-01 11:50:48 +0100
commitbf74cf4b187ee3c85da438c58a6aced72a86a107 (patch)
tree9bf16a65a8cfde73cb3af85ecc632592c5aaf3cb
parent5e46e4a8d4f816812619ca67c4ff41f4aaf4006f (diff)
downloadvirtualenv-bf74cf4b187ee3c85da438c58a6aced72a86a107.tar.gz
Update Github Actions (#1957)
-rw-r--r--.github/workflows/check.yml220
1 files changed, 107 insertions, 113 deletions
diff --git a/.github/workflows/check.yml b/.github/workflows/check.yml
index c8a4c50..7818ed5 100644
--- a/.github/workflows/check.yml
+++ b/.github/workflows/check.yml
@@ -3,21 +3,15 @@ on:
push:
pull_request:
schedule:
- - cron: '0 8 * * *'
+ - cron: "0 8 * * *"
jobs:
lint:
runs-on: ubuntu-latest
steps:
- - uses: actions/checkout@v2
- - uses: actions/setup-python@v2
- - name: set PY
- run: echo "::set-env name=PY::$(python -c 'import hashlib, sys;print(hashlib.sha256(sys.version.encode()+sys.executable.encode()).hexdigest())')"
- - uses: actions/cache@v2
- with:
- path: ~/.cache/pre-commit
- key: pre-commit|${{ env.PY }}|${{ hashFiles('.pre-commit-config.yaml') }}
- - uses: pre-commit/action@v1.1.0
+ - uses: actions/checkout@v2
+ - uses: actions/setup-python@v2
+ - uses: pre-commit/action@v2.0.0
test:
name: test ${{ matrix.py }} - ${{ matrix.os }}
@@ -26,125 +20,125 @@ jobs:
fail-fast: false
matrix:
os:
- - ubuntu
- - windows
- - macos
+ - ubuntu
+ - windows
+ - macos
py:
- - 3.8
- - 3.7
- - 3.6
- - 3.5
- - pypy3
- - 2.7
- - pypy2
+ - 3.9.0-rc.2
+ - 3.8
+ - 3.7
+ - 3.6
+ - 3.5
+ - pypy3
+ - 2.7
+ - pypy2
include:
- - {os: MacOs, py: brew@py3}
- - {os: Ubuntu, py: 3.9-dev}
+ - { os: MacOs, py: brew@py3 }
steps:
- - name: install OS dependencies
- run: |
- ${{ runner.os == 'Linux' && 'sudo apt-get update -y && sudo apt-get install fish csh' || true}}
- ${{ runner.os == 'macOS' && 'brew update -vvv && brew install fish tcsh' || true}}
- ${{ runner.os == 'Windows' && ( matrix.py == '2.7' || matrix.py == 'pypy2' ) && 'choco install vcpython27 --yes -f' || true }}
- shell: bash
- - name: setup python for tox
- uses: actions/setup-python@v2
- with:
- python-version: 3.8
- - name: install tox
- run: python -m pip install tox
- - uses: actions/checkout@v2
- - name: use local virtualenv for tox
- run: python -m pip install .
- - name: setup python for test ${{ matrix.py }}
- if: "!( startsWith(matrix.py,'brew@py') || endsWith(matrix.py, '-dev') )"
- uses: actions/setup-python@v2
- with:
- python-version: ${{ matrix.py }}
- - name: setup DEV python for test ${{ matrix.py }}
- uses: deadsnakes/action@v1.0.0
- if: endsWith(matrix.py, '-dev')
- with:
- python-version: ${{ matrix.py }}
- - name: setup brew python for test ${{ matrix.py }}
- if: startsWith(matrix.py,'brew@py')
- run: |
- import subprocess
- subprocess.check_call(["bash", "-c", f"brew upgrade python@3 || brew install python@3"])
- print(f"::add-path::/usr/local/opt/python@3")
- shell: python
- - name: pick environment to run
- run: |
- import subprocess; import json
- major, minor, impl = json.loads(subprocess.check_output(["python", "-c", "import json; import sys; import platform; print(json.dumps([sys.version_info[0], sys.version_info[1], platform.python_implementation()]));"], universal_newlines=True))
- print('::set-env name=TOXENV::' + ("py" if impl == "CPython" else "pypy") + ("{}{}".format(major, minor) if impl == "CPython" else ("3" if major == 3 else "")))
- shell: python
- - name: setup test suite
- run: tox -vv --notest
- - name: run test suite
- run: tox --skip-pkg-install
- env:
- PYTEST_ADDOPTS: "-vv --durations=20"
- CI_RUN: 'yes'
- DIFF_AGAINST: HEAD
- - name: rename coverage report file
- run: |
- import os; os.rename('.tox/coverage.{}.xml'.format(os.environ['TOXENV']), '.tox/coverage.xml')
- shell: python
- - uses: codecov/codecov-action@v1
- with:
- file: ./.tox/coverage.xml
- flags: tests
- name: ${{ matrix.py }} - ${{ matrix.os }}
+ - name: Install OS dependencies
+ run: |
+ for i in 1 2 3; do
+ echo "try $i" && \
+ ${{ runner.os == 'Linux' && 'sudo apt-get update -y && sudo apt-get install fish csh' || true}} && \
+ ${{ runner.os == 'macOS' && 'brew update -vvv && brew install fish tcsh' || true}} && \
+ ${{ runner.os == 'Windows' && ( matrix.py == '2.7' || matrix.py == 'pypy2' ) && 'choco install vcpython27 --yes -f' || true }} && \
+ exit 0 || true;
+ done
+ exit 1
+ shell: bash
+ - name: Setup python for tox
+ uses: actions/setup-python@v2
+ with:
+ python-version: 3.9.0-rc.2
+ - name: Install tox
+ run: python -m pip install tox
+ - uses: actions/checkout@v2
+ - name: Use local virtualenv for tox
+ run: python -m pip install .
+ - name: Setup python for test ${{ matrix.py }}
+ if: "!( startsWith(matrix.py,'brew@py') || endsWith(matrix.py, '-dev') )"
+ uses: actions/setup-python@v2
+ with:
+ python-version: ${{ matrix.py }}
+ - name: Setup brew python for test ${{ matrix.py }}
+ if: startsWith(matrix.py,'brew@py')
+ run: |
+ import subprocess
+ subprocess.check_call(["bash", "-c", f"brew upgrade python@3 || brew install python@3"])
+ print(f"::add-path::/usr/local/opt/python@3")
+ shell: python
+ - name: Pick environment to run
+ run: |
+ import subprocess; import json
+ major, minor, impl = json.loads(subprocess.check_output(["python", "-c", "import json; import sys; import platform; print(json.dumps([sys.version_info[0], sys.version_info[1], platform.python_implementation()]));"], universal_newlines=True))
+ print('::set-env name=TOXENV::' + ("py" if impl == "CPython" else "pypy") + ("{}{}".format(major, minor) if impl == "CPython" else ("3" if major == 3 else "")))
+ shell: python
+ - name: Setup test suite
+ run: tox -vv --notest
+ - name: Run test suite
+ run: tox --skip-pkg-install
+ env:
+ PYTEST_ADDOPTS: "-vv --durations=20"
+ CI_RUN: "yes"
+ DIFF_AGAINST: HEAD
+ - name: Rename coverage report file
+ run: |
+ import os; os.rename('.tox/coverage.{}.xml'.format(os.environ['TOXENV']), '.tox/coverage.xml')
+ shell: python
+ - uses: codecov/codecov-action@v1
+ with:
+ file: ./.tox/coverage.xml
+ flags: tests
+ name: ${{ matrix.py }} - ${{ matrix.os }}
check:
- name: check ${{ matrix.tox_env }} - ${{ matrix.os }}
+ name: ${{ matrix.tox_env }} - ${{ matrix.os }}
runs-on: ${{ matrix.os }}-latest
strategy:
fail-fast: false
matrix:
os:
- - Ubuntu
- - Windows
+ - ubuntu
+ - windows
tox_env:
- - dev
- - docs
- - readme
- - upgrade
- - zipapp
+ - dev
+ - docs
+ - readme
+ - upgrade
+ - zipapp
exclude:
- - {os: Windows, tox_env: readme}
- - {os: Windows, tox_env: docs}
+ - { os: windows, tox_env: readme }
+ - { os: windows, tox_env: docs }
steps:
- - uses: actions/checkout@v2
- - name: setup Python 3.8
- uses: actions/setup-python@v2
- with:
- python-version: 3.8
- - name: install tox
- run: python -m pip install tox
- - name: run check for ${{ matrix.tox_env }}
- run: python -m tox -e ${{ matrix.tox_env }}
- env:
- UPGRADE_ADVISORY: 'yes'
+ - uses: actions/checkout@v2
+ - name: Setup Python 3.9.0-rc.2
+ uses: actions/setup-python@v2
+ with:
+ python-version: 3.9.0-rc.2
+ - name: Install tox
+ run: python -m pip install tox
+ - name: Run check for ${{ matrix.tox_env }}
+ run: python -m tox -e ${{ matrix.tox_env }}
+ env:
+ UPGRADE_ADVISORY: "yes"
publish:
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
needs: [check, test, lint]
runs-on: ubuntu-latest
steps:
- - name: setup python to build package
- uses: actions/setup-python@v2
- with:
- python-version: 3.8
- - name: install pep517
- run: python -m pip install pep517
- - uses: actions/checkout@v2
- - name: build package
- run: python -m pep517.build -s -b . -o dist
- - name: publish to PyPi
- uses: pypa/gh-action-pypi-publish@main
- with:
- skip_existing: true
- user: __token__
- password: ${{ secrets.pypi_password }}
+ - name: Setup python to build package
+ uses: actions/setup-python@v2
+ with:
+ python-version: 3.9.0-rc.2
+ - name: Install https://pypi.org/project/build
+ run: python -m pip install build
+ - uses: actions/checkout@v2
+ - name: Build sdist and wheel
+ run: python -m build -s -w . -o dist
+ - name: Publish to PyPi
+ uses: pypa/gh-action-pypi-publish@main
+ with:
+ skip_existing: true
+ user: __token__
+ password: ${{ secrets.pypi_password }}