RDW: Detected blocking call to listdir with args #121422
Closed
Description
The problem
Error in logfile with request to post this on GitHub.
“Detected blocking call to listdir with args” with the RDW integration
What version of Home Assistant Core has the issue?
2024.7.1
What was the last working version of Home Assistant Core?
2024.6.5
What type of installation are you running?
Home Assistant OS
Integration causing the issue
RDW
Link to integration documentation on our website
No response
Diagnostics information
Core 2024.7.1
Supervisor 2024.06.2
Operating System 12.4
Frontend 20240705.0
Example YAML snippet
No response
Anything in the logs that might be useful for us?
Logger: homeassistant.util.loop
Source: util/loop.py:136
First occurred: 08:28:49 (1 occurrences)
Last logged: 08:28:49
Detected blocking call to listdir with args ('/config/deps/lib/python3.12/site-packages',) inside the event loop by integration 'rdw' at homeassistant/components/rdw/__init__.py, line 30: await coordinator.async_config_entry_first_refresh() (offender: /usr/local/lib/python3.12/importlib/metadata/__init__.py, line 680: return os.listdir(self.root or '.')), please create a bug report at https://github.com/home-assistant/core/issues?q=is%3Aopen+is%3Aissue+label%3A%22integration%3A+rdw%22 For developers, please see https://developers.home-assistant.io/docs/asyncio_blocking_operations/#listdir Traceback (most recent call last): File "<frozen runpy>", line 198, in _run_module_as_main File "<frozen runpy>", line 88, in _run_code File "/usr/src/homeassistant/homeassistant/__main__.py", line 223, in <module> sys.exit(main()) File "/usr/src/homeassistant/homeassistant/__main__.py", line 209, in main exit_code = runner.run(runtime_conf) File "/usr/src/homeassistant/homeassistant/runner.py", line 190, in run return loop.run_until_complete(setup_and_run_hass(runtime_config)) File "/usr/local/lib/python3.12/asyncio/base_events.py", line 674, in run_until_complete self.run_forever() File "/usr/local/lib/python3.12/asyncio/base_events.py", line 641, in run_forever self._run_once() File "/usr/local/lib/python3.12/asyncio/base_events.py", line 1990, in _run_once handle._run() File "/usr/local/lib/python3.12/asyncio/events.py", line 88, in _run self._context.run(self._callback, *self._args) File "/usr/src/homeassistant/homeassistant/setup.py", line 167, in async_setup_component result = await _async_setup_component(hass, domain, config) File "/usr/src/homeassistant/homeassistant/setup.py", line 449, in _async_setup_component await asyncio.gather( File "/usr/src/homeassistant/homeassistant/setup.py", line 451, in <genexpr> create_eager_task( File "/usr/src/homeassistant/homeassistant/util/async_.py", line 37, in create_eager_task return Task(coro, loop=loop, name=name, eager_start=True) File "/usr/src/homeassistant/homeassistant/config_entries.py", line 734, in async_setup_locked await self.async_setup(hass, integration=integration) File "/usr/src/homeassistant/homeassistant/config_entries.py", line 586, in async_setup result = await component.async_setup_entry(hass, self) File "/usr/src/homeassistant/homeassistant/components/rdw/__init__.py", line 30, in async_setup_entry await coordinator.async_config_entry_first_refresh()
Additional information
Logger: homeassistant.util.loop
Source: util/loop.py:77
First occurred: 09:29:02 (1 occurrences)
Last logged: 09:29:02
Detected blocking call to listdir with args ('/config/deps/lib/python3.12/site-packages',) in /usr/local/lib/python3.12/importlib/metadata/__init__.py, line 680: return os.listdir(self.root or '.') inside the event loop; This is causing stability issues. Please create a bug report at https://github.com/home-assistant/core/issues?q=is%3Aopen+is%3Aissue For developers, please see https://developers.home-assistant.io/docs/asyncio_blocking_operations/#listdir Traceback (most recent call last): File "<frozen runpy>", line 198, in _run_module_as_main File "<frozen runpy>", line 88, in _run_code File "/usr/src/homeassistant/homeassistant/__main__.py", line 223, in <module> sys.exit(main()) File "/usr/src/homeassistant/homeassistant/__main__.py", line 209, in main exit_code = runner.run(runtime_conf) File "/usr/src/homeassistant/homeassistant/runner.py", line 190, in run return loop.run_until_complete(setup_and_run_hass(runtime_config)) File "/usr/local/lib/python3.12/asyncio/base_events.py", line 674, in run_until_complete self.run_forever() File "/usr/local/lib/python3.12/asyncio/base_events.py", line 641, in run_forever self._run_once() File "/usr/local/lib/python3.12/asyncio/base_events.py", line 1990, in _run_once handle._run() File "/usr/local/lib/python3.12/asyncio/events.py", line 88, in _run self._context.run(self._callback, *self._args) File "/usr/src/homeassistant/homeassistant/helpers/update_coordinator.py", line 239, in __wrap_handle_refresh_interval self.config_entry.async_create_background_task( File "/usr/src/homeassistant/homeassistant/config_entries.py", line 1156, in async_create_background_task task = hass.async_create_background_task(target, name, eager_start) File "/usr/src/homeassistant/homeassistant/core.py", line 862, in async_create_background_task task = create_eager_task(target, name=name, loop=self.loop) File "/usr/src/homeassistant/homeassistant/util/async_.py", line 37, in create_eager_task return Task(coro, loop=loop, name=name, eager_start=True) File "/usr/src/homeassistant/homeassistant/helpers/update_coordinator.py", line 255, in _handle_refresh_interval await self._async_refresh(log_failures=True, scheduled=True) File "/usr/src/homeassistant/homeassistant/helpers/update_coordinator.py", line 312, in _async_refresh self.data = await self._async_update_data() File "/usr/src/homeassistant/homeassistant/helpers/update_coordinator.py", line 268, in _async_update_data return await self.update_method() File "/usr/local/lib/python3.12/site-packages/vehicle/rdw.py", line 136, in vehicle data = await self._request( File "/usr/local/lib/python3.12/site-packages/vehicle/rdw.py", line 70, in _request version = metadata.version(__package__) File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 889, in version return distribution(distribution_name).version File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 862, in distribution return Distribution.from_name(distribution_name) File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 397, in from_name return next(cls.discover(name=name)) File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 795, in <genexpr> path.search(prepared) for path in map(FastPath, paths) File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 693, in search return self.lookup(self.mtime).search(name) File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 703, in lookup return Lookup(self) File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 713, in __init__ for child in path.children(): File "/usr/local/lib/python3.12/importlib/metadata/__init__.py", line 680, in children return os.listdir(self.root or '.')