X Tutup
# This workflow will install Python dependencies, run tests and lint with a variety of Python versions # For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions name: Python package on: [push, pull_request, workflow_dispatch] permissions: contents: read jobs: build: runs-on: ubuntu-latest strategy: fail-fast: false matrix: python-version: ["3.7", "3.8", "3.9", "3.10", "3.11", "3.12"] include: - experimental: false defaults: run: shell: /bin/bash --noprofile --norc -exo pipefail {0} steps: - uses: actions/checkout@v4 with: fetch-depth: 0 submodules: recursive - name: Set up Python ${{ matrix.python-version }} uses: actions/setup-python@v4 with: python-version: ${{ matrix.python-version }} allow-prereleases: ${{ matrix.experimental }} - name: Prepare this repo for tests run: | ./init-tests-after-clone.sh - name: Set git user identity and command aliases for the tests run: | git config --global user.email "travis@ci.com" git config --global user.name "Travis Runner" # If we rewrite the user's config by accident, we will mess it up # and cause subsequent tests to fail cat test/fixtures/.gitconfig >> ~/.gitconfig - name: Update PyPA packages run: | # Get the latest pip, wheel, and prior to Python 3.12, setuptools. python -m pip install -U pip $(pip freeze --all | grep -oF setuptools) wheel - name: Install project and test dependencies run: | pip install ".[test]" - name: Show version and platform information run: | uname -a command -v git python git version python --version python -c 'import sys; print(sys.platform)' python -c 'import os; print(os.name)' python -c 'import git; print(git.compat.is_win)' - name: Check types with mypy run: | mypy -p git # With new versions of mypy new issues might arise. This is a problem if there is nobody able to fix them, # so we have to ignore errors until that changes. continue-on-error: true - name: Test with pytest run: | pytest --color=yes -p no:sugar --instafail -vv continue-on-error: false - name: Documentation run: | pip install -r doc/requirements.txt make -C doc html
X Tutup