From c7dfa5b05ea0560bdc9b40966884e567dcc3148b Mon Sep 17 00:00:00 2001 From: Jan Vesely Date: Thu, 17 Oct 2024 13:45:55 -0400 Subject: [PATCH 1/5] ga/install_pnl: Restrict win32 pandas to < 2.1.0 Later versions do not provide win32 wheels. Signed-off-by: Jan Vesely --- .github/actions/install-pnl/action.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/actions/install-pnl/action.yml b/.github/actions/install-pnl/action.yml index 77be434ce5..3e99c90348 100644 --- a/.github/actions/install-pnl/action.yml +++ b/.github/actions/install-pnl/action.yml @@ -67,6 +67,8 @@ runs: echo "contourpy<1.1.0" >> env_constraints.txt # pillow >= 10.0.0 doesn't provide win32 wheel echo "pillow < 10.0.0" >> env_constraints.txt + # pandas >= 2.1.0 doesn't provide win32 wheel + echo "pandas < 2.1.0" >> env_constraints.txt fi - name: Install updated package From e7646e3609cdcb5dc8f048dbe349fe79d91c798a Mon Sep 17 00:00:00 2001 From: Jan Vesely Date: Thu, 17 Oct 2024 14:35:48 -0400 Subject: [PATCH 2/5] ga/install_pnl: Restrict win32 llvmlite to < 0.42 Later versions do not provide win32 wheels. Signed-off-by: Jan Vesely --- .github/actions/install-pnl/action.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/actions/install-pnl/action.yml b/.github/actions/install-pnl/action.yml index 3e99c90348..e258ed4743 100644 --- a/.github/actions/install-pnl/action.yml +++ b/.github/actions/install-pnl/action.yml @@ -69,6 +69,8 @@ runs: echo "pillow < 10.0.0" >> env_constraints.txt # pandas >= 2.1.0 doesn't provide win32 wheel echo "pandas < 2.1.0" >> env_constraints.txt + # llvmlite >= 0.42.0 doesn't provide win32 wheel + echo "llvmlite < 0.42.0" >> env_constraints.txt fi - name: Install updated package From da16914058350d21f25225781ab1c489b7e481e1 Mon Sep 17 00:00:00 2001 From: Jan Vesely Date: Mon, 6 Jan 2025 21:55:18 -0500 Subject: [PATCH 3/5] requirements: Bump minimum rich version to >=10.2 Earlier versions required old typing_extensions module on all Python versions[0], instead of just Python3.7 [0] https://github.com/Textualize/rich/commit/43590b7f1e019ced4fe849b86d66799f80bc1843 Signed-off-by: Jan Vesely --- requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements.txt b/requirements.txt index 6f1bbe4a06..d9c48e347c 100644 --- a/requirements.txt +++ b/requirements.txt @@ -16,7 +16,7 @@ pandas<2.2.4 pillow<11.2.0 pint<0.22.0 protobuf<3.20.4 -rich>=10.1, <10.13 +rich>=10.2, <10.13 scipy>=1.7.3, <1.16 toposort<1.11 torch>=1.10.0, <2.6.0; (platform_machine == 'AMD64' or platform_machine == 'x86_64' or platform_machine == 'arm64' or platform_machine == 'aarch64') and platform_python_implementation == 'CPython' and implementation_name == 'cpython' From de09edc6b2a01343208ee5ce2dbe7c99c790f4f3 Mon Sep 17 00:00:00 2001 From: Jan Vesely Date: Thu, 17 Oct 2024 11:53:31 -0400 Subject: [PATCH 4/5] ci/ga: Remove Python3.7 CI jobs Signed-off-by: Jan Vesely --- .github/workflows/pnl-ci-docs.yml | 16 ++-------------- .github/workflows/pnl-ci.yml | 27 ++++++++++++--------------- .github/workflows/test-release.yml | 7 +------ 3 files changed, 15 insertions(+), 35 deletions(-) diff --git a/.github/workflows/pnl-ci-docs.yml b/.github/workflows/pnl-ci-docs.yml index 5fadde3045..02ba4b1b7e 100644 --- a/.github/workflows/pnl-ci-docs.yml +++ b/.github/workflows/pnl-ci-docs.yml @@ -21,7 +21,7 @@ jobs: strategy: fail-fast: false matrix: - python-version: ['3.7', '3.8', '3.9', '3.10', '3.11', '3.12'] + python-version: ['3.8', '3.9', '3.10', '3.11', '3.12'] os: [ubuntu-latest, macos-latest, windows-latest] pnl-version: ${{ (github.event_name == 'push') && fromJSON('["head"]') || fromJSON('["head", "base"]') }} exclude: @@ -29,8 +29,6 @@ jobs: pnl-version: 'base' - os: windows-latest pnl-version: 'base' - - python-version: '3.7' - pnl-version: 'base' - python-version: '3.8' pnl-version: 'base' - python-version: '3.9' @@ -40,14 +38,6 @@ jobs: - python-version: '3.12' pnl-version: 'base' - # Python 3.7 x64 on macos-14 (arm64) images is broken [0] - # and arm64 version is not available [1]. - # Restrict python 3.7 macos runs to macos-13 - # [0] https://github.com/actions/setup-python/issues/855 - # [1] https://github.com/actions/setup-python/issues/856 - - python-version: '3.7' - os: macos-latest - outputs: on_master: ${{ steps.on_master.outputs.on-branch }} @@ -80,9 +70,7 @@ jobs: - name: Set up Python ${{ matrix.python-version }} uses: actions/setup-python@v5 with: - # Block python3.7.17 on macos. see: - # https://github.com/actions/setup-python/issues/682 - python-version: ${{ (matrix.os == 'macos-latest' && matrix.python-version == '3.7') && '3.7.16' || matrix.python-version }} + python-version: ${{ matrix.python-version }} - name: Get pip cache location shell: bash diff --git a/.github/workflows/pnl-ci.yml b/.github/workflows/pnl-ci.yml index fd8c5517be..7576dba7d2 100644 --- a/.github/workflows/pnl-ci.yml +++ b/.github/workflows/pnl-ci.yml @@ -33,7 +33,7 @@ jobs: strategy: fail-fast: false matrix: - python-version: ['3.7', '3.11', '3.12'] + python-version: ['3.8', '3.11', '3.12'] python-architecture: ['x64'] extra-args: [''] os: [ubuntu, macos, windows] @@ -51,7 +51,7 @@ jobs: extra-args: '--forked -m "not llvm"' # add 32-bit build on windows - - python-version: '3.8' + - python-version: '3.9' python-architecture: 'x86' os: windows @@ -70,22 +70,18 @@ jobs: # https://github.com/ionelmc/pytest-benchmark/issues/243 extra-args: '-m benchmark --benchmark-enable --benchmark-only --benchmark-min-rounds=2 --benchmark-max-time=0.001 --benchmark-warmup=off -n0 --dist=no' - # add python 3.7 with deps restricted to min supported version - - python-version: '3.7' - python-architecture: 'x64' - os: ubuntu - version-restrict: 'min' - - # add python 3.8 build on macos since 3.7 is broken - # https://github.com/actions/virtual-environments/issues/4230 - # use default python-architecture + # add python 3.8 with deps restricted to min supported version + # use default python architecture + # https://github.com/actions/setup-python/issues/960 - python-version: '3.8' os: macos + version-restrict: 'min' exclude: - # 3.7 is broken on macos-11, - # https://github.com/actions/virtual-environments/issues/4230 - - python-version: '3.7' + # 3.8/x64 python is broken on aarch64 macos runners + # https://github.com/actions/setup-python/issues/960 + - python-version: '3.8' + python-architecture: 'x64' os: macos steps: @@ -112,7 +108,8 @@ jobs: if: ${{ matrix.version-restrict == 'min' }} shell: bash run: | - sed -i '/^[^#]/s/>=/==/' *requirements.txt + # macos/bsd sed requires backup suffix argument to -i + sed -i=.bak -e '/^[^#]/s/>=/==/' *requirements.txt git config user.name "github actions" git config user.email "none" git commit -a -m "Restrict version of direct dependencies to min" diff --git a/.github/workflows/test-release.yml b/.github/workflows/test-release.yml index 2f21bba3b5..7486c9e160 100644 --- a/.github/workflows/test-release.yml +++ b/.github/workflows/test-release.yml @@ -69,14 +69,9 @@ jobs: strategy: fail-fast: false matrix: - python-version: [3.7, 3.8, 3.9, '3.10', 3.11, 3.12] + python-version: ['3.8', '3.9', '3.10', '3.11', '3.12'] os: [ubuntu-latest, macos-latest, windows-latest] dist: [wheel, sdist] - exclude: - # 3.7 is broken on macos-11, - # https://github.com/actions/virtual-environments/issues/4230 - - python-version: '3.7' - os: macos-latest runs-on: ${{ matrix.os }} needs: [create-python-dist] From c3b163c5dcd48fbc537080979c35a247f7e712b7 Mon Sep 17 00:00:00 2001 From: Jan Vesely Date: Thu, 17 Oct 2024 11:53:59 -0400 Subject: [PATCH 5/5] setup: Drop support for Python3.7 Signed-off-by: Jan Vesely --- setup.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/setup.py b/setup.py index f382ef5477..3605637c94 100644 --- a/setup.py +++ b/setup.py @@ -57,7 +57,6 @@ def get_requirements(require_name=None): # Supported Python Versions 'Programming Language :: Python :: 3', - 'Programming Language :: Python :: 3.7', 'Programming Language :: Python :: 3.8', 'Programming Language :: Python :: 3.9', 'Programming Language :: Python :: 3.10', @@ -66,7 +65,7 @@ def get_requirements(require_name=None): ], # Require recent python - python_requires=">=3.7", + python_requires=">=3.8", # What does your project relate to? keywords='cognitive modeling',