Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[uss_qualifier] Make severity optional in record_failed #405

Merged
merged 2 commits into from
Dec 15, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 37 additions & 0 deletions monitoring/uss_qualifier/configurations/dev/uspace_f3548.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Configuration to run just the ASTM F3548-21 part of the uspace.yaml configuration
v1:
test_run:
resources:
$ref: ./uspace.yaml#/v1/test_run/resources
action:
$ref: ./uspace.yaml#/v1/test_run/action
execution:
stop_fast: true
skip_action_when:
- is_test_scenario: {}
except_when:
- has_ancestor:
which:
- is_test_suite: {}
regex_matches_name: ASTM F3548-21
- is_test_scenario: {}
regex_matches_name: Configure mock_uss locality
- is_test_scenario: {}
regex_matches_name: Unconfigure mock_uss locality
artifacts:
$ref: ./uspace.yaml#/v1/artifacts
validation:
criteria:
- applicability:
test_scenarios: {}
pass_condition:
each_element:
has_execution_error: false
- applicability:
failed_checks:
has_severity:
higher_than: Low
pass_condition:
elements:
count:
equal_to: 0
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ The flight planners subject to evaluation.
In this step, all successful requests for operational intent details made to the USSs that are part of the flight
planners provided as resource are used to determine and evaluate the 95th percentile of the requests durations.

#### Operational intent details requests take no more than [MaxRespondToOIDetailsRequest] second 95% of the time check
#### ⚠️ Operational intent details requests take no more than [MaxRespondToOIDetailsRequest] second 95% of the time check

