From 5a88160ad5de4b5cd782b014c29d20afb1268a42 Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Thu, 7 Nov 2024 17:12:31 +0100 Subject: [PATCH 1/3] Add runtime type checking in CI tests This should prevent TYPE_CHECKING misuse. It might also found issues not found by static type checking, typically by the current MyPy. Make it optional for now, while we fix issues. --- .github/workflows/ci-additional.yaml | 41 ++++++++++++++++++++++++++++ ci/requirements/environment.yml | 1 + pyproject.toml | 1 + 3 files changed, 43 insertions(+) diff --git a/.github/workflows/ci-additional.yaml b/.github/workflows/ci-additional.yaml index 96eca004521..32940b89f2b 100644 --- a/.github/workflows/ci-additional.yaml +++ b/.github/workflows/ci-additional.yaml @@ -80,6 +80,47 @@ jobs: # `xarray/tests/__init__.py`. python -m pytest --doctest-modules xarray --ignore xarray/tests -Werror + beartype: + name: beartype + runs-on: "ubuntu-latest" + needs: detect-ci-trigger + defaults: + run: + shell: bash -l {0} + env: + CONDA_ENV_FILE: ci/requirements/environment.yml + PYTHON_VERSION: "3.12" + + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 # Fetch all history for all branches and tags. + + - name: set environment variables + run: | + echo "TODAY=$(date +'%Y-%m-%d')" >> $GITHUB_ENV + - name: Setup micromamba + uses: mamba-org/setup-micromamba@v2 + with: + micromamba-version: ${{env.MICROMAMBA_VERSION}} + environment-file: ${{env.CONDA_ENV_FILE}} + environment-name: xarray-tests + create-args: >- + python=${{env.PYTHON_VERSION}} + cache-environment: true + cache-environment-key: "${{runner.os}}-${{runner.arch}}-py${{env.PYTHON_VERSION}}-${{env.TODAY}}-${{hashFiles(env.CONDA_ENV_FILE)}}" + - name: Install xarray + run: | + python -m pip install --no-deps -e . + - name: Version info + run: | + python xarray/util/print_versions.py + + - name: Run beartype + continue-on-error: true + run: | + python -m pytest --beartype-packages=xarray + mypy: name: Mypy runs-on: "ubuntu-latest" diff --git a/ci/requirements/environment.yml b/ci/requirements/environment.yml index 364ae03666f..8a79e966ed7 100644 --- a/ci/requirements/environment.yml +++ b/ci/requirements/environment.yml @@ -38,6 +38,7 @@ dependencies: - pydap - pydap-server - pytest + - pytest-beartype - pytest-cov - pytest-env - pytest-xdist diff --git a/pyproject.toml b/pyproject.toml index fd4a4293882..175f90924ee 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -41,6 +41,7 @@ dev = [ "mypy", "pre-commit", "pytest", + "pytest-beartype", "pytest-cov", "pytest-env", "pytest-xdist", From 05ad413d394a74d03de3be9968f606aadeca97be Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Fri, 3 Jan 2025 20:33:02 +0100 Subject: [PATCH 2/3] Avoid PEP 585 and PEP 604 rewrites This setting is only applicable when the target Python version is below 3.9 and 3.10 respectively. --- pyproject.toml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/pyproject.toml b/pyproject.toml index 175f90924ee..e3c101765ba 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -291,6 +291,9 @@ ban-relative-imports = "all" [tool.pytest.ini_options] addopts = ["--strict-config", "--strict-markers"] +[lint.pyupgrade] +keep-runtime-typing = true + # We want to forbid warnings from within xarray in our tests — instead we should # fix our own code, or mark the test itself as expecting a warning. So this: # - Converts any warning from xarray into an error From 1cdc2c40c798fb4de349e144a282559740f96bcc Mon Sep 17 00:00:00 2001 From: Dimitri Papadopoulos <3234522+DimitriPapadopoulos@users.noreply.github.com> Date: Sun, 10 Nov 2024 14:39:27 +0100 Subject: [PATCH 3/3] TESTING --- xarray/core/dataset.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/xarray/core/dataset.py b/xarray/core/dataset.py index d6ffa7308a3..f3b4e34e1b3 100644 --- a/xarray/core/dataset.py +++ b/xarray/core/dataset.py @@ -468,7 +468,7 @@ def merge_data_and_coords(data_vars: DataVars, coords) -> _MergeResult: ) -class DataVariables(Mapping[Any, "DataArray"]): +class DataVariables(Mapping[Any, "xarray.DataArray"]): __slots__ = ("_dataset",) def __init__(self, dataset: Dataset): @@ -550,7 +550,7 @@ class Dataset( DataWithCoords, DatasetAggregations, DatasetArithmetic, - Mapping[Hashable, "DataArray"], + Mapping[Hashable, "xarray.DataArray"], ): """A multi-dimensional, in memory, array database.