From 915f5bf84e108bba1d7041fbb057e7cc6d28cbd3 Mon Sep 17 00:00:00 2001 From: Marc Mueller <30130371+cdce8p@users.noreply.github.com> Date: Tue, 10 Oct 2023 12:43:12 +0200 Subject: [PATCH] Reset the threading.local _hass object every time (#101728) * Reset the threading.local _hass object every time * Remove reset from hass fixture --- tests/conftest.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/tests/conftest.py b/tests/conftest.py index c04b90d349ed30..09ad70bfcf1b42 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -376,6 +376,13 @@ def verify_cleanup( ) +@pytest.fixture(autouse=True) +def reset_hass_threading_local_object() -> Generator[None, None, None]: + """Reset the _Hass threading.local object for every test case.""" + yield + ha._hass.__dict__.clear() + + @pytest.fixture(autouse=True) def bcrypt_cost() -> Generator[None, None, None]: """Run with reduced rounds during tests, to speed up uses.""" @@ -559,9 +566,6 @@ def exc_handle(loop, context): # Restore timezone, it is set when creating the hass object dt_util.DEFAULT_TIME_ZONE = orig_tz - # Reset the _Hass threading.local object - ha._hass.__dict__.clear() - for ex in exceptions: if ( request.module.__name__,