diff --git a/build/dev/docker-compose.yaml b/build/dev/docker-compose.yaml index 4372c800dd..bc962f13bb 100644 --- a/build/dev/docker-compose.yaml +++ b/build/dev/docker-compose.yaml @@ -25,8 +25,8 @@ services: start_interval: 5s rid_bootstrapper: - image: interuss/dss:v0.18.0-rc1 - command: /usr/bin/db-manager --schemas_dir=/db-schemas/rid --db_version "latest" --cockroach_host crdb + image: interuss/dss:v0.19.0-rc2 + command: /usr/bin/db-manager migrate --schemas_dir=/db-schemas/rid --db_version "latest" --cockroach_host crdb depends_on: crdb: condition: service_healthy @@ -34,8 +34,8 @@ services: - dss_internal_network scd_bootstrapper: - image: interuss/dss:v0.18.0-rc1 - command: /usr/bin/db-manager --schemas_dir=/db-schemas/scd --db_version "latest" --cockroach_host crdb + image: interuss/dss:v0.19.0-rc2 + command: /usr/bin/db-manager migrate --schemas_dir=/db-schemas/scd --db_version "latest" --cockroach_host crdb depends_on: crdb: condition: service_healthy @@ -44,7 +44,7 @@ services: dss: hostname: dss.uss1.localutm - image: interuss/dss:v0.18.0-rc1 + image: interuss/dss:v0.19.0-rc2 volumes: - $PWD/../test-certs:/var/test-certs:ro - $PWD/startup/core_service.sh:/startup/core_service.sh:ro diff --git a/interfaces/automated_testing b/interfaces/automated_testing index 4e07f46eb4..417797f42e 160000 --- a/interfaces/automated_testing +++ b/interfaces/automated_testing @@ -1 +1 @@ -Subproject commit 4e07f46eb4452da761fb1658d3775d801d19312b +Subproject commit 417797f42e8ebd7cc1b71e82ec0fee0fe1e972a1 diff --git a/monitoring/uss_qualifier/configurations/dev/dss_probing.yaml b/monitoring/uss_qualifier/configurations/dev/dss_probing.yaml index 8e4e1b240d..57047b0c01 100644 --- a/monitoring/uss_qualifier/configurations/dev/dss_probing.yaml +++ b/monitoring/uss_qualifier/configurations/dev/dss_probing.yaml @@ -64,4 +64,4 @@ v1: pass_condition: elements: count: - equal_to: 8 # 6 CRDBAccess + 2 DSSOVNRequest scenarios are skipped + equal_to: 6 # 6 CRDBAccess scenarios are skipped diff --git a/monitoring/uss_qualifier/configurations/dev/f3548_self_contained.yaml b/monitoring/uss_qualifier/configurations/dev/f3548_self_contained.yaml index 5e2753d55a..570d1fd72c 100644 --- a/monitoring/uss_qualifier/configurations/dev/f3548_self_contained.yaml +++ b/monitoring/uss_qualifier/configurations/dev/f3548_self_contained.yaml @@ -134,6 +134,7 @@ v1: # A USS that hosts a DSS instance is also a participant in the test, even if they don't fulfill any other roles participant_id: uss1_dss base_url: http://dss.uss1.localutm + supports_ovn_request: true dss_instances: resource_type: resources.astm.f3548.v21.DSSInstancesResource @@ -146,8 +147,10 @@ v1: # Participants using a DSS instance they do not provide should be listed as users of that DSS (so that they can take credit for USS requirements enforced by the DSS) - mock_uss # mock_uss uses this DSS instance; it does not provide its own instance base_url: http://dss.uss1.localutm + supports_ovn_request: true - participant_id: uss2_dss base_url: http://dss.uss2.localutm + supports_ovn_request: true # Mock USS that can be used in tests for flight planning, modifying data sharing behavior and recording interactions mock_uss: diff --git a/monitoring/uss_qualifier/configurations/dev/library/environment_containers.yaml b/monitoring/uss_qualifier/configurations/dev/library/environment_containers.yaml index c4f20098c7..3e1953d3a2 100644 --- a/monitoring/uss_qualifier/configurations/dev/library/environment_containers.yaml +++ b/monitoring/uss_qualifier/configurations/dev/library/environment_containers.yaml @@ -187,6 +187,7 @@ scd_dss: specification: participant_id: uss1 base_url: http://dss.uss1.localutm + supports_ovn_request: true scd_dss_instances: $content_schema: monitoring/uss_qualifier/resources/definitions/ResourceDeclaration.json @@ -199,8 +200,10 @@ scd_dss_instances: user_participant_ids: - mock_uss base_url: http://dss.uss1.localutm + supports_ovn_request: true - participant_id: uss2 base_url: http://dss.uss2.localutm + supports_ovn_request: true # ===== DSS CockroachDB nodes ===== diff --git a/monitoring/uss_qualifier/configurations/dev/library/environment_localhost.yaml b/monitoring/uss_qualifier/configurations/dev/library/environment_localhost.yaml index 72b47a0f85..9995889c82 100644 --- a/monitoring/uss_qualifier/configurations/dev/library/environment_localhost.yaml +++ b/monitoring/uss_qualifier/configurations/dev/library/environment_localhost.yaml @@ -186,6 +186,7 @@ scd_dss: specification: participant_id: uss1 base_url: http://localhost:8082 + supports_ovn_request: true scd_dss_instances: $content_schema: monitoring/uss_qualifier/resources/definitions/ResourceDeclaration.json @@ -198,8 +199,10 @@ scd_dss_instances: user_participant_ids: - mock_uss base_url: http://localhost:8082 + supports_ovn_request: true - participant_id: uss2 base_url: http://localhost:8082 + supports_ovn_request: true # ===== DSS CockroachDB nodes ===== diff --git a/monitoring/uss_qualifier/configurations/dev/uspace.yaml b/monitoring/uss_qualifier/configurations/dev/uspace.yaml index 95d0b576a8..0d9f03d7b9 100644 --- a/monitoring/uss_qualifier/configurations/dev/uspace.yaml +++ b/monitoring/uss_qualifier/configurations/dev/uspace.yaml @@ -155,4 +155,4 @@ v1: pass_condition: elements: count: - equal_to: 6 # 4 CRDBAccess + 2 DSSOVNRequest scenarios are skipped + equal_to: 4 # 4 CRDBAccess scenarios are skipped diff --git a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/baseline.libsonnet b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/baseline.libsonnet index 1c1373067e..3d58485c33 100644 --- a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/baseline.libsonnet +++ b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/baseline.libsonnet @@ -419,7 +419,7 @@ function(env) { count: { // We currently expect this amount of skipped scenarios: making it an equality // to make sure this is reduced if some scenarios start to be executed - equal_to: 11, + equal_to: 9, }, }, }, diff --git a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/local/env.libsonnet b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/local/env.libsonnet index 0c24b3a8bd..b661f85166 100644 --- a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/local/env.libsonnet +++ b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/local/env.libsonnet @@ -89,6 +89,7 @@ function(participants) { // A USS that hosts a DSS instance is also a participant in the test, even if they don't fulfill any other roles participant_id: 'uss1_dss', base_url: 'http://dss.uss1.localutm', + supports_ovn_request: true, }, }, diff --git a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss1.libsonnet b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss1.libsonnet index d1ac6224b0..aba53512ae 100644 --- a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss1.libsonnet +++ b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss1.libsonnet @@ -44,6 +44,7 @@ 'mock_uss', // mock_uss uses this DSS instance; it does not provide its own instance ], base_url: 'http://dss.uss1.localutm', + supports_ovn_request: true }, ] } diff --git a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss2.libsonnet b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss2.libsonnet index 44d702f43a..1ff50d624c 100644 --- a/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss2.libsonnet +++ b/monitoring/uss_qualifier/configurations/dev/utm_implementation_us_lib/uss2.libsonnet @@ -40,6 +40,7 @@ { participant_id: 'uss2_dss', base_url: 'http://dss.uss2.localutm', + supports_ovn_request: true, }, ] } diff --git a/monitoring/uss_qualifier/scenarios/astm/netrid/display_data_evaluator.py b/monitoring/uss_qualifier/scenarios/astm/netrid/display_data_evaluator.py index fc9312bf3a..43f53b7e76 100644 --- a/monitoring/uss_qualifier/scenarios/astm/netrid/display_data_evaluator.py +++ b/monitoring/uss_qualifier/scenarios/astm/netrid/display_data_evaluator.py @@ -6,6 +6,8 @@ import s2sphere from loguru import logger from s2sphere import LatLng, LatLngRect +from uas_standards.astm.f3411.v22a.api import RIDHeightReference + from uas_standards.interuss.automated_testing.rid.v1.observation import ( Flight, GetDisplayDataResponse, @@ -50,6 +52,7 @@ def _rect_str(rect) -> str: VERTICAL_SPEED_PRECISION = 0.1 SPEED_PRECISION = 0.05 TIMESTAMP_ACCURACY_PRECISION = 0.05 +HEIGHT_PRECISION_M = 1 @dataclass @@ -1088,6 +1091,42 @@ def _evaluate_normal_sp_observation( details=f"Timestamp accuracy in Service Provider {mapping.injected_flight.uss_participant_id}'s response for flight with injection ID {mapping.injected_flight.flight.injection_id} in test {mapping.injected_flight.test_id} with telemetry index {mapping.telemetry_index} is {mapping.observed_flight.timestamp_accuracy} which is not equal to the injected value of {injected_telemetry.timestamp_accuracy}", ) + if "height" in injected_position: + # We injected a height so expect to observe one + if "height" not in observed_position: + check.record_failed( + "A value was injected for the height field, but none was returned in Service Provider response", + details=f"{mapping.injected_flight.uss_participant_id}'s flight with injection ID {mapping.injected_flight.flight.injection_id} in test {mapping.injected_flight.test_id} had a height injected, but Service Provider did not return a height at {mapping.observed_flight.query.query.request.initiated_at}", + ) + else: + if ( + injected_position.height.reference.value + != observed_position.height.reference.value + ): + check.record_failed( + "Height reference reported by Service Provider does not match injected height reference", + details=f"{mapping.injected_flight.uss_participant_id}'s flight with injection ID {mapping.injected_flight.flight.injection_id} in test {mapping.injected_flight.test_id} had telemetry index {mapping.telemetry_index} at {injected_telemetry.timestamp} with height={injected_position.height.distance} {injected_position.height.reference.value}, but Service Provider reported height={observed_position.height.distance} {observed_position.height.reference.value} at {mapping.observed_flight.query.query.request.initiated_at}", + ) + if not math.isclose( + injected_position.height.distance, + observed_position.height.distance, + abs_tol=HEIGHT_PRECISION_M, + ): + check.record_failed( + "Height reported by Service Provider does not match injected height", + details=f"{mapping.injected_flight.uss_participant_id}'s flight with injection ID {mapping.injected_flight.flight.injection_id} in test {mapping.injected_flight.test_id} had telemetry index {mapping.telemetry_index} at {injected_telemetry.timestamp} with height={injected_position.height.distance} {injected_position.height.reference.value}, but Service Provider reported height={observed_position.height.distance} {observed_position.height.reference.value} at {mapping.observed_flight.query.query.request.initiated_at}", + ) + else: + # We did not inject a height, but a height returning the magic 'unknown' value would still be seen as valid + if "height" in observed_position: + if not math.isclose( + observed_position.height.distance, -1000, abs_tol=1 + ): + check.record_failed( + "Injected no height, but Service Provider reported a height", + details=f"{mapping.injected_flight.uss_participant_id}'s flight with injection ID {mapping.injected_flight.flight.injection_id} in test {mapping.injected_flight.test_id} had no height injected, but Service Provider reported height={observed_position.height.distance} {observed_position.height.reference.value} at {mapping.observed_flight.query.query.request.initiated_at}", + ) + # Verify that flight details queries succeeded and returned correctly-formatted data for mapping in mappings.values(): details_queries = [ diff --git a/monitoring/uss_qualifier/scenarios/astm/netrid/v19/nominal_behavior.md b/monitoring/uss_qualifier/scenarios/astm/netrid/v19/nominal_behavior.md index 1da64737ba..48a347c29f 100644 --- a/monitoring/uss_qualifier/scenarios/astm/netrid/v19/nominal_behavior.md +++ b/monitoring/uss_qualifier/scenarios/astm/netrid/v19/nominal_behavior.md @@ -120,6 +120,10 @@ If the timestamp accuracy is not present, the USS under test is not properly imp **[astm.f3411.v19.NET0260,Table1,5](../../../../requirements/astm/f3411/v19.md)** requires that relevant Remote ID data, consistent with the common data dictionary, be reported by the Service Provider. The observed timestamp accuracy differs from the injected one. +#### ⚠️ Service Provider height check + +**[astm.f3411.v19.NET0260,Table1,13](../../../../requirements/astm/f3411/v19.md)** requires that relevant Remote ID data, consistent with the common data dictionary, be reported by the Service Provider. The reported height of the flight is unrealistic or otherwise not consistent with the injected data. + #### Successful flight details query check **[astm.f3411.v19.NET0710,2](../../../../requirements/astm/f3411/v19.md)** and **[astm.f3411.v19.NET0340](../../../../requirements/astm/f3411/v19.md)** require a Service Provider to implement the GET flight details endpoint. This check will fail if uss_qualifier cannot query that endpoint (specified in the ISA present in the DSS) successfully. diff --git a/monitoring/uss_qualifier/scenarios/astm/netrid/v22a/nominal_behavior.md b/monitoring/uss_qualifier/scenarios/astm/netrid/v22a/nominal_behavior.md index fcaeb8160d..4325ab4427 100644 --- a/monitoring/uss_qualifier/scenarios/astm/netrid/v22a/nominal_behavior.md +++ b/monitoring/uss_qualifier/scenarios/astm/netrid/v22a/nominal_behavior.md @@ -120,6 +120,10 @@ If the timestamp accuracy is not present, the USS under test is not properly imp **[astm.f3411.v22a.NET0260,Table1,6](../../../../requirements/astm/f3411/v22a.md)** requires that relevant Remote ID data, consistent with the common data dictionary, be reported by the Service Provider. The observed timestamp accuracy differs from the injected one. +#### ⚠️ Service Provider height check + +**[astm.f3411.v22a.NET0260,Table1,14](../../../../requirements/astm/f3411/v22a.md)** requires that relevant Remote ID data, consistent with the common data dictionary, be reported by the Service Provider. The reported height of the flight is unrealistic or otherwise not consistent with the injected data. + #### Successful flight details query check **[astm.f3411.v22a.NET0710,2](../../../../requirements/astm/f3411/v22a.md)** and **[astm.f3411.v22a.NET0340](../../../../requirements/astm/f3411/v22a.md) require a Service Provider to implement the GET flight details endpoint. This check will fail if uss_qualifier cannot query that endpoint (specified in the ISA present in the DSS) successfully. diff --git a/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.md b/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.md index e8718c5988..e6efc2a151 100644 --- a/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.md +++ b/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.md @@ -46,22 +46,22 @@ Check that the DSS has set the expected OVN correctly. This case validates the off-nominal behaviors of the OVN request. ### Attempt to create OIR with OVN suffix request not being a UUID test step -#### [Attempt to create OIR with OVN suffix request not being a UUID rejected check](./invalid_ovn_suffix_fragment.md) +#### [Attempt to create OIR with OVN suffix request not being a UUID rejected](./invalid_ovn_suffix_fragment.md) Check that the DSS rejects OVN suffix that are not UUIDs. If the DSS accepts the OVN suffix, or fails with an unexpected error, this check will fail. ### Attempt to create OIR with OVN suffix request empty test step -#### [Attempt to create OIR with OVN suffix request empty rejected check](./invalid_ovn_suffix_fragment.md) +#### [Attempt to create OIR with OVN suffix request empty rejected](./invalid_ovn_suffix_fragment.md) Check that the DSS rejects OVN suffix that are empty. If the DSS accepts the OVN suffix, or fails with an unexpected error, this check will fail. ### Attempt to create OIR with OVN suffix request being a UUID but not v7 test step -#### [Attempt to create OIR with OVN suffix request being a UUID but not v7 rejected check](./invalid_ovn_suffix_fragment.md) +#### [Attempt to create OIR with OVN suffix request being a UUID but not v7 rejected](./invalid_ovn_suffix_fragment.md) Check that the DSS rejects OVN suffix that are UUIDs but not v7. If the DSS accepts the OVN suffix, or fails with an unexpected error, this check will fail. ### Attempt to create OIR with OVN suffix request being an outdated UUIDv7 test step -#### [Attempt to create OIR with OVN suffix request being an outdated UUIDv7 rejected check](./invalid_ovn_suffix_fragment.md) +#### [Attempt to create OIR with OVN suffix request being an outdated UUIDv7 rejected](./invalid_ovn_suffix_fragment.md) Check that the DSS rejects OVN suffix that are outdated UUIDv7. If the DSS accepts the OVN suffix, or fails with an unexpected error, this check will fail. diff --git a/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.py b/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.py index 72d9e2aa53..69803cdc54 100644 --- a/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.py +++ b/monitoring/uss_qualifier/scenarios/interuss/ovn_request/dss_ovn_request.py @@ -77,7 +77,7 @@ def run(self, context: ExecutionContext): self.begin_test_step("Activate OIR with OVN suffix request") req_ovn_suffix = str(uuid7()) - self._activate_oir(extents, oir.ovn, req_ovn_suffix) + oir = self._activate_oir(extents, oir.ovn, req_ovn_suffix) self._check_expected_ovn(req_ovn_suffix, oir) self.end_test_step() @@ -165,6 +165,8 @@ def _activate_oir(self, extents: List[Volume4D], ovn: str, req_ovn_suffix: str): query_timestamps=qe.query_timestamps, ) + return oir + def _create_invalid_oir_attempt(self, extents: List[Volume4D], req_ovn_suffix: str): with self.check( "Attempt to create OIR with invalid requested OVN suffix query rejected", diff --git a/monitoring/uss_qualifier/suites/astm/netrid/f3411_19.md b/monitoring/uss_qualifier/suites/astm/netrid/f3411_19.md index 57e3292c61..23b63987b6 100644 --- a/monitoring/uss_qualifier/suites/astm/netrid/f3411_19.md +++ b/monitoring/uss_qualifier/suites/astm/netrid/f3411_19.md @@ -21,7 +21,7 @@