If the 95th percentile of the requests durations is higher than the threshold `MaxRespondToOIDetailsRequest` (1 second),
this check will fail per **[astm.f3548.v21.SCD0075](../../../requirements/astm/f3548/v21.md)**.
Expand All @@ -27,7 +27,7 @@ this check will fail per **[astm.f3548.v21.SCD0075](../../../requirements/astm/f

This step verifies that interactions with the interoperability test instances happened and where at least partly successful.

#### Interoperability test instance is available check
#### ⚠️ Interoperability test instance is available check

This check ensures that interactions with the interoperability test instance that each USS must provide are possible.

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@

from monitoring.monitorlib import fetch
from monitoring.monitorlib.fetch import evaluation, QueryType
from monitoring.uss_qualifier.common_data_definitions import Severity
from monitoring.uss_qualifier.configurations.configuration import ParticipantID
from monitoring.uss_qualifier.resources.flight_planning import FlightPlannersResource
from monitoring.uss_qualifier.scenarios.scenario import TestScenario
Expand Down Expand Up @@ -115,7 +114,6 @@ def _op_intent_details_step(self):
if p95 > constants.MaxRespondToOIDetailsRequestSeconds:
check.record_failed(
summary=f"95th percentile of durations for operational intent details requests to USS is higher than threshold",
severity=Severity.Medium,
participants=[participant],
details=f"threshold: {constants.MaxRespondToOIDetailsRequestSeconds}s, 95th percentile: {p95}s",
)
Expand Down Expand Up @@ -174,7 +172,6 @@ def _validate_participant_test_interop_instance(
if not success:
check.record_failed(
summary=f"No successful {query_type} interaction with interoperability test instance",
severity=Severity.Medium,
details=f"Found no successful {query_type} interaction with interoperability test instance, "
f"indicating that the test instance is either not available or not properly implemented.",
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,12 @@ A resources.astm.f3548.v21.DSSInstancesResource containing at least two DSS inst

### Test environment requirements test step

#### DSS instance is publicly addressable check
#### 🛑 DSS instance is publicly addressable check

As per **[astm.f3548.v21.DSS0300](../../../requirements/astm/f3548/v21.md)** the DSS instance should be publicly addressable.
As such, this check will fail if the resolved IP of the DSS host is a private IP address, unless that is explicitly
expected.

#### DSS instance is reachable check
#### 🛑 DSS instance is reachable check
As per **[astm.f3548.v21.DSS0300](../../../requirements/astm/f3548/v21.md)** the DSS instance should be publicly addressable.
As such, this check will fail if the DSS is not reachable with a dummy query.
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@
from monitoring.uss_qualifier.suites.suite import ExecutionContext
from uas_standards.astm.f3548.v21.api import Volume4D, Volume3D, Polygon, LatLngPoint

from monitoring.uss_qualifier.common_data_definitions import Severity
from monitoring.uss_qualifier.resources.astm.f3548.v21.dss import (
DSSInstancesResource,
DSSInstanceResource,
Expand Down Expand Up @@ -70,7 +69,6 @@ def _test_env_reqs(self):
elif ipaddress.ip_address(ip_addr).is_private:
check.record_failed(
summary=f"DSS host {parsed_url.netloc} is not publicly addressable",
severity=Severity.Medium,
participants=[dss.participant_id],
details=f"DSS (URL: {dss.base_url}, netloc: {parsed_url.netloc}, resolved IP: {ip_addr}) is not publicly addressable",
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -213,5 +213,5 @@ original accepted request), or it should have been removed (because the USS reje


## Cleanup
### Successful flight deletion check
### ⚠️ Successful flight deletion check
**[interuss.automated_testing.flight_planning.DeleteFlightSuccess](../../../../../requirements/interuss/automated_testing/flight_planning.md)**
Original file line number Diff line number Diff line change
Expand Up @@ -58,17 +58,17 @@ The setup will create two separate operational intents: one for each set of the

### Ensure clean workspace test step

#### Operational intents can be queried directly by their ID check
#### 🛑 Operational intents can be queried directly by their ID check

If an existing operational intent cannot directly be queried by its ID, the DSS implementation is in violation of
**[astm.f3548.v21.DSS0005](../../../requirements/astm/f3548/v21.md)**.

#### Operational intents can be searched using valid credentials check
#### 🛑 Operational intents can be searched using valid credentials check

A client with valid credentials should be allowed to search for operational intents in a given area.
Otherwise, the DSS is not in compliance with **[astm.f3548.v21.DSS0005](../../../requirements/astm/f3548/v21.md)**.

#### Operational intents can be deleted by their owner check
#### 🛑 Operational intents can be deleted by their owner check

If an existing operational intent cannot be deleted when providing the proper ID and OVN, the DSS implementation is in violation of
**[astm.f3548.v21.DSS0005](../../../requirements/astm/f3548/v21.md)**.
Expand All @@ -79,12 +79,12 @@ This test step ensures that an operation intent created with the main credential

To verify that the second credentials are valid, it will also create an operational intent with those credentials.

#### Can create an operational intent with valid credentials check
#### 🛑 Can create an operational intent with valid credentials check

If the DSS does not allow the creation of operation intents when the required parameters and credentials are provided,
it is in violation of **[astm.f3548.v21.DSS0005](../../../requirements/astm/f3548/v21.md)**.

#### Passed sets of credentials are different check
#### 🛑 Passed sets of credentials are different check

This scenario requires two sets of credentials that have a different 'sub' claim in order to validate that the
DSS properly controls access to operational intents.
Expand All @@ -98,29 +98,29 @@ This test case ensures that the DSS does not allow a caller to modify or delete
This test step will attempt to modify the operational intent that was created using the configured `dss` resource,
using the credentials provided in the `second_utm_auth` resource, and expect all such attempts to fail.

#### Operational intents can be queried directly by their ID check
#### 🛑 Operational intents can be queried directly by their ID check

If an existing operational intent cannot directly be queried by its ID, the DSS implementation is in violation of
**[astm.f3548.v21.DSS0005](../../../requirements/astm/f3548/v21.md)**.

#### Non-owning credentials cannot modify operational intent check
#### 🛑 Non-owning credentials cannot modify operational intent check

If an operational intent can be modified by a client which did not create it, the DSS implementation is
in violation of **[astm.f3548.v21.OPIN0035](../../../requirements/astm/f3548/v21.md)**.

#### Non-owning credentials cannot delete operational intent check
#### 🛑 Non-owning credentials cannot delete operational intent check

If an operational intent can be deleted by a client which did not create it, the DSS implementation is
in violation of **[astm.f3548.v21.OPIN0035](../../../requirements/astm/f3548/v21.md)**.

## Cleanup

### Operational intents can be queried directly by their ID check
### 🛑 Operational intents can be queried directly by their ID check

If an existing operational intent cannot directly be queried by its ID, the DSS implementation is in violation of
**[astm.f3548.v21.DSS0005](../../../requirements/astm/f3548/v21.md)**.

### Operational intents can be deleted by their owner check
### 🛑 Operational intents can be deleted by their owner check

If an existing operational intent cannot be deleted when providing the proper ID and OVN, the DSS implementation is in violation of
**[astm.f3548.v21.DSS0005](../../../requirements/astm/f3548/v21.md)**.
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
from typing import Optional, List
from typing import List

import loguru
from uas_standards.astm.f3548.v21.api import OperationalIntentState

from monitoring.monitorlib.geotemporal import Volume4DCollection
from uas_standards.astm.f3548.v21 import api as f3548v21
from monitoring.prober.infrastructure import register_resource_type
from monitoring.uss_qualifier.common_data_definitions import Severity
from monitoring.uss_qualifier.resources.astm.f3548.v21 import DSSInstanceResource
from monitoring.uss_qualifier.resources.astm.f3548.v21.dss import (
DSSInstance,
Expand Down Expand Up @@ -133,8 +132,7 @@ def _clean_known_op_intents_ids(self):
if q.response.status_code not in [200, 404]:
check.record_failed(
f"Could not access operational intent using main credentials",
Severity.High,
f"DSS responded with {q.response.status_code} to attempt to access OI {self._oid_1}",
details=f"DSS responded with {q.response.status_code} to attempt to access OI {self._oid_1}",
query_timestamps=[q.request.timestamp],
)
if q.response.status_code != 404:
Expand All @@ -146,8 +144,7 @@ def _clean_known_op_intents_ids(self):
) as check:
check.record_failed(
f"Could not delete operational intent using main credentials",
Severity.High,
f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_1}",
details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_1}",
query_timestamps=[dq.request.timestamp],
)

Expand All @@ -159,8 +156,7 @@ def _clean_known_op_intents_ids(self):
if q.response.status_code not in [200, 404]:
check.record_failed(
f"Could not access operational intent using second credentials",
Severity.High,
f"DSS responded with {q.response.status_code} to attempt to access OI {self._oid_2}",
details=f"DSS responded with {q.response.status_code} to attempt to access OI {self._oid_2}",
query_timestamps=[q.request.timestamp],
)
if q.response.status_code != 404:
Expand All @@ -174,8 +170,7 @@ def _clean_known_op_intents_ids(self):
if dq.response.status_code != 200:
check.record_failed(
f"Could not delete operational intent using second credentials",
Severity.High,
f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_2}",
details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_2}",
query_timestamps=[dq.request.timestamp],
)

Expand All @@ -192,8 +187,7 @@ def _ensure_clean_workspace(self):
if q.response.status_code != 200:
check.record_failed(
f"Could not search operational intents using main credentials",
Severity.High,
f"DSS responded with {q.response.status_code} to attempt to search OIs",
details=f"DSS responded with {q.response.status_code} to attempt to search OIs",
query_timestamps=[q.request.timestamp],
)

Expand All @@ -208,8 +202,7 @@ def _ensure_clean_workspace(self):
if dq.response.status_code != 200:
check.record_failed(
f"Could not delete operational intent using main credentials",
Severity.High,
f"DSS responded with {dq.response.status_code} to attempt to delete OI {op_intent.id}",
details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {op_intent.id}",
query_timestamps=[dq.request.timestamp],
)

Expand All @@ -223,8 +216,7 @@ def _ensure_clean_workspace(self):
if q.response.status_code != 200:
check.record_failed(
f"Could not search operational intents using second credentials",
Severity.High,
f"DSS responded with {q.response.status_code} to attempt to search OIs",
details=f"DSS responded with {q.response.status_code} to attempt to search OIs",
query_timestamps=[q.request.timestamp],
)

Expand All @@ -244,8 +236,7 @@ def _ensure_clean_workspace(self):
if dq.response.status_code != 200:
check.record_failed(
f"Could not delete operational intent using second credentials",
Severity.High,
f"DSS responded with {dq.response.status_code} to attempt to delete OI {op_intent.id}",
details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {op_intent.id}",
query_timestamps=[dq.request.timestamp],
)

Expand All @@ -265,8 +256,7 @@ def _create_op_intents(self):
if q1.response.status_code != 201:
check.record_failed(
f"Could not create operational intent using main credentials",
Severity.High,
f"DSS responded with {q1.response.status_code} to attempt to create OI {self._oid_1}",
details=f"DSS responded with {q1.response.status_code} to attempt to create OI {self._oid_1}",
query_timestamps=[q1.request.timestamp],
)

Expand All @@ -288,8 +278,7 @@ def _create_op_intents(self):
if q2.response.status_code != 201:
check.record_failed(
f"Could not create operational intent using second credentials",
Severity.High,
f"DSS responded with {q2.response.status_code} to attempt to create OI {self._oid_2}",
details=f"DSS responded with {q2.response.status_code} to attempt to create OI {self._oid_2}",
query_timestamps=[q2.request.timestamp],
)

Expand All @@ -306,8 +295,7 @@ def _ensure_credentials_are_different(self):
):
check.record_failed(
f"Second set of credentials is not different from the first",
Severity.High,
f"The same credentials were provided for the main 'dss' and the additional 'second_utm_auth'"
details=f"The same credentials were provided for the main 'dss' and the additional 'second_utm_auth'"
f" resources ({self._dss.client.auth_adapter.get_sub()}),",
)

