From 68b492eaa849664e51b05da2a252f2722d37fd46 Mon Sep 17 00:00:00 2001 From: Kate Case Date: Wed, 8 Nov 2023 16:15:32 -0500 Subject: [PATCH] Drop Python 3.6/3.7 support --- .github/workflows/ci-cd.yml | 106 ++-------------------- README.rst | 2 +- docs/changelog-fragments/532.breaking.rst | 2 + docs/conf.py | 2 +- docs/installation_guide.rst | 2 +- packaging/rpm/ansible-pylibssh.spec | 18 ++-- pyproject.toml | 7 +- requirements-build.txt | 12 +-- setup.cfg | 4 +- 9 files changed, 24 insertions(+), 131 deletions(-) create mode 100644 docs/changelog-fragments/532.breaking.rst diff --git a/.github/workflows/ci-cd.yml b/.github/workflows/ci-cd.yml index b08271e41..33f4ff37c 100644 --- a/.github/workflows/ci-cd.yml +++ b/.github/workflows/ci-cd.yml @@ -686,8 +686,6 @@ jobs: # NOTE: $ podman run -it --rm \ # NOTE: quay.io/pypa/manylinux2014_x86_64 \ # NOTE: ls -1 /opt/python - - cp36-cp36m - - cp37-cp37m - cp38-cp38 - cp39-cp39 - cp310-cp310 @@ -704,16 +702,6 @@ jobs: qemu_arch: amd64 include: # NOTE: manylinux2010 only on x86_64 - - manylinux-python-target: cp36-cp36m - manylinux-image-target: - arch: x86_64 - qemu_arch: amd64 - manylinux-year-target: 2010 - - manylinux-python-target: cp37-cp37m - manylinux-image-target: - arch: x86_64 - qemu_arch: amd64 - manylinux-year-target: 2010 - manylinux-python-target: cp38-cp38 manylinux-image-target: arch: x86_64 @@ -730,16 +718,6 @@ jobs: qemu_arch: amd64 manylinux-year-target: 2010 # NOTE: manylinux1 caps out at Python 3.9 - - manylinux-python-target: cp36-cp36m - manylinux-image-target: - arch: x86_64 - qemu_arch: amd64 - manylinux-year-target: 1 - - manylinux-python-target: cp37-cp37m - manylinux-image-target: - arch: x86_64 - qemu_arch: amd64 - manylinux-year-target: 1 - manylinux-python-target: cp38-cp38 manylinux-image-target: arch: x86_64 @@ -800,8 +778,6 @@ jobs: # NOTE: $ podman run -it --rm \ # NOTE: quay.io/pypa/manylinux2014_x86_64 \ # NOTE: ls -1 /opt/python - - cp36-cp36m - - cp37-cp37m - cp38-cp38 - cp39-cp39 - cp310-cp310 @@ -866,8 +842,10 @@ jobs: strategy: matrix: python-version: + - >- + 3.10 + - 3.9 - 3.8 - - 3.7 runner-vm-os: - ubuntu-22.04 store-sdist-to-artifact: @@ -876,9 +854,6 @@ jobs: - python-version: 3.12 runner-vm-os: ubuntu-22.04 store-sdist-to-artifact: true - - python-version: 3.6 # EOL, only provided for older OSs - runner-vm-os: ubuntu-20.04 - store-sdist-to-artifact: false env: PEP517_BUILD_ARGS: --sdist @@ -1068,19 +1043,9 @@ jobs: target-container: - tag: fedora:39 - tag: fedora:40 - - tag: centos/centos:stream8 - registry: quay.io # No matching package to install: 'python3dist(wheel)' # - tag: centos/centos:stream9 # registry: quay.io - - tag: ubi8/ubi:8.5 - registry: registry.access.redhat.com - - tag: ubi8/ubi:8.6 - registry: registry.access.redhat.com - - tag: ubi8/ubi:8.7 - registry: registry.access.redhat.com - - tag: ubi8/ubi:8.8 - registry: registry.access.redhat.com - tag: ubi9/ubi:9.0.0 registry: registry.access.redhat.com - tag: ubi9/ubi:9.1 @@ -1205,23 +1170,6 @@ jobs: steps.distribution-meta.outputs.dist-tag }}.noarch.rpm - - name: Install static test dependencies missing from UBI8 - if: contains(matrix.target-container.tag, 'ubi8') - run: >- - rpm - -ivh - --nodeps - https://vault.centos.org/"$( - rpm --eval '%{rhel}' - )".4.2105/BaseOS/x86_64/os/Packages/openssh-8.0p1-6${{ - steps.distribution-meta.outputs.dist-tag - }}_4.2.x86_64.rpm - https://rpmfind.net/linux/epel/"$( - rpm --eval '%{rhel}' - )"/Everything/x86_64/Packages/p/python3-toml-0.10.0-3${{ - steps.distribution-meta.outputs.dist-tag - }}.noarch.rpm - - name: Install static test dependencies missing from all UBIs if: contains(matrix.target-container.tag, 'ubi') run: >- @@ -1253,15 +1201,7 @@ jobs: }}${{ steps.distribution-meta.outputs.dist-tag }}.noarch.rpm https://rpmfind.net/linux/epel/"$( rpm --eval '%{rhel}' - )"/Everything/x86_64/Packages/${{ - contains(matrix.target-container.tag, 'ubi9') - && 't' - || 'p' - }}/${{ - !contains(matrix.target-container.tag, 'ubi9') - && 'python3-' - || '' - }}tox-${{ + )"/Everything/x86_64/Packages/t/tox-${{ contains(matrix.target-container.tag, 'ubi9') && '3.28.0-1' || '3.4.0-2' @@ -1273,33 +1213,9 @@ jobs: && '1.9.0-3' || '1.7.1-1' }}${{ steps.distribution-meta.outputs.dist-tag }}.noarch.rpm - https://${{ - contains(matrix.target-container.tag, '8') - && 'vault.centos.org' - || 'rpmfind.net/linux' - }}/${{ - contains(matrix.target-container.tag, 'ubi9') - && 'epel' - || 'centos' - }}/"$( + https://rpmfind.net/linux/epel/"$( rpm --eval '%{rhel}' - )"${{ - !contains(matrix.target-container.tag, 'ubi9') - && '-stream' - || '' - }}/${{ - contains(matrix.target-container.tag, 'ubi9') - && 'Everything' - || 'AppStream' - }}/x86_64/${{ - !contains(matrix.target-container.tag, 'ubi9') - && 'os/' - || '' - }}Packages/${{ - contains(matrix.target-container.tag, 'ubi9') - && 'p/' - || '' - }}python3-coverage-${{ + )"/Everything/x86_64/Packages/p/python3-coverage-${{ contains(matrix.target-container.tag, 'ubi9') && '6.2-1' || '4.5.1-9' @@ -1408,17 +1324,12 @@ jobs: - "3.10" - 3.9 - 3.8 - - 3.7 - - 3.6 runner-vm-os: - ubuntu-22.04 - ubuntu-20.04 dist-type: - binary - source - exclude: - - runner-vm-os: ubuntu-22.04 - python-version: 3.6 # EOL, only provided for older OSs uses: ./.github/workflows/reusable-tests.yml with: @@ -1450,16 +1361,11 @@ jobs: - "3.10" - 3.9 - 3.8 - - 3.7 - - 3.6 runner-vm-os: - macos-13 dist-type: - binary - source - exclude: - - runner-vm-os: ubuntu-22.04 - python-version: 3.6 # EOL, only provided for older OSs uses: ./.github/workflows/reusable-tests.yml with: diff --git a/README.rst b/README.rst index 0341503f7..f05c35c9a 100644 --- a/README.rst +++ b/README.rst @@ -53,7 +53,7 @@ The web view is @ https://ansible.github.io/pylibssh/. Requirements ------------ -You need Python 3.6+ +You need Python 3.8+ pylibssh requires libssh to be installed in particular: diff --git a/docs/changelog-fragments/532.breaking.rst b/docs/changelog-fragments/532.breaking.rst new file mode 100644 index 000000000..1b99dc37a --- /dev/null +++ b/docs/changelog-fragments/532.breaking.rst @@ -0,0 +1,2 @@ +Dropped support for Python 3.6 and Python 3.7 +-- by :user:`Qalthos` and :user:`webknjaz`. diff --git a/docs/conf.py b/docs/conf.py index e36ec97bf..f8fe4f4d2 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -1,5 +1,5 @@ # pylint: disable=invalid-name -# Requires Python 3.6+ +# Requires Python 3.8+ # Ref: https://www.sphinx-doc.org/en/master/usage/configuration.html """Configuration for the Sphinx documentation generator.""" diff --git a/docs/installation_guide.rst b/docs/installation_guide.rst index 280901f79..5f1cd0042 100644 --- a/docs/installation_guide.rst +++ b/docs/installation_guide.rst @@ -25,7 +25,7 @@ CPython and OS versions so in 99% of cases, you may seamlessly install |project| not needing any external dependencies on your system. -It should be enough for you to just have Python 3.6+ and +It should be enough for you to just have Python 3.8+ and a recent :std:doc:`pip ` installed. .. attention:: diff --git a/packaging/rpm/ansible-pylibssh.spec b/packaging/rpm/ansible-pylibssh.spec index 3f0302c45..b8c11f541 100644 --- a/packaging/rpm/ansible-pylibssh.spec +++ b/packaging/rpm/ansible-pylibssh.spec @@ -43,9 +43,8 @@ Source2: %{pypi_source build 0.3.1.post1} Source3: %{pypi_source Cython 0.29.32} Source4: %{pypi_source packaging 20.9} Source5: %{pypi_source setuptools 56.0.0} -Source6: %{pypi_source setuptools_scm 6.0.1} -Source7: %{pypi_source setuptools_scm_git_archive 1.4} -Source8: %{pypi_source toml 0.10.2} +Source6: %{pypi_source setuptools_scm 8.1.0} +Source8: %{pypi_source tomli 2.0.1} Source9: %{pypi_source pep517 0.10.0} Source10: %{pypi_source pip 21.1.1} Source11: %{pypi_source pyparsing 2.4.7} @@ -53,7 +52,7 @@ Source11: %{pypi_source pyparsing 2.4.7} %if 0%{?centos} == 0 Source12: %{pypi_source importlib_metadata 4.0.1} Source13: %{pypi_source zipp 3.4.1} -Source14: %{pypi_source typing_extensions 3.10.0.0} +Source14: %{pypi_source typing_extensions 4.12.2} %endif Source15: %{pypi_source pytest 6.2.4} Source16: %{pypi_source pytest-cov 2.12.1} @@ -145,11 +144,14 @@ PYTHONPATH="$(pwd)/bin" \ PYTHONPATH="$(pwd)/bin" \ %{__python3} -m pip install --no-deps -t bin %{SOURCE5} PYTHONPATH="$(pwd)/bin" \ -%{__python3} -m pip install --no-deps -t bin %{SOURCE6} --no-build-isolation -PYTHONPATH="$(pwd)/bin" \ -%{__python3} -m pip install --no-deps -t bin %{SOURCE7} +%{__python3} -m pip install --no-deps -t bin %{SOURCE6} PYTHONPATH="$(pwd)/bin" \ %{__python3} -m pip install --no-deps -t bin %{SOURCE8} +# RHEL specifically, not CentOS: +%if 0%{?centos} == 0 +PYTHONPATH="$(pwd)/bin" \ +%{__python3} -m pip install --no-deps -t bin %{SOURCE14} +%endif PYTHONPATH="$(pwd)/bin" \ %{__python3} -m pip install --no-deps -t bin %{SOURCE11} # RHEL specifically, not CentOS: @@ -158,8 +160,6 @@ PYTHONPATH="$(pwd)/bin" \ %{__python3} -m pip install --no-deps -t bin %{SOURCE12} PYTHONPATH="$(pwd)/bin" \ %{__python3} -m pip install --no-deps -t bin %{SOURCE13} -PYTHONPATH="$(pwd)/bin" \ -%{__python3} -m pip install --no-deps -t bin %{SOURCE14} %endif PYTHONPATH="$(pwd)/bin" \ %{__python3} -m pip install --no-deps -t bin %{SOURCE15} diff --git a/pyproject.toml b/pyproject.toml index 29d4949d0..9ccc99803 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -10,12 +10,7 @@ requires = [ "tomli; python_version < '3.11'", # needed by in-tree build backend `packaging/pep517_backend.py` # Plugins - "setuptools-scm >= 7.0.0; python_version >= '3.7'", - # ^ supports git archives through a plugin - # | | - # supports git archives natively V - "setuptools-scm[toml] >= 3.5, < 7.0.0; python_version < '3.7'", - "setuptools-scm-git-archive >= 1.1; python_version < '3.7'", + "setuptools-scm >= 7.0.0", ] backend-path = ["packaging"] # requires 'Pip>=20' or 'pep517>=0.6.0' build-backend = "pep517_backend.hooks" diff --git a/requirements-build.txt b/requirements-build.txt index ac70d772e..e24c7fd8c 100644 --- a/requirements-build.txt +++ b/requirements-build.txt @@ -12,13 +12,7 @@ packaging==21.3 # via setuptools-scm pyparsing==3.0.9 # via packaging -setuptools-scm==6.4.2 ; python_version < "3.7" -setuptools-scm==7.1.0 ; python_version == "3.7.*" -setuptools-scm==8.1.0 ; python_version > "3.7" - # via -r - -setuptools-scm-git-archive==1.4 ; python_version < "3.7" - # via -r - -toml==0.10.2 +setuptools-scm==8.1.0 # via -r - tomli==1.2.3 # via setuptools-scm @@ -28,9 +22,7 @@ wheel==0.37.1 # via -r - # The following packages are considered to be unsafe in a requirements file: -setuptools==59.6.0 ; python_version < "3.7" -setuptools==68.0.0 ; python_version == "3.7.*" -setuptools==68.2.2 ; python_version > "3.7" +setuptools==68.2.2 # via # -r - # setuptools-scm diff --git a/setup.cfg b/setup.cfg index fa02d16b2..10d956522 100644 --- a/setup.cfg +++ b/setup.cfg @@ -29,8 +29,6 @@ classifiers = Operating System :: POSIX :: Linux Programming Language :: Python :: 3 - Programming Language :: Python :: 3.6 - Programming Language :: Python :: 3.7 Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.10 @@ -46,7 +44,7 @@ keywords = libssh [options] -python_requires = >=3.6 +python_requires = >=3.8 # Ref: # https://setuptools.readthedocs.io/en/latest/setuptools.html#using-a-src-layout # (`src/` layout)