Add --batch-size hint to timeout errors in dump_devinfo (#696)

* Add --batch-size hint to timeout errors in dump_devinfo

* Add _echo_error function for displaying critical errors
This commit is contained in:
Steven B 2024-01-24 09:40:36 +00:00 committed by GitHub
parent bab40d43e6
commit f7c04bcef8
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -20,7 +20,14 @@ from typing import Dict, List, Union
import asyncclick as click import asyncclick as click
from devtools.helpers.smartrequests import COMPONENT_REQUESTS, SmartRequest from devtools.helpers.smartrequests import COMPONENT_REQUESTS, SmartRequest
from kasa import AuthenticationException, Credentials, Discover, SmartDevice from kasa import (
AuthenticationException,
Credentials,
Discover,
SmartDevice,
SmartDeviceException,
TimeoutException,
)
from kasa.discover import DiscoveryResult from kasa.discover import DiscoveryResult
from kasa.exceptions import SmartErrorCode from kasa.exceptions import SmartErrorCode
from kasa.tapo.tapodevice import TapoDevice from kasa.tapo.tapodevice import TapoDevice
@ -227,11 +234,7 @@ async def get_legacy_fixture(device):
try: try:
final = await device.protocol.query(final_query) final = await device.protocol.query(final_query)
except Exception as ex: except Exception as ex:
click.echo( _echo_error(f"Unable to query all successes at once: {ex}", bold=True, fg="red")
click.style(
f"Unable to query all successes at once: {ex}", bold=True, fg="red"
)
)
if device._discovery_info and not device._discovery_info.get("system"): if device._discovery_info and not device._discovery_info.get("system"):
# Need to recreate a DiscoverResult here because we don't want the aliases # Need to recreate a DiscoverResult here because we don't want the aliases
@ -254,6 +257,16 @@ async def get_legacy_fixture(device):
return save_filename, copy_folder, final return save_filename, copy_folder, final
def _echo_error(msg: str):
click.echo(
click.style(
msg,
bold=True,
fg="red",
)
)
async def _make_requests_or_exit( async def _make_requests_or_exit(
device: SmartDevice, device: SmartDevice,
requests: List[SmartRequest], requests: List[SmartRequest],
@ -277,17 +290,25 @@ async def _make_requests_or_exit(
final[method] = result final[method] = result
return final return final
except AuthenticationException as ex: except AuthenticationException as ex:
click.echo( _echo_error(
click.style( f"Unable to query the device due to an authentication error: {ex}",
f"Unable to query the device due to an authentication error: {ex}",
bold=True,
fg="red",
)
) )
exit(1) exit(1)
except SmartDeviceException as ex:
_echo_error(
f"Unable to query {name} at once: {ex}",
)
if (
isinstance(ex, TimeoutException)
or ex.error_code == SmartErrorCode.SESSION_TIMEOUT_ERROR
):
_echo_error(
"Timeout, try reducing the batch size via --batch-size option.",
)
exit(1)
except Exception as ex: except Exception as ex:
click.echo( _echo_error(
click.style(f"Unable to query {name} at once: {ex}", bold=True, fg="red") f"Unexpected exception querying {name} at once: {ex}",
) )
exit(1) exit(1)
@ -361,12 +382,8 @@ async def get_smart_fixture(device: TapoDevice, batch_size: int):
SmartRequest._create_request_dict(test_call.request) SmartRequest._create_request_dict(test_call.request)
) )
except AuthenticationException as ex: except AuthenticationException as ex:
click.echo( _echo_error(
click.style( f"Unable to query the device due to an authentication error: {ex}",
f"Unable to query the device due to an authentication error: {ex}",
bold=True,
fg="red",
)
) )
exit(1) exit(1)
except Exception as ex: except Exception as ex: