From 305b9eceae595a91dd3365210ecfbd6076132b55 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micka=C3=ABl=20Misbach?= Date: Wed, 18 Oct 2023 16:30:55 +0200 Subject: [PATCH] [uss_qualifier/utm] Use active volumes for activated op intents; [mock_uss/scdsc] Enforce active volume for activated op intent; Fix #217 (#237) * [uss_qualifier/scenarios/utm] Fix #178 * add req for op intent coverage; update according to feedback; optional severity * [uss_qualifier/utm] Use active volumes for activated op intents; [mock_uss/scdsc] Enforce active volume for activated op intent; Fix #217 * fix has_active_volume * correct mistakes --- monitoring/mock_uss/scdsc/flight_planning.py | 14 ++ monitoring/monitorlib/geotemporal.py | 6 + .../flight_intent_validation.md | 5 + .../flight_intent_validation.py | 27 ++- .../conflict_equal_priority_not_permitted.md | 23 ++- .../conflict_equal_priority_not_permitted.py | 190 ++++++++++-------- .../conflict_higher_priority.md | 23 ++- .../conflict_higher_priority.py | 185 +++++++++-------- .../flight_intents/conflicting_flights.json | 8 +- .../flight_intents/invalid_flight_auths.json | 8 +- .../invalid_flight_intents.yaml | 6 +- .../flight_intents/priority_preemption.json | 91 ++++----- .../flight_intents/conflicting_flights.yaml | 15 +- .../invalid_flight_intents.yaml | 10 +- .../flight_intents/priority_preemption.yaml | 88 ++++---- 15 files changed, 385 insertions(+), 314 deletions(-) diff --git a/monitoring/mock_uss/scdsc/flight_planning.py b/monitoring/mock_uss/scdsc/flight_planning.py index b63b47d9b9..1d69c1e2c0 100644 --- a/monitoring/mock_uss/scdsc/flight_planning.py +++ b/monitoring/mock_uss/scdsc/flight_planning.py @@ -1,6 +1,7 @@ from datetime import datetime from typing import Optional, List, Callable +import arrow from uas_standards.astm.f3548.v21 import api as f3548_v21 from uas_standards.astm.f3548.v21.constants import OiMaxVertices, OiMaxPlanHorizonDays from uas_standards.interuss.automated_testing.scd.v1 import api as scd_api @@ -68,6 +69,19 @@ def validate_request(req_body: scd_api.InjectFlightRequest, locality: Locality) f"Operational intent specifies an off-nominal volume while being in {req_body.operational_intent.state} state" ) + # Validate intent is currently active if in Activated state + # I.e. at least one volume has start time in the past and end time in the future + if req_body.operational_intent.state == OperationalIntentState.Activated: + now = arrow.utcnow().datetime + active_volume = Volume4DCollection.from_interuss_scd_api( + req_body.operational_intent.volumes + + req_body.operational_intent.off_nominal_volumes + ).has_active_volume(now) + if not active_volume: + raise PlanningError( + f"Operational intent is activated but has no volume currently active (now: {now})" + ) + def check_for_disallowed_conflicts( req_body: scd_api.InjectFlightRequest, diff --git a/monitoring/monitorlib/geotemporal.py b/monitoring/monitorlib/geotemporal.py index ec7d06a8b1..a9f648b7b7 100644 --- a/monitoring/monitorlib/geotemporal.py +++ b/monitoring/monitorlib/geotemporal.py @@ -570,3 +570,9 @@ def to_f3548v21(self) -> List[f3548v21.Volume4D]: def to_interuss_scd_api(self) -> List[interuss_scd_api.Volume4D]: return [v.to_interuss_scd_api() for v in self.volumes] + + def has_active_volume(self, time_ref: datetime) -> bool: + return any( + vol.time_start.datetime <= time_ref <= vol.time_end.datetime + for vol in self.volumes + ) diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.md b/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.md index dc390d82e4..d35466b351 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.md +++ b/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.md @@ -17,6 +17,11 @@ FlightIntentsResource that provides the following flight intents: - `invalid_too_far_away`: reference time mutation: reference time pulled back so that it is like the operational intent is attempted to be planned more than OiMaxPlanHorizon = 30 days ahead of time - `valid_conflict_tiny_overlap`: volumes mutation: has a volume that overlaps with `valid_op_intent` just above IntersectionMinimumPrecision = 1cm in a way that must result as a conflict +Because the scenario involves activation of intents, all activated intents must be active during the execution of the +test scenario, i.e. they must start before the reference time plus planning time duration. Additionally, their end time +must leave sufficient time for the execution of the test scenario. For the sake of simplicity, it is recommended to set +the start and end times of all the intents to the same range. + ### tested_uss FlightPlannerResource that will be tested for its validation of operational intents. diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.py b/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.py index a369a9a7e1..733ff43461 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.py +++ b/monitoring/uss_qualifier/scenarios/astm/utm/flight_intent_validation/flight_intent_validation.py @@ -1,3 +1,5 @@ +import arrow + from monitoring.monitorlib.geotemporal import Volume4DCollection from monitoring.uss_qualifier.common_data_definitions import Severity from uas_standards.astm.f3548.v21.api import OperationalIntentState @@ -56,10 +58,10 @@ def __init__( self.tested_uss = tested_uss.flight_planner self.dss = dss.dss - flight_intents = flight_intents.get_flight_intents() + _flight_intents = flight_intents.get_flight_intents() extents = [] - for intent in flight_intents.values(): + for intent in _flight_intents.values(): extents.extend(intent.request.operational_intent.volumes) extents.extend(intent.request.operational_intent.off_nominal_volumes) self._intents_extent = Volume4DCollection.from_interuss_scd_api( @@ -73,12 +75,25 @@ def __init__( self.invalid_too_far_away, self.valid_conflict_tiny_overlap, ) = ( - flight_intents["valid_flight"], - flight_intents["valid_activated"], - flight_intents["invalid_too_far_away"], - flight_intents["valid_conflict_tiny_overlap"], + _flight_intents["valid_flight"], + _flight_intents["valid_activated"], + _flight_intents["invalid_too_far_away"], + _flight_intents["valid_conflict_tiny_overlap"], ) + now = arrow.utcnow().datetime + for intent_name, intent in _flight_intents.items(): + if ( + intent.request.operational_intent.state + == OperationalIntentState.Activated + ): + assert Volume4DCollection.from_interuss_scd_api( + intent.request.operational_intent.volumes + + intent.request.operational_intent.off_nominal_volumes + ).has_active_volume( + now + ), f"at least one volume of activated intent {intent_name} must be active now (now is {now})" + assert ( self.valid_flight.request.operational_intent.state == OperationalIntentState.Accepted diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.md b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.md index 45b861167b..323af0aab3 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.md +++ b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.md @@ -21,7 +21,7 @@ Otherwise, the FlightIntentsResource must provide the following flight intents: - + < @@ -29,7 +29,7 @@ Otherwise, the FlightIntentsResource must provide the following flight intents: - + @@ -37,44 +37,49 @@ Otherwise, the FlightIntentsResource must provide the following flight intents: - + - + - + - + - + - + - +
Flight intent IDFlight intent IDFlight name Priority StateMust not conflict with
flight_1_planned_time_range_Aflight_1_planned_vol_A Flight 1 Any (but all the same) AcceptedN/A
flight_1_activated_time_range_Aflight_1_activated_vol_A Activated
flight_1_activated_time_range_A_extendedflight_1_activated_vol_A_extended Flight 1m Activated Flight 2 N/A
flight_1_planned_time_range_Bflight_1_planned_vol_B Flight 1c Planned N/A Flight 2
flight_1_activated_time_range_Bflight_1_activated_vol_B Activated
flight_2_equal_prio_planned_time_range_Bflight_2_equal_prio_planned_vol_B Flight 2 Planned Flight 1, Flight 1m Flight 1c
flight_2_equal_prio_activated_time_range_Bflight_2_equal_prio_activated_vol_B Activated
flight_2_equal_prio_nonconforming_time_range_Aflight_2_equal_prio_nonconforming_vol_A Nonconforming
+Because the scenario involves activation of intents, all activated intents must be active during the execution of the +test scenario, i.e. they must start before the reference time plus planning time duration. Additionally, their end time +must leave sufficient time for the execution of the test scenario. For the sake of simplicity, it is recommended to set +the start and end times of all the intents to the same range. + ### tested_uss FlightPlannerResource that is under test and will manage flight 1. diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.py b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.py index 4f71ae140d..b25af16ffc 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.py +++ b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_equal_priority_not_permitted/conflict_equal_priority_not_permitted.py @@ -1,5 +1,6 @@ from typing import Optional +import arrow from uas_standards.astm.f3548.v21.api import ( OperationalIntentReference, ) @@ -48,16 +49,16 @@ class ConflictEqualPriorityNotPermitted(TestScenario): flight_1_id: Optional[str] = None - flight_1_planned_time_range_A: FlightIntent - flight_1_activated_time_range_A: FlightIntent - flight_1_activated_time_range_A_extended: FlightIntent - flight_1_planned_time_range_B: FlightIntent - flight_1_activated_time_range_B: FlightIntent + flight_1_planned_vol_A: FlightIntent + flight_1_activated_vol_A: FlightIntent + flight_1_activated_vol_A_extended: FlightIntent + flight_1_planned_vol_B: FlightIntent + flight_1_activated_vol_B: FlightIntent flight_2_id: Optional[str] = None - flight_2_equal_prio_planned_time_range_B: FlightIntent - flight_2_equal_prio_activated_time_range_B: FlightIntent - flight_2_equal_prio_nonconforming_time_range_A: FlightIntent + flight_2_equal_prio_planned_vol_B: FlightIntent + flight_2_equal_prio_activated_vol_B: FlightIntent + flight_2_equal_prio_nonconforming_vol_A: FlightIntent tested_uss: FlightPlanner control_uss: FlightPlanner @@ -83,10 +84,10 @@ def __init__( ) raise ScenarioCannotContinueError(msg) - flight_intents = flight_intents.get_flight_intents() + _flight_intents = flight_intents.get_flight_intents() extents = [] - for intent in flight_intents.values(): + for intent in _flight_intents.values(): extents.extend(intent.request.operational_intent.volumes) extents.extend(intent.request.operational_intent.off_nominal_volumes) self._intents_extent = Volume4DCollection.from_interuss_scd_api( @@ -95,97 +96,110 @@ def __init__( try: ( - self.flight_1_planned_time_range_A, - self.flight_1_activated_time_range_A, - self.flight_1_activated_time_range_A_extended, - self.flight_1_planned_time_range_B, - self.flight_1_activated_time_range_B, - self.flight_2_equal_prio_planned_time_range_B, - self.flight_2_equal_prio_activated_time_range_B, - self.flight_2_equal_prio_nonconforming_time_range_A, + self.flight_1_planned_vol_A, + self.flight_1_activated_vol_A, + self.flight_1_activated_vol_A_extended, + self.flight_1_planned_vol_B, + self.flight_1_activated_vol_B, + self.flight_2_equal_prio_planned_vol_B, + self.flight_2_equal_prio_activated_vol_B, + self.flight_2_equal_prio_nonconforming_vol_A, ) = ( - flight_intents["flight_1_planned_time_range_A"], - flight_intents["flight_1_activated_time_range_A"], - flight_intents["flight_1_activated_time_range_A_extended"], - flight_intents["flight_1_planned_time_range_B"], - flight_intents["flight_1_activated_time_range_B"], - flight_intents["flight_2_equal_prio_planned_time_range_B"], - flight_intents["flight_2_equal_prio_activated_time_range_B"], - flight_intents["flight_2_equal_prio_nonconforming_time_range_A"], + _flight_intents["flight_1_planned_vol_A"], + _flight_intents["flight_1_activated_vol_A"], + _flight_intents["flight_1_activated_vol_A_extended"], + _flight_intents["flight_1_planned_vol_B"], + _flight_intents["flight_1_activated_vol_B"], + _flight_intents["flight_2_equal_prio_planned_vol_B"], + _flight_intents["flight_2_equal_prio_activated_vol_B"], + _flight_intents["flight_2_equal_prio_nonconforming_vol_A"], ) + now = arrow.utcnow().datetime + for intent_name, intent in _flight_intents.items(): + if ( + intent.request.operational_intent.state + == OperationalIntentState.Activated + ): + assert Volume4DCollection.from_interuss_scd_api( + intent.request.operational_intent.volumes + + intent.request.operational_intent.off_nominal_volumes + ).has_active_volume( + now + ), f"at least one volume of activated intent {intent_name} must be active now (now is {now})" + assert ( - self.flight_1_planned_time_range_A.request.operational_intent.state + self.flight_1_planned_vol_A.request.operational_intent.state == OperationalIntentState.Accepted - ), "flight_1_planned_time_range_A must have state Accepted" + ), "flight_1_planned_vol_A must have state Accepted" assert ( - self.flight_1_activated_time_range_A.request.operational_intent.state + self.flight_1_activated_vol_A.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_1_activated_time_range_A must have state Activated" + ), "flight_1_activated_vol_A must have state Activated" assert ( - self.flight_1_activated_time_range_A_extended.request.operational_intent.state + self.flight_1_activated_vol_A_extended.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_1_activated_time_range_A_extended must have state Activated" + ), "flight_1_activated_vol_A_extended must have state Activated" assert ( - self.flight_1_planned_time_range_B.request.operational_intent.state + self.flight_1_planned_vol_B.request.operational_intent.state == OperationalIntentState.Accepted - ), "flight_1_planned_time_range_B must have state Accepted" + ), "flight_1_planned_vol_B must have state Accepted" assert ( - self.flight_1_activated_time_range_B.request.operational_intent.state + self.flight_1_activated_vol_B.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_1_activated_time_range_B must have state Activated" + ), "flight_1_activated_vol_B must have state Activated" assert ( - self.flight_2_equal_prio_planned_time_range_B.request.operational_intent.state + self.flight_2_equal_prio_planned_vol_B.request.operational_intent.state == OperationalIntentState.Accepted - ), "flight_2_equal_prio_planned_time_range_B must have state Accepted" + ), "flight_2_equal_prio_planned_vol_B must have state Accepted" assert ( - self.flight_2_equal_prio_activated_time_range_B.request.operational_intent.state + self.flight_2_equal_prio_activated_vol_B.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_2_equal_prio_activated_time_range_B must have state Activated" + ), "flight_2_equal_prio_activated_vol_B must have state Activated" assert ( - self.flight_2_equal_prio_nonconforming_time_range_A.request.operational_intent.state + self.flight_2_equal_prio_nonconforming_vol_A.request.operational_intent.state == OperationalIntentState.Nonconforming - ), "flight_2_equal_prio_nonconforming_time_range_A must have state Nonconforming" + ), "flight_2_equal_prio_nonconforming_vol_A must have state Nonconforming" assert ( - self.flight_2_equal_prio_planned_time_range_B.request.operational_intent.priority - == self.flight_1_planned_time_range_A.request.operational_intent.priority + self.flight_2_equal_prio_planned_vol_B.request.operational_intent.priority + == self.flight_1_planned_vol_A.request.operational_intent.priority ), "flight_2 must have priority equal to flight_1" assert not Volume4DCollection.from_interuss_scd_api( - self.flight_1_planned_time_range_A.request.operational_intent.volumes + self.flight_1_planned_vol_A.request.operational_intent.volumes ).intersects_vol4s( Volume4DCollection.from_interuss_scd_api( - self.flight_2_equal_prio_planned_time_range_B.request.operational_intent.volumes + self.flight_2_equal_prio_planned_vol_B.request.operational_intent.volumes ) - ), "flight_1_planned_time_range_A and flight_2_equal_prio_planned_time_range_B must not intersect" + ), "flight_1_planned_vol_A and flight_2_equal_prio_planned_vol_B must not intersect" assert not Volume4DCollection.from_interuss_scd_api( - self.flight_1_planned_time_range_A.request.operational_intent.volumes + self.flight_1_planned_vol_A.request.operational_intent.volumes ).intersects_vol4s( Volume4DCollection.from_interuss_scd_api( - self.flight_1_activated_time_range_B.request.operational_intent.volumes + self.flight_1_activated_vol_B.request.operational_intent.volumes ) - ), "flight_1_planned_time_range_A and flight_1_activated_time_range_B must not intersect" + ), "flight_1_planned_vol_A and flight_1_activated_vol_B must not intersect" assert Volume4DCollection.from_interuss_scd_api( - self.flight_1_activated_time_range_B.request.operational_intent.volumes + self.flight_1_activated_vol_B.request.operational_intent.volumes ).intersects_vol4s( Volume4DCollection.from_interuss_scd_api( - self.flight_2_equal_prio_activated_time_range_B.request.operational_intent.volumes + self.flight_2_equal_prio_activated_vol_B.request.operational_intent.volumes ) - ), "flight_1_activated_time_range_B and flight_2_equal_prio_activated_time_range_B must intersect" + ), "flight_1_activated_vol_B and flight_2_equal_prio_activated_vol_B must intersect" assert Volume4DCollection.from_interuss_scd_api( - self.flight_1_activated_time_range_A.request.operational_intent.volumes + self.flight_1_activated_vol_A.request.operational_intent.volumes ).intersects_vol4s( Volume4DCollection.from_interuss_scd_api( - self.flight_2_equal_prio_nonconforming_time_range_A.request.operational_intent.off_nominal_volumes + self.flight_2_equal_prio_nonconforming_vol_A.request.operational_intent.off_nominal_volumes ) - ), "flight_1_activated_time_range_A.volumes and flight_2_equal_prio_nonconforming_time_range_A.off_nominal_volumes must intersect" + ), "flight_1_activated_vol_A.volumes and flight_2_equal_prio_nonconforming_vol_A.off_nominal_volumes must intersect" assert ( len( - self.flight_2_equal_prio_nonconforming_time_range_A.request.operational_intent.off_nominal_volumes + self.flight_2_equal_prio_nonconforming_vol_A.request.operational_intent.off_nominal_volumes ) > 0 - ), "flight_2_equal_prio_nonconforming_time_range_A must have off-nominal volume" + ), "flight_2_equal_prio_nonconforming_vol_A must have off-nominal volume" except KeyError as e: raise ValueError( @@ -262,14 +276,14 @@ def _setup(self) -> bool: self, "Area clearing", [ - self.flight_1_planned_time_range_A, - self.flight_1_activated_time_range_A, - self.flight_1_activated_time_range_A_extended, - self.flight_1_planned_time_range_B, - self.flight_1_activated_time_range_B, - self.flight_2_equal_prio_planned_time_range_B, - self.flight_2_equal_prio_activated_time_range_B, - self.flight_2_equal_prio_nonconforming_time_range_A, + self.flight_1_planned_vol_A, + self.flight_1_activated_vol_A, + self.flight_1_activated_vol_A_extended, + self.flight_1_planned_vol_B, + self.flight_1_activated_vol_B, + self.flight_2_equal_prio_planned_vol_B, + self.flight_2_equal_prio_activated_vol_B, + self.flight_2_equal_prio_nonconforming_vol_A, ], [self.tested_uss, self.control_uss], ) @@ -288,10 +302,10 @@ def _attempt_plan_flight_conflict(self) -> OperationalIntentReference: self, "Plan flight 2", self.control_uss, - self.flight_2_equal_prio_planned_time_range_B.request, + self.flight_2_equal_prio_planned_vol_B.request, ) flight_2_oi_ref = validator.expect_shared( - self.flight_2_equal_prio_planned_time_range_B.request + self.flight_2_equal_prio_planned_vol_B.request ) with OpIntentValidator( @@ -306,11 +320,11 @@ def _attempt_plan_flight_conflict(self) -> OperationalIntentReference: self, "Activate flight 2", self.control_uss, - self.flight_2_equal_prio_activated_time_range_B.request, + self.flight_2_equal_prio_activated_vol_B.request, self.flight_2_id, ) flight_2_oi_ref = validator.expect_shared( - self.flight_2_equal_prio_activated_time_range_B.request + self.flight_2_equal_prio_activated_vol_B.request ) with OpIntentValidator( @@ -324,7 +338,7 @@ def _attempt_plan_flight_conflict(self) -> OperationalIntentReference: self, "Attempt to plan flight 1", self.tested_uss, - self.flight_1_planned_time_range_B.request, + self.flight_1_planned_vol_B.request, ) validator.expect_not_shared() @@ -342,7 +356,7 @@ def _attempt_activate_flight_conflict(self): self, "Attempt to directly activate conflicting flight 1", self.tested_uss, - self.flight_1_activated_time_range_B.request, + self.flight_1_activated_vol_B.request, self.flight_1_id, ) validator.expect_not_shared() @@ -361,10 +375,10 @@ def _attempt_modify_planned_flight_conflict( self, "Plan flight 1", self.tested_uss, - self.flight_1_planned_time_range_A.request, + self.flight_1_planned_vol_A.request, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_planned_time_range_A.request + self.flight_1_planned_vol_A.request ) with OpIntentValidator( @@ -379,11 +393,11 @@ def _attempt_modify_planned_flight_conflict( self, "Attempt to modify planned flight 1 into conflict", self.tested_uss, - self.flight_1_planned_time_range_B.request, + self.flight_1_planned_vol_B.request, self.flight_1_id, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_planned_time_range_A.request, skip_if_not_found=True + self.flight_1_planned_vol_A.request, skip_if_not_found=True ) return flight_1_oi_ref @@ -403,11 +417,11 @@ def _attempt_modify_activated_flight_conflict( self, "Activate flight 1", self.tested_uss, - self.flight_1_activated_time_range_A.request, + self.flight_1_activated_vol_A.request, self.flight_1_id, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_activated_time_range_A.request + self.flight_1_activated_vol_A.request ) with OpIntentValidator( @@ -422,11 +436,11 @@ def _attempt_modify_activated_flight_conflict( self, "Attempt to modify activated flight 1 into conflict", self.tested_uss, - self.flight_1_activated_time_range_B.request, + self.flight_1_activated_vol_B.request, self.flight_1_id, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_activated_time_range_A.request, skip_if_not_found=True + self.flight_1_activated_vol_A.request, skip_if_not_found=True ) return flight_1_oi_ref @@ -448,11 +462,11 @@ def _modify_activated_flight_preexisting_conflict( self, "Activate flight 1", self.tested_uss, - self.flight_1_activated_time_range_A.request, + self.flight_1_activated_vol_A.request, self.flight_1_id, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_activated_time_range_A.request + self.flight_1_activated_vol_A.request ) with OpIntentValidator( @@ -473,7 +487,7 @@ def _modify_activated_flight_preexisting_conflict( }, {InjectFlightResponseResult.Failed: "Failure"}, self.control_uss, - self.flight_2_equal_prio_nonconforming_time_range_A.request, + self.flight_2_equal_prio_nonconforming_vol_A.request, self.flight_2_id, ) if resp_flight_2.result == InjectFlightResponseResult.NotSupported: @@ -482,7 +496,7 @@ def _modify_activated_flight_preexisting_conflict( raise ScenarioCannotContinueError(msg) validator.expect_shared( - self.flight_2_equal_prio_nonconforming_time_range_A.request + self.flight_2_equal_prio_nonconforming_vol_A.request ) with OpIntentValidator( @@ -503,17 +517,15 @@ def _modify_activated_flight_preexisting_conflict( }, {InjectFlightResponseResult.Failed: "Failure"}, self.tested_uss, - self.flight_1_activated_time_range_A_extended.request, + self.flight_1_activated_vol_A_extended.request, self.flight_1_id, ) if resp_flight_1.result == InjectFlightResponseResult.ReadyToFly: - validator.expect_shared( - self.flight_1_activated_time_range_A_extended.request - ) + validator.expect_shared(self.flight_1_activated_vol_A_extended.request) elif resp_flight_1.result == InjectFlightResponseResult.Rejected: validator.expect_shared( - self.flight_1_activated_time_range_A.request, skip_if_not_found=True + self.flight_1_activated_vol_A.request, skip_if_not_found=True ) def cleanup(self): diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.md b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.md index 15e012b15f..debfc437a0 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.md +++ b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.md @@ -16,7 +16,7 @@ FlightIntentsResource that provides the following flight intents: - + @@ -24,7 +24,7 @@ FlightIntentsResource that provides the following flight intents: - + @@ -32,29 +32,29 @@ FlightIntentsResource that provides the following flight intents: - + - + - + - + - + @@ -62,17 +62,22 @@ FlightIntentsResource that provides the following flight intents: - + - +
Flight intent IDFlight intent ID Flight name Priority StateMust not conflict with
flight_1_planned_time_range_Aflight_1_planned_vol_A Flight 1 Any AcceptedFlight 2m
flight_1_activated_time_range_Aflight_1_activated_vol_A Activated
flight_1_planned_time_range_A_extendedflight_1_planned_vol_A_extended Flight 1m Accepted Flight 2 N/A
flight_1_activated_time_range_A_extendedflight_1_activated_vol_A_extended Activated
flight_1_activated_time_range_Bflight_1_activated_vol_B Flight 1c Activated Flight 2 N/A
flight_2_planned_time_range_Aflight_2_planned_vol_A Flight 2 Higher than Flight 1* AcceptedN/A
flight_2_activated_time_range_Aflight_2_activated_vol_A Activated
flight_2_activated_time_range_Bflight_2_activated_vol_B Flight 2m Activated Flight 1c Flight 1
+Because the scenario involves activation of intents, all activated intents must be active during the execution of the +test scenario, i.e. they must start before the reference time plus planning time duration. Additionally, their end time +must leave sufficient time for the execution of the test scenario. For the sake of simplicity, it is recommended to set +the start and end times of all the intents to the same range. + ### tested_uss FlightPlannerResource that is under test and will manage flight 1. diff --git a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.py b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.py index 165694c73a..d660ae127f 100644 --- a/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.py +++ b/monitoring/uss_qualifier/scenarios/astm/utm/nominal_planning/conflict_higher_priority/conflict_higher_priority.py @@ -1,5 +1,6 @@ from typing import Optional, Tuple +import arrow from uas_standards.astm.f3548.v21.api import ( OperationalIntentReference, ) @@ -47,16 +48,16 @@ class ConflictHigherPriority(TestScenario): flight_1_id: Optional[str] = None - flight_1_planned_time_range_A: FlightIntent - flight_1_planned_time_range_A_extended: FlightIntent - flight_1_activated_time_range_A: FlightIntent - flight_1_activated_time_range_A_extended: FlightIntent - flight_1_activated_time_range_B: FlightIntent + flight_1_planned_vol_A: FlightIntent + flight_1_planned_vol_A_extended: FlightIntent + flight_1_activated_vol_A: FlightIntent + flight_1_activated_vol_A_extended: FlightIntent + flight_1_activated_vol_B: FlightIntent flight_2_id: Optional[str] = None - flight_2_planned_time_range_A: FlightIntent - flight_2_activated_time_range_A: FlightIntent - flight_2_activated_time_range_B: FlightIntent + flight_2_planned_vol_A: FlightIntent + flight_2_activated_vol_A: FlightIntent + flight_2_activated_vol_B: FlightIntent tested_uss: FlightPlanner control_uss: FlightPlanner @@ -74,10 +75,10 @@ def __init__( self.control_uss = control_uss.flight_planner self.dss = dss.dss - flight_intents = flight_intents.get_flight_intents() + _flight_intents = flight_intents.get_flight_intents() extents = [] - for intent in flight_intents.values(): + for intent in _flight_intents.values(): extents.extend(intent.request.operational_intent.volumes) extents.extend(intent.request.operational_intent.off_nominal_volumes) self._intents_extent = Volume4DCollection.from_interuss_scd_api( @@ -86,86 +87,98 @@ def __init__( try: ( - self.flight_1_planned_time_range_A, - self.flight_1_planned_time_range_A_extended, - self.flight_1_activated_time_range_A, - self.flight_1_activated_time_range_A_extended, - self.flight_1_activated_time_range_B, - self.flight_2_planned_time_range_A, - self.flight_2_activated_time_range_A, - self.flight_2_activated_time_range_B, + self.flight_1_planned_vol_A, + self.flight_1_planned_vol_A_extended, + self.flight_1_activated_vol_A, + self.flight_1_activated_vol_A_extended, + self.flight_1_activated_vol_B, + self.flight_2_planned_vol_A, + self.flight_2_activated_vol_A, + self.flight_2_activated_vol_B, ) = ( - flight_intents["flight_1_planned_time_range_A"], - flight_intents["flight_1_planned_time_range_A_extended"], - flight_intents["flight_1_activated_time_range_A"], - flight_intents["flight_1_activated_time_range_A_extended"], - flight_intents["flight_1_activated_time_range_B"], - flight_intents["flight_2_planned_time_range_A"], - flight_intents["flight_2_activated_time_range_A"], - flight_intents["flight_2_activated_time_range_B"], + _flight_intents["flight_1_planned_vol_A"], + _flight_intents["flight_1_planned_vol_A_extended"], + _flight_intents["flight_1_activated_vol_A"], + _flight_intents["flight_1_activated_vol_A_extended"], + _flight_intents["flight_1_activated_vol_B"], + _flight_intents["flight_2_planned_vol_A"], + _flight_intents["flight_2_activated_vol_A"], + _flight_intents["flight_2_activated_vol_B"], ) + now = arrow.utcnow().datetime + for intent_name, intent in _flight_intents.items(): + if ( + intent.request.operational_intent.state + == OperationalIntentState.Activated + ): + assert Volume4DCollection.from_interuss_scd_api( + intent.request.operational_intent.volumes + + intent.request.operational_intent.off_nominal_volumes + ).has_active_volume( + now + ), f"at least one volume of activated intent {intent_name} must be active now (now is {now})" + assert ( - self.flight_1_planned_time_range_A.request.operational_intent.state + self.flight_1_planned_vol_A.request.operational_intent.state == OperationalIntentState.Accepted - ), "flight_1_planned_time_range_A must have state Accepted" + ), "flight_1_planned_vol_A must have state Accepted" assert ( - self.flight_1_planned_time_range_A_extended.request.operational_intent.state + self.flight_1_planned_vol_A_extended.request.operational_intent.state == OperationalIntentState.Accepted - ), "flight_1_planned_time_range_A_extended must have state Accepted" + ), "flight_1_planned_vol_A_extended must have state Accepted" assert ( - self.flight_1_activated_time_range_A.request.operational_intent.state + self.flight_1_activated_vol_A.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_1_activated_time_range_A must have state Activated" + ), "flight_1_activated_vol_A must have state Activated" assert ( - self.flight_1_activated_time_range_A_extended.request.operational_intent.state + self.flight_1_activated_vol_A_extended.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_1_activated_time_range_A_extended must have state Activated" + ), "flight_1_activated_vol_A_extended must have state Activated" assert ( - self.flight_1_activated_time_range_B.request.operational_intent.state + self.flight_1_activated_vol_B.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_1_activated_time_range_B must have state Activated" + ), "flight_1_activated_vol_B must have state Activated" assert ( - self.flight_2_planned_time_range_A.request.operational_intent.state + self.flight_2_planned_vol_A.request.operational_intent.state == OperationalIntentState.Accepted - ), "flight_2_planned_time_range_A must have state Accepted" + ), "flight_2_planned_vol_A must have state Accepted" assert ( - self.flight_2_activated_time_range_A.request.operational_intent.state + self.flight_2_activated_vol_A.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_2_activated_time_range_A must have state Activated" + ), "flight_2_activated_vol_A must have state Activated" assert ( - self.flight_2_activated_time_range_B.request.operational_intent.state + self.flight_2_activated_vol_B.request.operational_intent.state == OperationalIntentState.Activated - ), "flight_2_activated_time_range_B must have state Activated" + ), "flight_2_activated_vol_B must have state Activated" - # TODO: check that the time ranges are equal where they need to be # TODO: check that flight data is the same across the different versions of the flight assert ( - self.flight_2_planned_time_range_A.request.operational_intent.priority - > self.flight_1_planned_time_range_A.request.operational_intent.priority + self.flight_2_planned_vol_A.request.operational_intent.priority + > self.flight_1_planned_vol_A.request.operational_intent.priority ), "flight_2 must have higher priority than flight_1" assert Volume4DCollection.from_interuss_scd_api( - self.flight_1_planned_time_range_A.request.operational_intent.volumes + self.flight_1_planned_vol_A.request.operational_intent.volumes ).intersects_vol4s( Volume4DCollection.from_interuss_scd_api( - self.flight_2_planned_time_range_A.request.operational_intent.volumes + self.flight_2_planned_vol_A.request.operational_intent.volumes ) - ), "flight_1_planned_time_range_A and flight_2_planned_time_range_A must intersect" + ), "flight_1_planned_vol_A and flight_2_planned_vol_A must intersect" assert Volume4DCollection.from_interuss_scd_api( - self.flight_1_planned_time_range_A.request.operational_intent.volumes + self.flight_1_planned_vol_A.request.operational_intent.volumes ).intersects_vol4s( Volume4DCollection.from_interuss_scd_api( - self.flight_1_planned_time_range_A_extended.request.operational_intent.volumes + self.flight_1_planned_vol_A_extended.request.operational_intent.volumes ) - ), "flight_1_planned_time_range_A and flight_1_planned_time_range_A_extended must intersect" + ), "flight_1_planned_vol_A and flight_1_planned_vol_A_extended must intersect" assert not Volume4DCollection.from_interuss_scd_api( - self.flight_1_planned_time_range_A.request.operational_intent.volumes + self.flight_1_planned_vol_A.request.operational_intent.volumes ).intersects_vol4s( Volume4DCollection.from_interuss_scd_api( - self.flight_1_activated_time_range_B.request.operational_intent.volumes + self.flight_1_activated_vol_B.request.operational_intent.volumes ) - ), "flight_1_planned_time_range_A and flight_1_activated_time_range_B must not intersect" + ), "flight_1_planned_vol_A and flight_1_activated_vol_B must not intersect" except KeyError as e: raise ValueError( @@ -241,14 +254,14 @@ def _setup(self) -> bool: self, "Area clearing", [ - self.flight_1_planned_time_range_A, - self.flight_1_planned_time_range_A_extended, - self.flight_1_activated_time_range_A, - self.flight_1_activated_time_range_A_extended, - self.flight_1_activated_time_range_B, - self.flight_2_planned_time_range_A, - self.flight_2_activated_time_range_A, - self.flight_2_activated_time_range_B, + self.flight_1_planned_vol_A, + self.flight_1_planned_vol_A_extended, + self.flight_1_activated_vol_A, + self.flight_1_activated_vol_A_extended, + self.flight_1_activated_vol_B, + self.flight_2_planned_vol_A, + self.flight_2_activated_vol_A, + self.flight_2_activated_vol_B, ], [self.tested_uss, self.control_uss], ) @@ -267,9 +280,9 @@ def _attempt_plan_flight_conflict(self): self, "Plan flight 2", self.control_uss, - self.flight_2_planned_time_range_A.request, + self.flight_2_planned_vol_A.request, ) - validator.expect_shared(self.flight_2_planned_time_range_A.request) + validator.expect_shared(self.flight_2_planned_vol_A.request) with OpIntentValidator( self, @@ -282,7 +295,7 @@ def _attempt_plan_flight_conflict(self): self, "Attempt to plan flight 1", self.tested_uss, - self.flight_1_planned_time_range_A.request, + self.flight_1_planned_vol_A.request, ) validator.expect_not_shared() @@ -305,10 +318,10 @@ def _attempt_modify_planned_flight_conflict( self, "Plan flight 1", self.tested_uss, - self.flight_1_planned_time_range_A.request, + self.flight_1_planned_vol_A.request, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_planned_time_range_A.request + self.flight_1_planned_vol_A.request ) with OpIntentValidator( @@ -322,9 +335,9 @@ def _attempt_modify_planned_flight_conflict( self, "Plan flight 2", self.control_uss, - self.flight_2_planned_time_range_A.request, + self.flight_2_planned_vol_A.request, ) - validator.expect_shared(self.flight_2_planned_time_range_A.request) + validator.expect_shared(self.flight_2_planned_vol_A.request) with OpIntentValidator( self, @@ -338,11 +351,11 @@ def _attempt_modify_planned_flight_conflict( self, "Attempt to modify planned flight 1 in conflict", self.tested_uss, - self.flight_1_planned_time_range_A_extended.request, + self.flight_1_planned_vol_A_extended.request, self.flight_1_id, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_planned_time_range_A.request, skip_if_not_found=True + self.flight_1_planned_vol_A.request, skip_if_not_found=True ) return flight_1_oi_ref @@ -362,11 +375,11 @@ def _attempt_activate_flight_conflict( self, "Attempt to activate conflicting flight 1", self.tested_uss, - self.flight_1_activated_time_range_A.request, + self.flight_1_activated_vol_A.request, self.flight_1_id, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_planned_time_range_A.request, skip_if_not_found=True + self.flight_1_planned_vol_A.request, skip_if_not_found=True ) return flight_1_oi_ref @@ -391,11 +404,11 @@ def _modify_activated_flight_conflict_preexisting( self, "Activate flight 1", self.tested_uss, - self.flight_1_activated_time_range_A.request, + self.flight_1_activated_vol_A.request, self.flight_1_id, ) flight_1_oi_ref = validator.expect_shared( - self.flight_1_activated_time_range_A.request + self.flight_1_activated_vol_A.request ) with OpIntentValidator( @@ -409,10 +422,10 @@ def _modify_activated_flight_conflict_preexisting( self, "Plan flight 2", self.control_uss, - self.flight_2_planned_time_range_A.request, + self.flight_2_planned_vol_A.request, ) flight_2_oi_ref = validator.expect_shared( - self.flight_2_planned_time_range_A.request + self.flight_2_planned_vol_A.request ) with OpIntentValidator( @@ -427,11 +440,11 @@ def _modify_activated_flight_conflict_preexisting( self, "Activate flight 2", self.control_uss, - self.flight_2_activated_time_range_A.request, + self.flight_2_activated_vol_A.request, self.flight_2_id, ) flight_2_oi_ref = validator.expect_shared( - self.flight_2_activated_time_range_A.request + self.flight_2_activated_vol_A.request ) with OpIntentValidator( @@ -446,18 +459,18 @@ def _modify_activated_flight_conflict_preexisting( self, "Modify activated flight 1 in conflict with activated flight 2", self.tested_uss, - self.flight_1_activated_time_range_A_extended.request, + self.flight_1_activated_vol_A_extended.request, self.flight_1_id, preexisting_conflict=True, ) if resp.result == InjectFlightResponseResult.ReadyToFly: flight_1_oi_ref = validator.expect_shared( - self.flight_1_activated_time_range_A_extended.request + self.flight_1_activated_vol_A_extended.request ) else: flight_1_oi_ref = validator.expect_shared( - self.flight_1_activated_time_range_A.request + self.flight_1_activated_vol_A.request ) return flight_1_oi_ref, flight_2_oi_ref @@ -479,10 +492,10 @@ def _attempt_modify_activated_flight_conflict( self, "Modify activated flight 2 to not conflict with activated flight 1", self.control_uss, - self.flight_2_activated_time_range_B.request, + self.flight_2_activated_vol_B.request, self.flight_2_id, ) - validator.expect_shared(self.flight_2_activated_time_range_B.request) + validator.expect_shared(self.flight_2_activated_vol_B.request) with OpIntentValidator( self, @@ -496,11 +509,11 @@ def _attempt_modify_activated_flight_conflict( self, "Attempt to modify activated flight 1 in conflict", self.tested_uss, - self.flight_1_activated_time_range_B.request, + self.flight_1_activated_vol_B.request, self.flight_1_id, ) validator.expect_shared( - self.flight_1_activated_time_range_A_extended.request, + self.flight_1_activated_vol_A_extended.request, skip_if_not_found=True, ) diff --git a/monitoring/uss_qualifier/test_data/che/flight_intents/conflicting_flights.json b/monitoring/uss_qualifier/test_data/che/flight_intents/conflicting_flights.json index 429a13a41b..59b6248886 100644 --- a/monitoring/uss_qualifier/test_data/che/flight_intents/conflicting_flights.json +++ b/monitoring/uss_qualifier/test_data/che/flight_intents/conflicting_flights.json @@ -248,11 +248,11 @@ } }, "time_start": { - "value": "2023-02-12T10:37:14.483425+00:00", + "value": "2023-02-12T10:27:14.483425+00:00", "format": "RFC3339" }, "time_end": { - "value": "2023-02-12T10:42:14.483425+00:00", + "value": "2023-02-12T10:52:14.483425+00:00", "format": "RFC3339" } } @@ -581,11 +581,11 @@ } }, "time_start": { - "value": "2023-02-12T10:37:14.483425+00:00", + "value": "2023-02-12T10:27:14.483425+00:00", "format": "RFC3339" }, "time_end": { - "value": "2023-02-12T10:42:14.483425+00:00", + "value": "2023-02-12T10:52:14.483425+00:00", "format": "RFC3339" } } diff --git a/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_auths.json b/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_auths.json index d9a45adeb4..daa0f3d57a 100644 --- a/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_auths.json +++ b/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_auths.json @@ -36,11 +36,11 @@ } }, "time_start": { - "value": "2023-02-12T10:37:05.359502+00:00", + "value": "2023-02-12T10:27:05.359502+00:00", "format": "RFC3339" }, "time_end": { - "value": "2023-02-12T10:42:05.359502+00:00", + "value": "2023-02-12T10:52:05.359502+00:00", "format": "RFC3339" } } @@ -103,11 +103,11 @@ } }, "time_start": { - "value": "2023-02-12T10:37:05.359502+00:00", + "value": "2023-02-12T10:27:05.359502+00:00", "format": "RFC3339" }, "time_end": { - "value": "2023-02-12T10:42:05.359502+00:00", + "value": "2023-02-12T10:52:05.359502+00:00", "format": "RFC3339" } } diff --git a/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_intents.yaml b/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_intents.yaml index 7034978c94..c8c624d89f 100644 --- a/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_intents.yaml +++ b/monitoring/uss_qualifier/test_data/che/flight_intents/invalid_flight_intents.yaml @@ -23,10 +23,10 @@ intents: reference: W84 units: M time_start: - value: '2023-02-12T10:37:05.359502+00:00' + value: '2023-02-12T10:27:05.359502+00:00' format: RFC3339 time_end: - value: '2023-02-12T10:42:05.359502+00:00' + value: '2023-02-12T10:52:05.359502+00:00' format: RFC3339 state: Accepted off_nominal_volumes: [ ] @@ -77,7 +77,7 @@ intents: reference: W84 units: M time_start: - value: '2023-02-12T10:42:05.359502+00:00' + value: '2023-02-12T10:27:05.359502+00:00' format: RFC3339 time_end: value: '2023-02-12T10:57:05.359502+00:00' diff --git a/monitoring/uss_qualifier/test_data/che/flight_intents/priority_preemption.json b/monitoring/uss_qualifier/test_data/che/flight_intents/priority_preemption.json index b2fbc18685..b7830c0b1b 100644 --- a/monitoring/uss_qualifier/test_data/che/flight_intents/priority_preemption.json +++ b/monitoring/uss_qualifier/test_data/che/flight_intents/priority_preemption.json @@ -1,6 +1,6 @@ { "intents": { - "flight_1_planned_time_range_A": { + "flight_1_planned_vol_A": { "full": { "reference_time": "2023-02-12T10:34:14.483425+00:00", "request": { @@ -240,11 +240,11 @@ } }, "time_start": { - "value": "2023-02-12T10:37:14.483425+00:00", + "value": "2023-02-12T10:27:14.483425+00:00", "format": "RFC3339" }, "time_end": { - "value": "2023-02-12T10:42:14.483425+00:00", + "value": "2023-02-12T10:52:14.483425+00:00", "format": "RFC3339" } } @@ -273,9 +273,9 @@ } } }, - "flight_1_activated_time_range_A": { + "flight_1_activated_vol_A": { "delta": { - "source": "flight_1_planned_time_range_A", + "source": "flight_1_planned_vol_A", "mutation": { "request": { "operational_intent": { @@ -285,17 +285,18 @@ } } }, - "flight_1_planned_time_range_A_extended": { + "flight_1_planned_vol_A_extended": { "delta": { - "source": "flight_1_planned_time_range_A", + "source": "flight_1_planned_vol_A", "mutation": { "request": { "operational_intent": { "volumes": [ { - "time_start": { - "value": "2023-02-12T10:36:12.256896+00:00", - "format": "RFC3339" + "volume": { + "altitude_lower": { + "value": 575.0 + } } } ] @@ -304,9 +305,9 @@ } } }, - "flight_1_activated_time_range_A_extended": { + "flight_1_activated_vol_A_extended": { "delta": { - "source": "flight_1_planned_time_range_A_extended", + "source": "flight_1_planned_vol_A_extended", "mutation": { "request": { "operational_intent": { @@ -316,21 +317,21 @@ } } }, - "flight_1_planned_time_range_B": { + "flight_1_planned_vol_B": { "delta": { - "source": "flight_1_planned_time_range_A", + "source": "flight_1_planned_vol_A", "mutation": { "request": { "operational_intent": { "volumes": [ { - "time_start": { - "value": "2023-02-12T10:44:41.251669+00:00", - "format": "RFC3339" - }, - "time_end": { - "value": "2023-02-12T10:48:55.233778+00:00", - "format": "RFC3339" + "volume": { + "altitude_lower": { + "value": 650.0 + }, + "altitude_upper": { + "value": 705.0 + } } } ] @@ -339,9 +340,9 @@ } } }, - "flight_1_activated_time_range_B": { + "flight_1_activated_vol_B": { "delta": { - "source": "flight_1_planned_time_range_B", + "source": "flight_1_planned_vol_B", "mutation": { "request": { "operational_intent": { @@ -351,7 +352,7 @@ } } }, - "flight_2_planned_time_range_A": { + "flight_2_planned_vol_A": { "full": { "reference_time": "2023-02-12T10:34:14.483425+00:00", "request": { @@ -639,11 +640,11 @@ } }, "time_start": { - "value": "2023-02-12T10:37:14.483425+00:00", + "value": "2023-02-12T10:27:14.483425+00:00", "format": "RFC3339" }, "time_end": { - "value": "2023-02-12T10:42:14.483425+00:00", + "value": "2023-02-12T10:52:14.483425+00:00", "format": "RFC3339" } } @@ -672,9 +673,9 @@ } } }, - "flight_2_activated_time_range_A": { + "flight_2_activated_vol_A": { "delta": { - "source": "flight_2_planned_time_range_A", + "source": "flight_2_planned_vol_A", "mutation": { "request": { "operational_intent": { @@ -684,21 +685,21 @@ } } }, - "flight_2_activated_time_range_B": { + "flight_2_activated_vol_B": { "delta": { - "source": "flight_2_activated_time_range_A", + "source": "flight_2_activated_vol_A", "mutation": { "request": { "operational_intent": { "volumes": [ { - "time_start": { - "value": "2023-02-12T10:44:41.251669+00:00", - "format": "RFC3339" - }, - "time_end": { - "value": "2023-02-12T10:48:55.233778+00:00", - "format": "RFC3339" + "volume": { + "altitude_lower": { + "value": 650.0 + }, + "altitude_upper": { + "value": 705.0 + } } } ] @@ -707,9 +708,9 @@ } } }, - "flight_2_equal_prio_planned_time_range_B": { + "flight_2_equal_prio_planned_vol_B": { "delta": { - "source": "flight_2_activated_time_range_B", + "source": "flight_2_activated_vol_B", "mutation": { "request": { "operational_intent": { @@ -720,9 +721,9 @@ } } }, - "flight_2_equal_prio_activated_time_range_B": { + "flight_2_equal_prio_activated_vol_B": { "delta": { - "source": "flight_2_equal_prio_planned_time_range_B", + "source": "flight_2_equal_prio_planned_vol_B", "mutation": { "request": { "operational_intent": { @@ -732,9 +733,9 @@ } } }, - "flight_2_equal_prio_nonconforming_time_range_A": { + "flight_2_equal_prio_nonconforming_vol_A": { "delta": { - "source": "flight_2_equal_prio_activated_time_range_B", + "source": "flight_2_equal_prio_activated_vol_B", "mutation": { "request": { "operational_intent": { @@ -1022,11 +1023,11 @@ } }, "time_start": { - "value": "2023-02-12T10:37:14.483425+00:00", + "value": "2023-02-12T10:27:14.483425+00:00", "format": "RFC3339" }, "time_end": { - "value": "2023-02-12T10:42:14.483425+00:00", + "value": "2023-02-12T10:52:14.483425+00:00", "format": "RFC3339" } } diff --git a/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/conflicting_flights.yaml b/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/conflicting_flights.yaml index a08c345b57..cf7f2a9794 100644 --- a/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/conflicting_flights.yaml +++ b/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/conflicting_flights.yaml @@ -1,7 +1,7 @@ intents: first_flight: full: - reference_time: '2023-01-01T00:00:00+00:00' + reference_time: '2023-01-01T00:12:00+00:00' request: operational_intent: volumes: @@ -39,10 +39,10 @@ intents: reference: W84 units: M time_start: - value: '2023-01-01T00:03:00+00:00' + value: '2023-01-01T00:05:00+00:00' format: RFC3339 time_end: - value: '2023-01-01T00:08:00+00:00' + value: '2023-01-01T00:17:00+00:00' format: RFC3339 state: Accepted off_nominal_volumes: [ ] @@ -67,14 +67,11 @@ intents: mutation: request: operational_intent: - volumes: - - time_start: - value: '2023-01-01T00:03:00+00:00' state: Activated conflicting_flight: full: - reference_time: '2023-01-01T00:00:00+00:00' + reference_time: '2023-01-01T00:12:00+00:00' request: operational_intent: volumes: @@ -102,10 +99,10 @@ intents: reference: W84 units: M time_start: - value: '2023-01-01T00:05:20+00:00' + value: '2023-01-01T00:06:20+00:00' format: RFC3339 time_end: - value: '2023-01-01T00:10:40+00:00' + value: '2023-01-01T00:20:40+00:00' format: RFC3339 state: Accepted off_nominal_volumes: [ ] diff --git a/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/invalid_flight_intents.yaml b/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/invalid_flight_intents.yaml index c09c16b41f..01ddb804a7 100644 --- a/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/invalid_flight_intents.yaml +++ b/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/invalid_flight_intents.yaml @@ -1,7 +1,7 @@ intents: valid_flight: full: - reference_time: '2023-01-01T00:00:00+00:00' + reference_time: '2023-01-01T00:12:00+00:00' request: operational_intent: volumes: @@ -23,10 +23,10 @@ intents: reference: W84 units: M time_start: - value: '2023-01-01T00:03:00+00:00' + value: '2023-01-01T00:05:00+00:00' format: RFC3339 time_end: - value: '2023-01-01T00:08:00+00:00' + value: '2023-01-01T00:17:00+00:00' format: RFC3339 state: Accepted off_nominal_volumes: [ ] @@ -77,10 +77,10 @@ intents: reference: W84 units: M time_start: - value: '2023-01-01T00:08:00+00:00' + value: '2023-01-01T00:05:00+00:00' format: RFC3339 time_end: - value: '2023-01-01T00:09:00+00:00' + value: '2023-01-01T00:20:00+00:00' format: RFC3339 invalid_activated_offnominal: diff --git a/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/priority_preemption.yaml b/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/priority_preemption.yaml index a3d6ceb179..fd663fd895 100644 --- a/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/priority_preemption.yaml +++ b/monitoring/uss_qualifier/test_data/usa/kentland/flight_intents/priority_preemption.yaml @@ -1,7 +1,7 @@ intents: - flight_1_planned_time_range_A: + flight_1_planned_vol_A: full: - reference_time: '2023-01-01T00:00:00+00:00' + reference_time: '2023-01-01T00:12:00+00:00' request: operational_intent: volumes: @@ -39,10 +39,10 @@ intents: reference: W84 units: M time_start: - value: '2023-01-01T00:03:00+00:00' + value: '2023-01-01T00:05:00+00:00' format: RFC3339 time_end: - value: '2023-01-01T00:08:00+00:00' + value: '2023-01-01T00:17:00+00:00' format: RFC3339 state: Accepted off_nominal_volumes: [ ] @@ -61,58 +61,57 @@ intents: uas_id: '' uas_type_certificate: '' - flight_1_activated_time_range_A: + flight_1_activated_vol_A: delta: - source: flight_1_planned_time_range_A + source: flight_1_planned_vol_A mutation: request: operational_intent: state: Activated - flight_1_planned_time_range_A_extended: + flight_1_planned_vol_A_extended: delta: - source: flight_1_planned_time_range_A + source: flight_1_planned_vol_A mutation: request: operational_intent: volumes: - - time_start: - value: '2023-01-01T00:02:00+00:00' - format: RFC3339 + - volume: + altitude_lower: + value: 425 - flight_1_activated_time_range_A_extended: + flight_1_activated_vol_A_extended: delta: - source: flight_1_planned_time_range_A_extended + source: flight_1_planned_vol_A_extended mutation: request: operational_intent: state: Activated - flight_1_planned_time_range_B: + flight_1_planned_vol_B: delta: - source: flight_1_planned_time_range_A + source: flight_1_planned_vol_A mutation: request: operational_intent: volumes: - - time_start: - value: '2023-01-01T00:09:00+00:00' - format: RFC3339 - time_end: - value: '2023-01-01T00:10:00+00:00' - format: RFC3339 + - volume: + altitude_lower: + value: 602 + altitude_upper: + value: 750 - flight_1_activated_time_range_B: + flight_1_activated_vol_B: delta: - source: flight_1_planned_time_range_B + source: flight_1_planned_vol_B mutation: request: operational_intent: state: Activated - flight_2_planned_time_range_A: + flight_2_planned_vol_A: full: - reference_time: '2023-01-01T00:00:00+00:00' + reference_time: '2023-01-01T00:12:00+00:00' request: operational_intent: volumes: @@ -140,10 +139,10 @@ intents: reference: W84 units: M time_start: - value: '2023-01-01T00:02:00+00:00' + value: '2023-01-01T00:05:00+00:00' format: RFC3339 time_end: - value: '2023-01-01T00:12:15+00:00' + value: '2023-01-01T00:17:00+00:00' format: RFC3339 state: Accepted off_nominal_volumes: [ ] @@ -162,48 +161,47 @@ intents: uas_id: '' uas_type_certificate: '' - flight_2_activated_time_range_A: + flight_2_activated_vol_A: delta: - source: flight_2_planned_time_range_A + source: flight_2_planned_vol_A mutation: request: operational_intent: state: Activated - flight_2_activated_time_range_B: + flight_2_activated_vol_B: delta: - source: flight_2_activated_time_range_A + source: flight_2_activated_vol_A mutation: request: operational_intent: volumes: - - time_start: - value: '2023-01-01T00:09:00+00:00' - format: RFC3339 - time_end: - value: '2023-01-01T00:10:00+00:00' - format: RFC3339 + - volume: + altitude_lower: + value: 483 + altitude_upper: + value: 519 - flight_2_equal_prio_planned_time_range_B: + flight_2_equal_prio_planned_vol_B: delta: - source: flight_2_activated_time_range_B + source: flight_2_activated_vol_B mutation: request: operational_intent: state: Accepted priority: 0 - flight_2_equal_prio_activated_time_range_B: + flight_2_equal_prio_activated_vol_B: delta: - source: flight_2_equal_prio_planned_time_range_B + source: flight_2_equal_prio_planned_vol_B mutation: request: operational_intent: state: Activated - flight_2_equal_prio_nonconforming_time_range_A: + flight_2_equal_prio_nonconforming_vol_A: delta: - source: flight_2_equal_prio_activated_time_range_B + source: flight_2_equal_prio_activated_vol_B mutation: request: operational_intent: @@ -233,8 +231,8 @@ intents: reference: W84 units: M time_start: - value: '2023-01-01T00:02:00+00:00' + value: '2023-01-01T00:05:00+00:00' format: RFC3339 time_end: - value: '2023-01-01T00:12:15+00:00' + value: '2023-01-01T00:17:00+00:00' format: RFC3339