From 1a6af82aa59007afdd0bbed5fe6537ec609b3bd9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micka=C3=ABl=20Misbach?= Date: Fri, 9 Feb 2024 03:43:14 +0100 Subject: [PATCH] [uss_qualifier/resources/f3548/dss/delete_op_intent] Fix use of QueryError for error handling (#498) --- monitoring/uss_qualifier/resources/astm/f3548/v21/dss.py | 5 +++++ .../scenarios/astm/utm/dss/test_step_fragments.py | 1 + .../scenarios/astm/utm/off_nominal_planning/down_uss.py | 1 + .../scenarios/astm/utm/op_intent_ref_access_control.py | 4 ++++ 4 files changed, 11 insertions(+) diff --git a/monitoring/uss_qualifier/resources/astm/f3548/v21/dss.py b/monitoring/uss_qualifier/resources/astm/f3548/v21/dss.py index 95f57ef0f8..59c7d9a86c 100644 --- a/monitoring/uss_qualifier/resources/astm/f3548/v21/dss.py +++ b/monitoring/uss_qualifier/resources/astm/f3548/v21/dss.py @@ -295,6 +295,11 @@ def delete_op_intent( id: str, ovn: str, ) -> Tuple[OperationalIntentReference, List[SubscriberToNotify], Query]: + """ + Delete an operational intent. + Raises: + * QueryError: if request failed, if HTTP status code is different than 200, or if the parsing of the response failed. + """ self._uses_scope(Scope.StrategicCoordination) op = OPERATIONS[OperationID.DeleteOperationalIntentReference] query = query_and_describe( diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/dss/test_step_fragments.py b/monitoring/uss_qualifier/scenarios/astm/utm/dss/test_step_fragments.py index ac8d9ed59f..1cf30767cf 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/dss/test_step_fragments.py +++ b/monitoring/uss_qualifier/scenarios/astm/utm/dss/test_step_fragments.py @@ -26,6 +26,7 @@ def remove_op_intent( scenario.record_query(query) except fetch.QueryError as e: scenario.record_queries(e.queries) + query = e.queries[0] check.record_failed( summary=f"Could not remove op intent reference {oi_id}", details=f"When attempting to remove op intent reference {oi_id} from the DSS, received {query.status_code}; {e}", diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/off_nominal_planning/down_uss.py b/monitoring/uss_qualifier/scenarios/astm/utm/off_nominal_planning/down_uss.py index f64a1e6368..f67ec24fd2 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/off_nominal_planning/down_uss.py +++ b/monitoring/uss_qualifier/scenarios/astm/utm/off_nominal_planning/down_uss.py @@ -301,6 +301,7 @@ def _clear_op_intents(self): self.record_query(del_query) except QueryError as e: self.record_queries(e.queries) + del_query = e.queries[0] check.record_failed( summary=f"Failed to delete op intent {oi_ref.id} from DSS", details=f"DSS responded code {del_query.status_code}; error message: {del_query.error_message}; {e}", diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/op_intent_ref_access_control.py b/monitoring/uss_qualifier/scenarios/astm/utm/op_intent_ref_access_control.py index deff96c0dc..7f861f0a48 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/op_intent_ref_access_control.py +++ b/monitoring/uss_qualifier/scenarios/astm/utm/op_intent_ref_access_control.py @@ -166,6 +166,7 @@ def _clean_known_op_intents_ids(self): self.record_query(dq) except QueryError as e: self.record_queries(e.queries) + dq = e.queries[0] check.record_failed( f"Could not delete operational intent using main credentials", details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_1}; {e}", @@ -201,6 +202,7 @@ def _clean_known_op_intents_ids(self): self.record_query(dq) except QueryError as e: self.record_queries(e.queries) + dq = e.queries[0] check.record_failed( f"Could not delete operational intent using second credentials", details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_2}; {e}", @@ -241,6 +243,7 @@ def _attempt_to_delete_remaining_op_intents(self): self.record_query(dq) except QueryError as e: self.record_queries(e.queries) + dq = e.queries[0] check.record_failed( f"Could not delete operational intent using main credentials", details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {op_intent.id}; {e}", @@ -282,6 +285,7 @@ def _attempt_to_delete_remaining_op_intents(self): self.record_query(dq) except QueryError as e: self.record_queries(e.queries) + dq = e.queries[0] check.record_failed( f"Could not delete operational intent using second credentials", details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {op_intent.id}; {e}",