From fc7b615b726476a898918d99c292610f10a9e9c0 Mon Sep 17 00:00:00 2001 From: Vincent Wieland Date: Fri, 3 May 2024 10:03:54 +0200 Subject: [PATCH] Require and test python >=3.10 according to NEP 29 (#1379) * Update setup.cfg Remove python 3.9 * Update ci.yml Remove python 3.9 and update to 3.11 * Update deploy.yml Change python 3.9 by 3.11 * Update ci.yml Add python 3.10 * Update setup.cfg Add python 3.12 * Update ci.yml Update from python 3.11 to 3.12 * Update deploy.yml Update from python 3.11 to 3.12 * Skip aesara tests on case of python >= 3.12 and use 3.11 for building the documentation. * Update test/base/test_objective.py Co-authored-by: Daniel Weindl * Update .github/workflows/ci.yml --------- Co-authored-by: PaulJonasJost Co-authored-by: Daniel Weindl --- .github/workflows/ci.yml | 23 +++++++++++------------ .github/workflows/deploy.yml | 2 +- setup.cfg | 4 ++-- test/base/test_objective.py | 7 +++++++ 4 files changed, 21 insertions(+), 15 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 75a91fccb..29869655c 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -24,7 +24,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9', '3.11'] + python-version: ['3.10', '3.12'] steps: - name: Check out repository @@ -63,7 +63,7 @@ jobs: runs-on: macos-latest strategy: matrix: - python-version: ['3.11'] + python-version: ['3.12'] steps: - name: Check out repository @@ -99,7 +99,7 @@ jobs: runs-on: windows-latest strategy: matrix: - python-version: ['3.11'] + python-version: ['3.12'] steps: - name: Check out repository @@ -132,7 +132,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9', '3.11'] + python-version: ['3.10', '3.12'] steps: - name: Check out repository @@ -171,7 +171,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9', '3.11'] + python-version: ['3.10', '3.12'] # needed to allow julia-actions/cache to delete old caches that it has created permissions: @@ -225,8 +225,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - # ipopt does not work on 3.9 (https://github.com/mechmotum/cyipopt/issues/225) - python-version: ['3.11'] + python-version: ['3.12'] steps: - name: Check out repository @@ -262,7 +261,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9', '3.11'] + python-version: ['3.10', '3.12'] steps: - name: Check out repository @@ -298,7 +297,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9', '3.11'] + python-version: ['3.10', '3.12'] steps: - name: Check out repository @@ -334,7 +333,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.11'] + python-version: ['3.12'] steps: - name: Check out repository @@ -399,7 +398,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9'] + python-version: ['3.10'] steps: - name: Check out repository @@ -429,7 +428,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9'] + python-version: ['3.10'] steps: - name: Check out repository diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index 4cb46a6e3..e1ed397bb 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -9,7 +9,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - python-version: ['3.9'] + python-version: ['3.12'] steps: - name: Check out repository diff --git a/setup.cfg b/setup.cfg index e5d201411..4d94bb3b7 100644 --- a/setup.cfg +++ b/setup.cfg @@ -33,9 +33,9 @@ classifiers = License :: OSI Approved :: BSD License Operating System :: OS Independent Programming Language :: Python + Programming Language :: Python :: 3.12 Programming Language :: Python :: 3.11 Programming Language :: Python :: 3.10 - Programming Language :: Python :: 3.9 keywords = parameter inference optimization @@ -58,7 +58,7 @@ install_requires = tqdm >= 4.46.0 tabulate >= 0.8.10 -python_requires = >=3.9 +python_requires = >=3.10 include_package_data = True # Where is my code diff --git a/test/base/test_objective.py b/test/base/test_objective.py index d2c556927..998a1f0af 100644 --- a/test/base/test_objective.py +++ b/test/base/test_objective.py @@ -2,6 +2,7 @@ import copy import numbers +import sys from functools import partial import numpy as np @@ -12,6 +13,11 @@ from ..util import CRProblem, poly_for_sensi, rosen_for_sensi +pytest_skip_aesara = pytest.mark.skipif( + sys.version_info >= (3, 12), + reason="Skipped Aesara tests on Python 3.12 or higher", +) + @pytest.fixture(params=[True, False]) def integrated(request): @@ -178,6 +184,7 @@ def rel_err(eps_): ) +@pytest_skip_aesara def test_aesara(max_sensi_order, integrated): """Test function composition and gradient computation via aesara""" import aesara.tensor as aet