From df397ff8735cf25c1175e435f253be717ed2aa0f Mon Sep 17 00:00:00 2001 From: "Lori A. Burns" Date: Fri, 20 Oct 2023 17:16:53 -0400 Subject: [PATCH 1/5] Update CI.yaml --- .github/workflows/CI.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/CI.yaml b/.github/workflows/CI.yaml index 2aaf0082..4e5465f0 100644 --- a/.github/workflows/CI.yaml +++ b/.github/workflows/CI.yaml @@ -8,7 +8,7 @@ on: jobs: test: - runs-on: ubuntu-latest + runs-on: [ ubuntu-latest, windows-latest ] strategy: fail-fast: false matrix: From e97955fe9607e74dfaef1026352d42bdcdabeda1 Mon Sep 17 00:00:00 2001 From: "Lori A. Burns" Date: Fri, 20 Oct 2023 17:19:54 -0400 Subject: [PATCH 2/5] Update CI.yaml --- .github/workflows/CI.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/CI.yaml b/.github/workflows/CI.yaml index 4e5465f0..9a923f36 100644 --- a/.github/workflows/CI.yaml +++ b/.github/workflows/CI.yaml @@ -8,7 +8,7 @@ on: jobs: test: - runs-on: [ ubuntu-latest, windows-latest ] + runs-on: windows-latest strategy: fail-fast: false matrix: From eeec9e41520795fd4d38702d6c7c78ad4ea6a675 Mon Sep 17 00:00:00 2001 From: "Lori A. Burns" Date: Mon, 23 Oct 2023 12:37:12 -0400 Subject: [PATCH 3/5] stuff --- .github/workflows/CI.yaml | 13 +++++++++++-- qcelemental/tests/test_importing.py | 2 +- qcelemental/util/importing.py | 5 +++++ 3 files changed, 17 insertions(+), 3 deletions(-) diff --git a/.github/workflows/CI.yaml b/.github/workflows/CI.yaml index 9a923f36..b8906222 100644 --- a/.github/workflows/CI.yaml +++ b/.github/workflows/CI.yaml @@ -5,15 +5,24 @@ on: branches: - master pull_request: + branches: + - master + schedule: + - cron: "9 16 * * 1" jobs: test: - runs-on: windows-latest strategy: fail-fast: false matrix: python-version: ["3.7", "3.9", "3.11", "3.12"] pydantic-version: ["1", "2"] + runs-on: [ubuntu-latest, windows-latest] + exclude: + - runs-on: windows-latest + pydantic-version: "1" + name: "🐍 ${{ matrix.python-version }} • ${{ matrix.pydantic-version }} • ${{ matrix.runs-on }}" + runs-on: ${{ matrix.runs-on }} steps: - name: Set up Python ${{ matrix.python-version }} @@ -30,9 +39,9 @@ jobs: # ^ start of line, pydantic, optional spaces and > sign, capture the version, replace with ^{version} # Should avoid also replacing the autodoc-pydantic spec later on. - name: Sed replace pydantic on repo + if: matrix.pydantic-version == '1' run: | sed -i 's/^pydantic *= *">*= *\([0-9.]*\)"/pydantic = "^\1"/' pyproject.toml - if: matrix.pydantic-version == '1' - name: Install repo with poetry (full deps) if: matrix.python-version != '3.9' run: poetry install --no-interaction --no-ansi --all-extras diff --git a/qcelemental/tests/test_importing.py b/qcelemental/tests/test_importing.py index 7bfcda97..2caed79c 100644 --- a/qcelemental/tests/test_importing.py +++ b/qcelemental/tests/test_importing.py @@ -117,7 +117,7 @@ def test_which_import_f_raisemsg_submodule(): def test_which_t(): ans = qcel.util.which("ls") - assert ans.split(os.path.sep)[-1] == "ls" + assert ans.split(os.path.sep)[-1] in ["ls", "ls.EXE"] def test_which_t_bool(): diff --git a/qcelemental/util/importing.py b/qcelemental/util/importing.py index 8daaf264..009f6631 100644 --- a/qcelemental/util/importing.py +++ b/qcelemental/util/importing.py @@ -99,6 +99,11 @@ def which( lenv = {"PATH": os.pathsep.join([os.path.abspath(x) for x in env.split(os.pathsep) if x != ""])} lenv = {k: v for k, v in lenv.items() if v is not None} + if sys.platform == "win32" and sys.version_info >= (3, 12, 0) and sys.version_info < (3, 12, 1): + # https://github.com/python/cpython/issues/109590 + if command == "psi4": + command = "psi4.bat" + ans = shutil.which(command, mode=os.F_OK | os.X_OK, path=lenv["PATH"]) # secondary check, see https://github.com/MolSSI/QCEngine/issues/292 From 01fcdb9b0543b5f787102d09b100ed44a02e8742 Mon Sep 17 00:00:00 2001 From: "Lori A. Burns" Date: Mon, 23 Oct 2023 12:46:30 -0400 Subject: [PATCH 4/5] update docs py --- .github/workflows/CI.yaml | 2 +- docs/changelog.rst | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/CI.yaml b/.github/workflows/CI.yaml index b8906222..f6dad230 100644 --- a/.github/workflows/CI.yaml +++ b/.github/workflows/CI.yaml @@ -71,7 +71,7 @@ jobs: - uses: actions/setup-python@v4 name: Set up Python with: - python-version: "3.7" + python-version: "3.10" - name: Install poetry run: pip install poetry # Force pydantic 1.0 by modifying poetry dep "pydantic" string with in-place sed (see above for details) diff --git a/docs/changelog.rst b/docs/changelog.rst index 789bb35b..00aa664a 100644 --- a/docs/changelog.rst +++ b/docs/changelog.rst @@ -40,11 +40,13 @@ Bug Fixes - (:pr:`325`, :issue:`324`) Ensure ``util.measure_coordinates`` isn't returning NaN angles just because floating-point errors are outside arccos's ``[-1, 1]`` bounds. - (:pr:`315`) Stop resetting numpy print formatting. +- (:pr:`328`) TODO Misc. +++++ - (:pr:`320`) Reset ``black`` formatting to 2022. - (:pr:`327`) Enable Python v3.12 in poetry. +- (:pr:`328`) Test on Windows. 0.26.0 / 2023-07-31 From b96978fe3a0815f02013013d3c29167c961168ad Mon Sep 17 00:00:00 2001 From: "Lori A. Burns" Date: Mon, 23 Oct 2023 19:02:22 -0400 Subject: [PATCH 5/5] docs --- docs/changelog.rst | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/docs/changelog.rst b/docs/changelog.rst index 00aa664a..b85044ab 100644 --- a/docs/changelog.rst +++ b/docs/changelog.rst @@ -20,7 +20,7 @@ Changelog .. +++++ -Unreleased +0.27.0 / 2023-10-DD (Unreleased) ------------------- Breaking Changes @@ -40,13 +40,15 @@ Bug Fixes - (:pr:`325`, :issue:`324`) Ensure ``util.measure_coordinates`` isn't returning NaN angles just because floating-point errors are outside arccos's ``[-1, 1]`` bounds. - (:pr:`315`) Stop resetting numpy print formatting. -- (:pr:`328`) TODO +- (:pr:`328`) Add workaround for only python v3.12.0 and psi4 (can be expanded) to handle + ``util.which`` on Windows when a cmd (non-executable) and a cmd. live + side-by-side. Otherwise see ``[WinError 193] %1 is not a valid Win32 application``. Misc. +++++ - (:pr:`320`) Reset ``black`` formatting to 2022. - (:pr:`327`) Enable Python v3.12 in poetry. -- (:pr:`328`) Test on Windows. +- (:pr:`328`) Start Windows testing and cron testing. 0.26.0 / 2023-07-31