diff --git a/trino/client.py b/trino/client.py index 92ad6f0f..e0f69079 100644 --- a/trino/client.py +++ b/trino/client.py @@ -855,7 +855,7 @@ def execute( call fetch() until finished is true. """ if self.cancelled: - raise exceptions.TrinoUserError("Query has been cancelled", self.query_id) + raise exceptions.TrinoUserError({"message": "Query has been cancelled"}, self.query_id) response = self._request.post(self._sql, additional_http_headers) status = self._request.process(response) diff --git a/trino/exceptions.py b/trino/exceptions.py index ccbd19b8..7b5607f5 100644 --- a/trino/exceptions.py +++ b/trino/exceptions.py @@ -72,38 +72,41 @@ class TrinoDataError(NotSupportedError): class TrinoQueryError(Error): - def __init__(self, error: Any, query_id: Optional[str] = None) -> None: + def __init__(self, error: Dict[str, Any], query_id: Optional[str] = None) -> None: self._error = error self._query_id = query_id @property def error_code(self) -> Optional[int]: - return self._error.get("errorCode", None) + return self._error.get("errorCode") @property def error_name(self) -> Optional[str]: - return self._error.get("errorName", None) + return self._error.get("errorName") @property def error_type(self) -> Optional[str]: - return self._error.get("errorType", None) + return self._error.get("errorType") @property def error_exception(self) -> Optional[str]: - return self.failure_info.get("type", None) if self.failure_info else None + return self.failure_info.get("type") if self.failure_info else None @property def failure_info(self) -> Optional[Dict[str, Any]]: - return self._error.get("failureInfo", None) + return self._error.get("failureInfo") @property def message(self) -> str: return self._error.get("message", "Trino did not return an error message") @property - def error_location(self) -> Tuple[int, int]: - location = self._error["errorLocation"] - return (location["lineNumber"], location["columnNumber"]) + def error_location(self) -> Optional[Tuple[int, int]]: + location = self._error.get("errorLocation") + if location: + return (location["lineNumber"], location["columnNumber"]) + else: + return None @property def query_id(self) -> Optional[str]: