From cc30460d27b68f688ce977ed3b4ae20efb29e93a Mon Sep 17 00:00:00 2001 From: Sean Hammond Date: Tue, 11 Jun 2024 17:36:08 +0100 Subject: [PATCH] Upgrade Python patch versions and add 3.11, 3.12 --- .cookiecutter/cookiecutter.json | 2 +- .github/workflows/ci.yml | 10 +++++----- .python-version | 8 +++++--- Makefile | 28 ++++++++++++++++++++++++---- README.md | 2 +- bin/make_python | 2 +- tox.ini | 2 +- 7 files changed, 38 insertions(+), 16 deletions(-) diff --git a/.cookiecutter/cookiecutter.json b/.cookiecutter/cookiecutter.json index 5e37031..bed780e 100644 --- a/.cookiecutter/cookiecutter.json +++ b/.cookiecutter/cookiecutter.json @@ -10,7 +10,7 @@ "package_name": "pip_sync_faster", "slug": "pip-sync-faster", "short_description": "A wrapper that makes pip-sync faster.", - "python_versions": "3.10.6, 3.9.13, 3.8.13", + "python_versions": "3.12.4, 3.11.9, 3.10.14, 3.9.19, 3.8.19", "github_owner": "hypothesis", "copyright_holder": "Hypothesis", "public": "yes", diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 3b770a6..2cfe8d1 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -22,7 +22,7 @@ jobs: - name: Install Python uses: actions/setup-python@v4 with: - python-version: '3.10' + python-version: '3.12' - run: python -m pip install 'tox<4' - run: tox -e checkformatting Lint: @@ -32,14 +32,14 @@ jobs: - name: Install Python uses: actions/setup-python@v4 with: - python-version: '3.10' + python-version: '3.12' - run: python -m pip install 'tox<4' - run: tox -e lint Tests: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.10', '3.9', '3.8'] + python-version: ['3.12', '3.11', '3.10', '3.9', '3.8'] name: Unit tests with Python ${{ matrix.python-version }} steps: - uses: actions/checkout@v3 @@ -64,7 +64,7 @@ jobs: - name: Install Python uses: actions/setup-python@v4 with: - python-version: '3.10' + python-version: '3.12' - name: Download coverage files uses: actions/download-artifact@v3 with: @@ -75,7 +75,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.10', '3.9', '3.8'] + python-version: ['3.12', '3.11', '3.10', '3.9', '3.8'] name: Functional tests with Python ${{ matrix.python-version }} steps: - uses: actions/checkout@v3 diff --git a/.python-version b/.python-version index 918735a..29afc11 100644 --- a/.python-version +++ b/.python-version @@ -1,3 +1,5 @@ -3.10.6 -3.9.13 -3.8.13 +3.12.4 +3.11.9 +3.10.14 +3.9.19 +3.8.19 diff --git a/Makefile b/Makefile index 17a60d5..83d0116 100644 --- a/Makefile +++ b/Makefile @@ -34,10 +34,20 @@ checkformatting: python @pyenv exec tox -qe checkformatting .PHONY: test -$(call help,make test,"run the unit tests in Python 3.10") +$(call help,make test,"run the unit tests in Python 3.12") test: python @pyenv exec tox -qe tests +.PHONY: test-py311 +$(call help,make test-py311,"run the unit tests in Python 3.11") +test-py311: python + @pyenv exec tox -qe py311-tests + +.PHONY: test-py310 +$(call help,make test-py310,"run the unit tests in Python 3.10") +test-py310: python + @pyenv exec tox -qe py310-tests + .PHONY: test-py39 $(call help,make test-py39,"run the unit tests in Python 3.9") test-py39: python @@ -51,13 +61,23 @@ test-py38: python .PHONY: coverage $(call help,make coverage,"run the tests and print the coverage report") coverage: python - @pyenv exec tox --parallel -qe 'tests,py{39,38}-tests,coverage' + @pyenv exec tox --parallel -qe 'tests,py{311,310,39,38}-tests,coverage' .PHONY: functests -$(call help,make functests,"run the functional tests in Python 3.10") +$(call help,make functests,"run the functional tests in Python 3.12") functests: python @pyenv exec tox -qe functests +.PHONY: functests-py311 +$(call help,make functests-py311,"run the functional tests in Python 3.11") +functests-py311: python + @pyenv exec tox -qe py311-functests + +.PHONY: functests-py310 +$(call help,make functests-py310,"run the functional tests in Python 3.10") +functests-py310: python + @pyenv exec tox -qe py310-functests + .PHONY: functests-py39 $(call help,make functests-py39,"run the functional tests in Python 3.9") functests-py39: python @@ -72,7 +92,7 @@ functests-py38: python $(call help,make sure,"make sure that the formatting$(comma) linting and tests all pass") sure: python sure: - @pyenv exec tox --parallel -qe 'checkformatting,lint,tests,py{39,38}-tests,coverage,functests,py{39,38}-functests' + @pyenv exec tox --parallel -qe 'checkformatting,lint,tests,py{311,310,39,38}-tests,coverage,functests,py{311,310,39,38}-functests' .PHONY: template $(call help,make template,"update from the latest cookiecutter template") diff --git a/README.md b/README.md index 53e1268..2cad5fe 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ - + diff --git a/bin/make_python b/bin/make_python index 4573bfd..a2266ab 100755 --- a/bin/make_python +++ b/bin/make_python @@ -8,7 +8,7 @@ if [ -n "${CI+x}" ]; then exit; fi pyenv_root=$(pyenv root) -for python_version in 3.10.6 3.9.13 3.8.13; do +for python_version in 3.12.4 3.11.9 3.10.14 3.9.19 3.8.19; do bin_dir=$pyenv_root/versions/$python_version/bin if [ ! -f "$bin_dir"/tox ]; then pyenv install --skip-existing "$python_version" diff --git a/tox.ini b/tox.ini index 8e0279a..3bb16b9 100644 --- a/tox.ini +++ b/tox.ini @@ -45,7 +45,7 @@ deps = lint,template: cookiecutter typecheck: mypy depends = - coverage: tests,py{39,38}-tests + coverage: tests,py{311,310,39,38}-tests commands = dev: {posargs:ipython --classic --no-banner --no-confirm-exit} format: black src tests bin