diff --git a/.github/workflows/python-app.yml b/.github/workflows/python-app.yml index 2197daa8..7a5e5914 100644 --- a/.github/workflows/python-app.yml +++ b/.github/workflows/python-app.yml @@ -5,7 +5,7 @@ name: Python application on: push: - branches: ["main"] + branches: ["**"] pull_request: branches: ["main"] @@ -37,4 +37,15 @@ jobs: - name: Rye activation run: | rye sync - rye run pytest tests + + - name: test with rye + run: rye run pytest -vv --color=yes --cov=./ --cov-report=xml + + - uses: codecov/codecov-action@v4 + with: + fail_ci_if_error: true # optional (default = false) + files: ./coverage.xml + flags: unittests # optional + name: codecov-umbrella # optional + token: ${{ secrets.CODECOV_TOKEN }} # required + verbose: true # optional (default = false) diff --git a/.github/workflows/ruff.yml b/.github/workflows/ruff.yml index 9c7e174f..44c6e5bd 100644 --- a/.github/workflows/ruff.yml +++ b/.github/workflows/ruff.yml @@ -9,4 +9,5 @@ jobs: - uses: actions/checkout@v4 - uses: chartboost/ruff-action@v1 with: + src: "./src" python-version: "3.11" diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml deleted file mode 100644 index 1e3fdfa7..00000000 --- a/.github/workflows/test.yml +++ /dev/null @@ -1,53 +0,0 @@ -name: Run Tests - -on: - push: - branches: - - main - pull_request: - branches: "**" - -jobs: - test: - runs-on: ubuntu-latest - - strategy: - max-parallel: 5 - - steps: - - uses: actions/checkout@v3 - - - name: Set up Python - uses: actions/setup-python@v4 - with: - python-version: "3.11" - - - name: Get pip cache dir - id: pip-cache - run: | - # echo "::set-output name=dir::$(pip cache dir)" - echo "dir=$(pip cache dir)" >> $GITHUB_OUTPUT - - - name: Cache PyPI modules - uses: actions/cache@v3 - env: - cache-name: cache-pypi - with: - path: | - ${{ steps.pip-cache.outputs.dir }} - key: ${{ runner.os }}-build-${{ env.cache-name}}-${{ hashFiles('**/environment*.yml') }} - - - name: Source environment, test with pytest and generate coverage - run: | - echo "Now running tests" - python -m pytest -c pytest-config/pytest-coverage-codecov.ini - - - name: Upload coverage to Codecov - uses: codecov/codecov-action@v3 - with: - token: ${{ secrets.CODECOV_TOKEN }} - files: ./coverage.xml - flags: unittests - env_vars: OS,PYTHON - fail_ci_if_error: true - verbose: true diff --git a/README.rst b/README.rst index e30fde1a..0a8fa9a3 100644 --- a/README.rst +++ b/README.rst @@ -12,10 +12,8 @@ .. |docs_status| image:: https://readthedocs.org/projects/arpes-v4/badge/?version=daredevil&style=flat :target: https://arpes-v4.readthedocs.io/en/daredevil/ -.. |coverage| image:: https://codecov.io/gh/chstan/arpes/branch/master/graph/badge.svg?token=mVrFuVRr3p +.. |coverage| image:: https://codecov.io/gh/arafune/arpes/graph/badge.svg?token=TW9EPVB1VE :target: https://app.codecov.io/gh/arafune/arpes -.. |test_status| image:: https://github.com/arafune/arpes/actions/workflows/test.yml/badge.svg?branch=master - :target: https://github.com/arafune/arpes/actions/workflows/test.yml .. |code style| image:: https://img.shields.io/badge/code%20style-black-000000.svg :target: https://github.com/psf/black .. |code fromat| image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json diff --git a/docs/source/CHANGELOG.rst b/docs/source/CHANGELOG.rst index 60e796bf..6ba915ea 100644 --- a/docs/source/CHANGELOG.rst +++ b/docs/source/CHANGELOG.rst @@ -9,11 +9,7 @@ Primary (X.-.-) version numbers are used to denote backwards incompatibilities between versions, while minor (-.X.-) numbers primarily indicate new features and documentation. -4.0.1 () - -New -~~~ - +4.0.1 (2024-07-21) Changed diff --git a/pyproject.toml b/pyproject.toml index fae84c0e..f0b44f6e 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -10,28 +10,28 @@ readme = "README.rst" requires-python = ">= 3.11" dependencies = [ - "holoviews>=1.16.0", - "astropy>=6.1", - "xarray>=2023.9.0", - "lmfit>=1.3.1", - "matplotlib>=3.8.0", - "pint>=0.22", - "h5py>=3.11.0", - "ase>=3.23.0", - "dill>=0.3.6", - "tqdm>=4.65.0", - "numba>=0.57.1", - "scikit-learn>=1.4.2", - "scikit-image>=0.20.0", - "netcdf4>=1.6.4", - "rx>=3.2.0", - "jupyter_server>=2.8", - "hvplot>=0.10", - "ipywidgets", - "ipykernel", - "more-itertools>=10.2.0", - "igorpy @ git+https://github.com/arafune/igorpy.git", - "titlecase>=2.4.1", + "holoviews>=1.16.0", + "astropy>=6.1", + "xarray>=2023.9.0", + "lmfit>=1.3.1", + "matplotlib>=3.8.0", + "pint>=0.22", + "h5py>=3.11.0", + "ase>=3.23.0", + "dill>=0.3.6", + "tqdm>=4.65.0", + "numba>=0.57.1", + "scikit-learn>=1.4.2", + "scikit-image>=0.20.0", + "rx>=3.2.0", + "jupyter_server>=2.8", + "hvplot>=0.10", + "ipywidgets", + "ipykernel", + "more-itertools>=10.2.0", + "igorpy @ git+https://github.com/arafune/igorpy.git", + "titlecase>=2.4.1", + "h5netcdf>=1.3.0", ] [build-system] diff --git a/src/arpes/__init__.py b/src/arpes/__init__.py index d1c2974a..1b5d2fa4 100644 --- a/src/arpes/__init__.py +++ b/src/arpes/__init__.py @@ -9,7 +9,7 @@ if TYPE_CHECKING: from ._typing import ConfigSettings, ConfigType # Use both version conventions for people's sanity. -VERSION = "4.0.0" +VERSION = "4.0.1" __version__ = VERSION diff --git a/src/arpes/endstations/plugin/example_data.py b/src/arpes/endstations/plugin/example_data.py index da67d5a6..159ccddf 100644 --- a/src/arpes/endstations/plugin/example_data.py +++ b/src/arpes/endstations/plugin/example_data.py @@ -9,7 +9,6 @@ from __future__ import annotations -import warnings from logging import DEBUG, INFO, Formatter, StreamHandler, getLogger from typing import TYPE_CHECKING, ClassVar @@ -75,9 +74,6 @@ def load_single_frame( # Wrap into a dataset dataset = xr.Dataset({"spectrum": data}) - warnings.warn( - 'loaded data has not corrected by "offsets". You may need "S.apply_offsets"', - stacklevel=2, - ) + dataset.S.apply_offsets(data.S.offsets) return dataset diff --git a/src/arpes/xarray_extensions.py b/src/arpes/xarray_extensions.py index 8cb37a65..50cbc0ce 100644 --- a/src/arpes/xarray_extensions.py +++ b/src/arpes/xarray_extensions.py @@ -2937,7 +2937,7 @@ def map( """ return apply_dataarray(self._obj, np.vectorize(fn, **kwargs)) - def shift_by( # noqa: PLR0913 + def shift_by( self, other: xr.DataArray | NDArray[np.float64], shift_axis: str = "", @@ -3098,7 +3098,7 @@ def max_in_window( return destination - def first_exceeding( # noqa: PLR0913 + def first_exceeding( self, dim: str, value: float, diff --git a/tests/conftest.py b/tests/conftest.py index 4f13dbda..bc8d3a86 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -6,17 +6,18 @@ from pathlib import Path from typing import TYPE_CHECKING, TypedDict +import pytest + import arpes.config import arpes.endstations -import pytest from arpes.io import example_data - from tests.utils import cache_loader if TYPE_CHECKING: from collections.abc import Callable, Iterator import xarray as xr + from arpes._typing import ScanInfo, WorkSpaceType diff --git a/tests/test_basic_data_loading.py b/tests/test_basic_data_loading.py index 4c4321d4..d4b5bddb 100644 --- a/tests/test_basic_data_loading.py +++ b/tests/test_basic_data_loading.py @@ -5,10 +5,11 @@ import contextlib from typing import TYPE_CHECKING, Any, ClassVar -import arpes.xarray_extensions # pylint: disable=unused-import, redefined-outer-name # noqa: F401 import numpy as np import pytest import xarray as xr + +import arpes.xarray_extensions # pylint: disable=unused-import, redefined-outer-name # noqa: F401 from arpes.utilities.conversion import convert_to_kspace if TYPE_CHECKING: diff --git a/tests/test_bz_spec.py b/tests/test_bz_spec.py index 89dc06ab..c1c116a6 100644 --- a/tests/test_bz_spec.py +++ b/tests/test_bz_spec.py @@ -2,6 +2,7 @@ import numpy as np import pytest + from arpes.utilities import bz_spec diff --git a/tests/test_curve_fitting.py b/tests/test_curve_fitting.py index 20ba9f4b..64f213d4 100644 --- a/tests/test_curve_fitting.py +++ b/tests/test_curve_fitting.py @@ -2,23 +2,29 @@ import numpy as np import xarray as xr + from arpes.analysis import rebin from arpes.fits import AffineBroadenedFD, LorentzianModel, broadcast_model from arpes.fits.utilities import parse_model -TOLERANCE = 2e-3 +RTOL = 5e-2 # 5 % +TOLERANCE = 1e-2 def test_parse_model() -> None: """Test parse_model.""" assert parse_model(AffineBroadenedFD) == AffineBroadenedFD - assert parse_model((AffineBroadenedFD, LorentzianModel)) == (AffineBroadenedFD, LorentzianModel) assert parse_model([AffineBroadenedFD, LorentzianModel]) == [AffineBroadenedFD, LorentzianModel] assert parse_model("AffineBroadenedFD + LorentzianModel") == [ AffineBroadenedFD, "+", LorentzianModel, ] + assert parse_model("AffineBroadenedFD * LorentzianModel") == [ + AffineBroadenedFD, + "*", + LorentzianModel, + ] def test_broadcast_fitting(dataarray_cut: xr.DataArray) -> None: @@ -30,40 +36,55 @@ def test_broadcast_fitting(dataarray_cut: xr.DataArray) -> None: [AffineBroadenedFD], near_ef_rebin, "phi", + prefixes=("a_",), + params={ + "a_center": {"value": 0.0, "vary": True, "min": -0.1}, + "a_width": {"value": 0.1}, + "a_lin_bkg": {"value": 20000, "max": 30000, "min": 10000}, + }, progress=False, ) a_band_data = fit_results.results.F.bands["a_"] - np.testing.assert_almost_equal( + np.testing.assert_allclose( a_band_data.center.values, np.array( [ - -0.00456955, - -0.00217572, - -0.00268341, - -0.02043154, - -0.00331786, - -0.00397203, - -0.00390515, - -0.0198554, + -0.03744157, + -0.03853184, + -0.035255, + -0.04542634, + -0.04720573, + -0.0463577, + -0.04804507, + -0.03251984, ], ), + rtol=RTOL, # TODO: [RA] Consider why this value strongly depends on the platform. ) - np.testing.assert_almost_equal( + np.testing.assert_allclose( actual=a_band_data.sigma, desired=np.array((np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan)), ) - np.testing.assert_almost_equal( + np.testing.assert_allclose( actual=a_band_data.amplitude, desired=np.array((np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan)), ) - assert np.abs(fit_results.results.F.p("a_center").mean().item() + 0.00761) < TOLERANCE + assert ( + np.abs(fit_results.results.F.p("a_center").mean().item() + 0.04134788683594517) < TOLERANCE + ) fit_results = broadcast_model( [AffineBroadenedFD], near_ef_rebin, "phi", parallelize=True, + prefixes=("a_",), + params={ + "a_center": {"value": 0.0, "vary": True, "min": -0.1}, + "a_width": {"value": 0.1}, + "a_lin_bkg": {"value": 20000, "max": 30000, "min": 10000}, + }, progress=True, ) assert fit_results.results.F.parameter_names == { @@ -77,35 +98,37 @@ def test_broadcast_fitting(dataarray_cut: xr.DataArray) -> None: assert fit_results.results.F.band_names == {"a_"} assert fit_results.F.fit_dimensions == ["eV"] - np.testing.assert_almost_equal( + np.testing.assert_allclose( fit_results.results.F.mean_square_error().values, np.array( [ - 1558314.8960161, - 1511851.0381156, - 1458591.605262, - 457007.0366379, - 1279915.8356443, - 1319729.3599192, - 1229990.7381464, - 403335.4076894, + 13769.07645062, + 15927.48553538, + 13030.76068365, + 11847.62221047, + 9828.60331845, + 16164.81630826, + 12844.01730529, + 11887.61788115, ], ), + rtol=RTOL, ) params_ = fit_results.results.F.param_as_dataset("a_conv_width") - np.testing.assert_almost_equal( + np.testing.assert_allclose( params_["value"].values, np.array( [ - 2.8879836, - 0.7276058, - 3.0653718, - 0.1415692, - 3.2048873, - 3.3533791, - 3.0634597, - 0.1502903, + 0.02348614, + 0.02656286, + 0.02529021, + 0.01889499, + 0.01715083, + 0.01831382, + 0.02238334, + 0.02063916, ], ), + rtol=RTOL, ) diff --git a/tests/test_derivative_analysis.py b/tests/test_derivative_analysis.py index 70176608..4ba12588 100644 --- a/tests/test_derivative_analysis.py +++ b/tests/test_derivative_analysis.py @@ -6,6 +6,7 @@ import numpy as np import pytest + from arpes.analysis import ( curvature1d, curvature2d, diff --git a/tests/test_direct_and_example_data_loading.py b/tests/test_direct_and_example_data_loading.py index fa35f3b7..81e8843d 100644 --- a/tests/test_direct_and_example_data_loading.py +++ b/tests/test_direct_and_example_data_loading.py @@ -6,6 +6,7 @@ import numpy as np import xarray as xr + from arpes.endstations.plugin.ALG_main import ALGMainChamber from arpes.io import load_data, load_example_data diff --git a/tests/test_fits.py b/tests/test_fits.py index 52ca14f6..ff4f9534 100644 --- a/tests/test_fits.py +++ b/tests/test_fits.py @@ -6,9 +6,10 @@ import matplotlib.pyplot as plt import numpy as np import pytest -from arpes.plotting.fits import plot_fit, plot_fits from matplotlib.axes import Axes +from arpes.plotting.fits import plot_fit, plot_fits + @pytest.fixture() def mock_model_results() -> list[lf.model.ModelResult]: diff --git a/tests/test_generic_utilities.py b/tests/test_generic_utilities.py index 3d39ed85..671d4413 100644 --- a/tests/test_generic_utilities.py +++ b/tests/test_generic_utilities.py @@ -1,6 +1,7 @@ """Test for generic utility.""" import pytest + from arpes.utilities import clean_keys, deep_equals, deep_update diff --git a/tests/test_momentum_conversion.py b/tests/test_momentum_conversion.py index 0d5b332b..a2a41736 100644 --- a/tests/test_momentum_conversion.py +++ b/tests/test_momentum_conversion.py @@ -2,10 +2,11 @@ from typing import TYPE_CHECKING -import arpes.xarray_extensions # pylint: disable=unused-import, redefined-outer-name # noqa: F401 import numpy as np import pytest import xarray as xr + +import arpes.xarray_extensions # pylint: disable=unused-import, redefined-outer-name # noqa: F401 from arpes.utilities.conversion import convert_to_kspace from arpes.utilities.conversion.base import CoordinateConverter from arpes.utilities.conversion.forward import ( diff --git a/tests/test_momentum_conversion_forward.py b/tests/test_momentum_conversion_forward.py index d11a1630..07568f70 100644 --- a/tests/test_momentum_conversion_forward.py +++ b/tests/test_momentum_conversion_forward.py @@ -5,6 +5,7 @@ import numpy as np import pytest import xarray as xr + from arpes.fits.fit_models import AffineBroadenedFD, QuadraticModel from arpes.fits.utilities import broadcast_model from arpes.utilities.conversion.forward import ( @@ -16,6 +17,8 @@ if TYPE_CHECKING: from collections.abc import Hashable +RTOL = 1e-2 + @pytest.fixture() def energy_corrected(dataarray_map: xr.DataArray) -> xr.DataArray: @@ -45,9 +48,10 @@ def test_convert_through_angular_point(energy_corrected: xr.DataArray) -> None: {"ky": np.linspace(-1, 1, 400)}, {"kx": np.linspace(-0.02, 0.02, 10)}, ).sel(eV=0, method="nearest") - np.testing.assert_almost_equal( + np.testing.assert_allclose( cut.values[-5:], np.array([2153.6281264, 2145.0536287, 2136.4768379, 2133.0278227, 2140.2402017]), + rtol=RTOL, ) @@ -77,7 +81,8 @@ def test_convert_through_angular_pair(energy_corrected: xr.DataArray) -> None: {"kx": np.linspace(-0, 0, 400)}, # interpolate from p1 to p2 only {"ky": np.linspace(-0.02, 0.02, 10)}, # take 20 milli inv ang. perpendicular ) - np.testing.assert_almost_equal( + np.testing.assert_allclose( cut.sel(eV=0.0, method="nearest").values[:5], np.array([2593.8578436, 2596.044673, 2597.7261315, 2599.1409414, 2600.387114]), + rtol=RTOL, ) diff --git a/tests/test_plot_with_holoviews.py b/tests/test_plot_with_holoviews.py index ca2e06eb..3d26d784 100644 --- a/tests/test_plot_with_holoviews.py +++ b/tests/test_plot_with_holoviews.py @@ -1,9 +1,10 @@ """Unit test for plotting/holoviews.py.""" import xarray as xr -from arpes.plotting import profile_view from holoviews.core.layout import AdjointLayout +from arpes.plotting import profile_view + class TestProfileView: """Class for profile_view function.""" diff --git a/tests/test_prodigy_itx.py b/tests/test_prodigy_itx.py index 1a104a8c..57bc1881 100644 --- a/tests/test_prodigy_itx.py +++ b/tests/test_prodigy_itx.py @@ -5,6 +5,7 @@ import numpy as np import pytest import xarray as xr + from arpes.endstations.prodigy_itx import ProdigyItx, load_sp2 data_dir = Path(__file__).parent.parent / "src" / "arpes" / "example_data" diff --git a/tests/test_prodigy_xy.py b/tests/test_prodigy_xy.py index 9e64543e..f17ccb2a 100644 --- a/tests/test_prodigy_xy.py +++ b/tests/test_prodigy_xy.py @@ -4,6 +4,7 @@ import numpy as np import pytest + from arpes.endstations.prodigy_xy import ProdigyXY data_dir = Path(__file__).parent.parent / "src" / "arpes" / "example_data" diff --git a/tests/test_stack_plot.py b/tests/test_stack_plot.py index 11e4b974..3061e57e 100644 --- a/tests/test_stack_plot.py +++ b/tests/test_stack_plot.py @@ -3,6 +3,7 @@ import numpy as np import pytest import xarray as xr + from arpes.plotting import stack_plot diff --git a/tests/test_xarray_extensions.py b/tests/test_xarray_extensions.py index 76465629..385821fd 100644 --- a/tests/test_xarray_extensions.py +++ b/tests/test_xarray_extensions.py @@ -3,6 +3,7 @@ import numpy as np import pytest import xarray as xr + from arpes.fits.fit_models import ( AffineBackgroundModel, AffineBroadenedFD, @@ -340,12 +341,13 @@ def test_G_shift( cut = fmap.sum("theta", keep_attrs=True).sel(eV=slice(-0.2, 0.1), phi=slice(-0.25, 0.3)) fit_results = broadcast_model(AffineBroadenedFD, cut, "phi") edge = QuadraticModel().guess_fit(fit_results.results.F.p("center")).eval(x=fmap.phi) - np.testing.assert_almost_equal( + np.testing.assert_allclose( actual=fmap.G.shift_by(edge, shift_axis="eV", by_axis="phi").sel( eV=0, method="nearest", )[:][0][:5], desired=np.array([5.625749, 566.8711542, 757.8334417, 637.2900199, 610.679927]), + rtol=1e-2, ) # # Taken from custom-dot-t-function diff --git a/tests/test_xps.py b/tests/test_xps.py index 38359f95..ed5b6b21 100644 --- a/tests/test_xps.py +++ b/tests/test_xps.py @@ -2,6 +2,7 @@ import numpy as np import xarray as xr + from arpes.analysis.xps import approximate_core_levels @@ -14,7 +15,7 @@ class TestXPS: def test_approximate_core_levels(self, dataarray_cut2: xr.DataArray) -> None: """Test for approximate_core_levels.""" energies = approximate_core_levels(dataarray_cut2.S.sum_other(["eV"])) - np.testing.assert_array_almost_equal( + np.testing.assert_allclose( energies, [9.36826347305, 9.58383233535, 9.89520958085], )