Expand All @@ -329,8 +317,7 @@ def _check_mutation_on_non_owned_intent_fails(self):
if q.response.status_code != 403:
check.record_failed(
f"Could update operational intent using second credentials",
Severity.High,
f"DSS responded with {q.response.status_code} to attempt to update OI {self._oid_1}",
details=f"DSS responded with {q.response.status_code} to attempt to update OI {self._oid_1}",
query_timestamps=[q.request.timestamp],
)
# Attempt to update the base_url of the intent created with the main credentials using the second credentials
Expand All @@ -350,8 +337,7 @@ def _check_mutation_on_non_owned_intent_fails(self):
if q.response.status_code != 403:
check.record_failed(
f"Could update operational intent using second credentials",
Severity.High,
f"DSS responded with {q.response.status_code} to attempt to update OI {self._oid_1}",
details=f"DSS responded with {q.response.status_code} to attempt to update OI {self._oid_1}",
query_timestamps=[q.request.timestamp],
)

Expand All @@ -367,8 +353,7 @@ def _check_mutation_on_non_owned_intent_fails(self):
if dq.response.status_code != 403:
check.record_failed(
f"Could delete operational intent using second credentials",
Severity.High,
f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_1}",
details=f"DSS responded with {dq.response.status_code} to attempt to delete OI {self._oid_1}",
query_timestamps=[dq.request.timestamp],
)

Expand All @@ -382,8 +367,7 @@ def _check_mutation_on_non_owned_intent_fails(self):
if qcheck.response.status_code != 200:
check.record_failed(
f"Could not access operational intent using main credentials",
Severity.High,
f"DSS responded with {qcheck.response.status_code} to attempt to access OI {self._oid_1} "
details=f"DSS responded with {qcheck.response.status_code} to attempt to access OI {self._oid_1} "
f"while this OI should have been available.",
query_timestamps=[qcheck.request.timestamp],
)
Expand All @@ -395,8 +379,7 @@ def _check_mutation_on_non_owned_intent_fails(self):
if op_1_current != self._current_ref_1:
check.record_failed(
f"Could update operational intent using second credentials",
Severity.High,
f"Operational intent {self._oid_1} was modified by second credentials",
details=f"Operational intent {self._oid_1} was modified by second credentials",
query_timestamps=[q.request.timestamp, qcheck.request.timestamp],
)

Expand Down
Loading
Loading