From 1937e9bbedfda0ab11919428b0b1b027900f594d Mon Sep 17 00:00:00 2001 From: Tarik Zegmott Date: Tue, 4 Jun 2024 10:37:24 -0400 Subject: [PATCH] fix(scout): improve error handling (#87) --- dtcli/scout.py | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/dtcli/scout.py b/dtcli/scout.py index 9df49ba..00b0a27 100644 --- a/dtcli/scout.py +++ b/dtcli/scout.py @@ -26,7 +26,7 @@ @click.option("-v", "--verbose", count=True, help="Verbosity: v=INFO, vv=DEBUG.") @click.option("-q", "--quiet", is_flag=True, help="Set log level to ERROR.") @click.pass_context -def scout( +def scout( # noqa: C901 ctx: click.Context, dataset: str, scopes: List[str], @@ -86,8 +86,20 @@ def scout( url = server + endpoint logger.debug(f"URL: {url}") response = requests.get(url) - data = response.json() - logger.debug(f"Data: {data}") + try: + data = response.json() + logger.debug(f"Data: {data}") + except requests.JSONDecodeError: + if "Response Timeout" in response.text: + error_console.print("Error: Datatrail server timed out.") + return None + else: + error_console.print(f"Error: {response.text}") + return None + + if "error" in data.keys(): + error_console.print(data["error"]) + return None for scope in data.keys(): basepath = data.get(scope).get("basepath")