From 66cfbc4c45b7abb4792dba2babda8ab053cc2986 Mon Sep 17 00:00:00 2001 From: Pavel Novotny Date: Wed, 20 Nov 2024 15:23:32 +0100 Subject: [PATCH] host: tests for new search options (#15539) hosts: new tests for searching with more options Two new tests were added for searching hosts with new options: - reported data, like, BIOS vendor, version, etc. - new alias `configuration_status` for `status` (cherry picked from commit f9eacdc8646b1a13da06fb09a98d546d572c0499) --- tests/foreman/ui/test_host.py | 83 +++++++++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) diff --git a/tests/foreman/ui/test_host.py b/tests/foreman/ui/test_host.py index f8708888da9..c537c47586d 100644 --- a/tests/foreman/ui/test_host.py +++ b/tests/foreman/ui/test_host.py @@ -866,6 +866,89 @@ def test_positive_search_by_parameter(session, module_org, smart_proxy_location, assert values[0]['Name'] == param_host.name +@pytest.mark.tier2 +@pytest.mark.rhel_ver_match('8') +@pytest.mark.no_containers +def test_positive_search_by_reported_data( + target_sat, rhel_contenthost, module_org, module_ak_with_cv +): + """ + Search for host by reported data. + For example, search by `reported.bios_vendor = SeaBIOS`. + + :id: 54341d00-34bc-11ef-a8a6-000c29a0e355 + + :expectedresults: Return only hosts matching the reported data. + + :Verifies: SAT-9132 + + :customerscenario: true + """ + result = rhel_contenthost.register(module_org, None, module_ak_with_cv.name, target_sat) + assert result.status == 0, f'Failed to register host: {result.stderr}' + client = rhel_contenthost + + reported_data_params = [ + 'bios_release_date', + 'bios_vendor', + 'bios_version', + ] + source_host = client.nailgun_host + assert source_host.reported_data, f'Source host {client.hostname} does not report any data.' + source_reported_data = source_host.reported_data + + with target_sat.ui_session() as session: + session.organization.select(org_name=ANY_CONTEXT['org']) + session.location.select(loc_name=ANY_CONTEXT['location']) + + for param_name in reported_data_params: + param_value = source_reported_data[param_name] + search_string = f'reported.{param_name} = {param_value}' + api_hosts = target_sat.api.Host().search(query={'search': search_string}) + ui_hosts = session.host.search(search_string) + assert set([host.name for host in api_hosts]) == set( + [host['Name'] for host in ui_hosts] + ) + + +@pytest.mark.tier2 +@pytest.mark.usefixtures('function_host') +def test_positive_search_by_configuration_status_alias(target_sat): + """ + Search for host by new alias `configuration_status`. + + :id: 6af725d2-44fe-4b04-a8d6-ce8321a673d4 + + :expectedresults: Searching hosts by original `status` and new alias `configuration_status` + returns the same results. + + :Verifies: SAT-9132 + + :customerscenario: true + """ + status_search_term = Box(name='status', alias='configuration_status') + search_params = [ + 'enabled = true', + 'failed >= 0', + 'failed_restarts >= 0', + 'applied >= 0', + 'pending >= 0', + ] + + with target_sat.ui_session() as session: + session.organization.select(org_name=ANY_CONTEXT['org']) + session.location.select(loc_name=ANY_CONTEXT['location']) + + for search_param in search_params: + results = {} + for search_term in status_search_term.values(): + search_string = f'{search_term}.{search_param}' + results[search_term] = [host['Name'] for host in session.host.search(search_string)] + assert ( + results[status_search_term.name] == results[status_search_term.alias] + ), f'Different search results were found: {results}' + + @pytest.mark.tier4 def test_positive_search_by_parameter_with_different_values( session, module_org, smart_proxy_location, target_sat