From cdbc7010d0f4da03c2a8f2413f69d4b5fdebc133 Mon Sep 17 00:00:00 2001 From: Jeremy Lenz Date: Thu, 28 Sep 2023 09:57:43 -0400 Subject: [PATCH] Fixes #36731 - Use facts, not operatingsystem name, to identify RHEL hosts (#10738) * Fixes #36731 - Use facts, not operatingsystem name, to identify RHEL hosts * Refs #36731 - update for optimized facts --- .../concerns/host_managed_extensions.rb | 27 +++++++++++++- .../concerns/operatingsystem_extensions.rb | 17 --------- app/models/katello/rhel_lifecycle_status.rb | 6 +-- .../concerns/host_managed_extensions_test.rb | 37 +++++++++++++++++++ .../operatingsystem_extensions_test.rb | 16 -------- test/models/rhel_lifecycle_status_test.rb | 15 ++++---- 6 files changed, 72 insertions(+), 46 deletions(-) diff --git a/app/models/katello/concerns/host_managed_extensions.rb b/app/models/katello/concerns/host_managed_extensions.rb index 58755bac1a8..bc32a67aaba 100644 --- a/app/models/katello/concerns/host_managed_extensions.rb +++ b/app/models/katello/concerns/host_managed_extensions.rb @@ -108,8 +108,6 @@ def remote_execution_proxies(provider, *_rest) delegate :content_source_id, :single_content_view, :single_lifecycle_environment, :default_environment?, :single_content_view_environment?, :multi_content_view_environment?, :kickstart_repository_id, :bound_repositories, :installable_errata, :installable_rpms, to: :content_facet, allow_nil: true - delegate :rhel_eos_schedule_index, to: :operatingsystem, allow_nil: true - has_many :content_view_environment_content_facets, through: :content_facet, class_name: 'Katello::ContentViewEnvironmentContentFacet' has_many :content_view_environments, through: :content_view_environment_content_facets has_many :content_views, through: :content_view_environments @@ -524,6 +522,31 @@ def traces_helpers(search:) ::Katello::HostTracer.helpers_for(traces) end + def probably_rhel? + # Get the os name from sub-man facts rather than operatingsystem. This is + # less likely to have been changed by the user. + os_name, = facts('distribution::name').values # only query for that one fact, then get its value + # if this fact isn't there, we can ignore it because the host is not "managed" + os_name.present? && os_name.start_with?('Red Hat Enterprise Linux') + end + + def rhel_eos_schedule_index + return nil unless probably_rhel? + major = operatingsystem.major + return "RHEL#{major}" unless major == "7" + arch_name = architecture&.name + case arch_name + when "ppc64le" + "RHEL7 (POWER9)" + when "aarch64" + "RHEL7 (ARM)" + when "s390x" + "RHEL7 (System z (Structure A))" + else + "RHEL#{major}" + end + end + def package_names_for_job_template(action:, search:, versions: nil) actions = %w(install remove update).freeze case action diff --git a/app/models/katello/concerns/operatingsystem_extensions.rb b/app/models/katello/concerns/operatingsystem_extensions.rb index 8d8875dfb4e..a824a80a86a 100644 --- a/app/models/katello/concerns/operatingsystem_extensions.rb +++ b/app/models/katello/concerns/operatingsystem_extensions.rb @@ -44,23 +44,6 @@ def set_atomic_attributes def atomic? name.match(/.*atomic.*/i) end - - def rhel_eos_schedule_index(arch_name: nil) - return nil unless name == "RedHat" # using name and not title so we get specifically RHEL, not rebuilds - return "RHEL#{major}" unless major == "7" - case arch_name - when "x86_64", nil - "RHEL7" - when "ppc64le" - "RHEL7 (POWER9)" - when "aarch64" - "RHEL7 (ARM)" - when "s390x" - "RHEL7 (System z (Structure A))" - else - "RHEL#{major}" - end - end end end end diff --git a/app/models/katello/rhel_lifecycle_status.rb b/app/models/katello/rhel_lifecycle_status.rb index 159b30dc34b..554f4f35b20 100644 --- a/app/models/katello/rhel_lifecycle_status.rb +++ b/app/models/katello/rhel_lifecycle_status.rb @@ -179,7 +179,7 @@ def maintenance_support_end_date end def rhel_eos_schedule_index - host&.operatingsystem&.rhel_eos_schedule_index(arch_name: host&.arch&.name) + host&.rhel_eos_schedule_index end def to_global(_options = {}) @@ -195,12 +195,12 @@ def to_global(_options = {}) end def to_status - self.class.to_status(rhel_eos_schedule_index: self.host&.operatingsystem&.rhel_eos_schedule_index) + self.class.to_status(rhel_eos_schedule_index: self.host&.rhel_eos_schedule_index) end # this status is only relevant for RHEL def relevant?(_options = {}) - host&.operatingsystem&.rhel_eos_schedule_index + host&.rhel_eos_schedule_index.present? end end end diff --git a/test/models/concerns/host_managed_extensions_test.rb b/test/models/concerns/host_managed_extensions_test.rb index 12c41750145..3ec02db1b5e 100644 --- a/test/models/concerns/host_managed_extensions_test.rb +++ b/test/models/concerns/host_managed_extensions_test.rb @@ -423,6 +423,43 @@ def test_search_known_traces class HostRhelEosSchedulesTest < ActiveSupport::TestCase let(:host) { FactoryBot.create(:host, :with_subscription) } + def test_probably_rhel? + host.expects(:facts).with('distribution::name').returns({'distribution::name' => 'Red Hat Enterprise Linux'}) + assert host.probably_rhel? + end + + def test_probably_not_rhel + host.expects(:facts).with('distribution::name').returns({'distribution::name' => 'CentOS'}) + refute host.probably_rhel? + end + + def test_rhel_eos_schedule_index + os = Operatingsystem.create!(:name => "RedHat", :major => "7", :minor => "3") + host.expects(:facts).at_least_once.returns({'distribution::name' => 'Red Hat Enterprise Linux Server'}) + host.operatingsystem = os + host.architecture = architectures(:x86_64) + host.architecture.expects(:name).at_least_once.returns("x86_64") + assert_equal "RHEL7", host.rhel_eos_schedule_index + host.architecture.expects(:name).returns("ppc64le") + assert_equal "RHEL7 (POWER9)", host.rhel_eos_schedule_index + host.architecture.expects(:name).returns("aarch64") + assert_equal "RHEL7 (ARM)", host.rhel_eos_schedule_index + host.architecture.expects(:name).returns("s390x") + assert_equal "RHEL7 (System z (Structure A))", host.rhel_eos_schedule_index + + os = Operatingsystem.create!(:name => "RedHat", :major => "6", :minor => "3") + host.expects(:facts).returns({'distribution::name' => 'Red Hat Enterprise Linux'}) + host.operatingsystem = os + assert_equal "RHEL6", host.rhel_eos_schedule_index + end + + def test_rhel_eos_schedule_index_non_rhel + os = Operatingsystem.create!(:name => "CentOS_Stream", :major => "8", :minor => "") + host.operatingsystem = os + host.expects(:facts).returns({'distribution::name' => 'CentOS Stream'}) + assert_nil host.rhel_eos_schedule_index + end + def test_full_support_end_dates host.expects(:rhel_eos_schedule_index).returns('RHEL9') expected_date = ::Katello::RhelLifecycleStatus.full_support_end_dates['RHEL9'] diff --git a/test/models/concerns/operatingsystem_extensions_test.rb b/test/models/concerns/operatingsystem_extensions_test.rb index 7c1f0523552..92118b32fd8 100644 --- a/test/models/concerns/operatingsystem_extensions_test.rb +++ b/test/models/concerns/operatingsystem_extensions_test.rb @@ -37,21 +37,5 @@ def test_assign_template_for_atomic assert_equal "x86_64", os.architectures.first.name assert_equal "#{::Operatingsystem::REDHAT_ATOMIC_HOST_DISTRO_NAME} 7.3", os.description end - - def test_rhel_eos_schedule_index - os = Operatingsystem.create!(:name => "RedHat", :major => "7", :minor => "3") - assert_equal "RHEL7", os.rhel_eos_schedule_index - assert_equal "RHEL7 (POWER9)", os.rhel_eos_schedule_index(arch_name: "ppc64le") - assert_equal "RHEL7 (ARM)", os.rhel_eos_schedule_index(arch_name: "aarch64") - assert_equal "RHEL7 (System z (Structure A))", os.rhel_eos_schedule_index(arch_name: "s390x") - - os = Operatingsystem.create!(:name => "RedHat", :major => "6", :minor => "3") - assert_equal "RHEL6", os.rhel_eos_schedule_index - end - - def test_rhel_eos_schedule_index_non_rhel - os = Operatingsystem.create!(:name => "CentOS_Stream", :major => "8", :minor => "3") - assert_nil os.rhel_eos_schedule_index - end end end diff --git a/test/models/rhel_lifecycle_status_test.rb b/test/models/rhel_lifecycle_status_test.rb index a827c9bfe2f..6f708bfd052 100644 --- a/test/models/rhel_lifecycle_status_test.rb +++ b/test/models/rhel_lifecycle_status_test.rb @@ -70,7 +70,7 @@ def fake_extended_support_end_date(date) def test_to_status_full_support os.hosts << host host.operatingsystem.update(:name => "RedHat", :major => "9", :minor => "0") - host.operatingsystem.expects(:rhel_eos_schedule_index).returns(release) + host.expects(:rhel_eos_schedule_index).returns(release) Katello::RhelLifecycleStatus.expects(:approaching_end_of_category).returns({}) fake_full_support_end_date(Date.today + 2.years) fake_maintenance_support_end_date(Date.today + 10.years) @@ -81,7 +81,7 @@ def test_to_status_full_support def test_to_status_maintenance_support os.hosts << host host.operatingsystem.update(:name => "RedHat", :major => "9", :minor => "0") - host.operatingsystem.expects(:rhel_eos_schedule_index).returns(release) + host.expects(:rhel_eos_schedule_index).returns(release) fake_full_support_end_date(Date.today - 1.year) fake_maintenance_support_end_date(Date.today + 2.years) fake_extended_support_end_date(Date.today + 10.years) @@ -91,7 +91,7 @@ def test_to_status_maintenance_support def test_to_status_approaching_end_of_support os.hosts << host host.operatingsystem.update(:name => "RedHat", :major => "9", :minor => "0") - host.operatingsystem.expects(:rhel_eos_schedule_index).returns(release) + host.expects(:rhel_eos_schedule_index).returns(release) Katello::RhelLifecycleStatus.expects(:approaching_end_of_category).returns({ 'extended_support' => Date.today + 2.days }) assert_equal Katello::RhelLifecycleStatus::APPROACHING_END_OF_SUPPORT, status.to_status end @@ -99,7 +99,7 @@ def test_to_status_approaching_end_of_support def test_to_status_extended_support os.hosts << host host.operatingsystem.update(:name => "RedHat", :major => "9", :minor => "0") - host.operatingsystem.expects(:rhel_eos_schedule_index).returns(release) + host.expects(:rhel_eos_schedule_index).returns(release) fake_full_support_end_date(Date.today - 5.years) fake_maintenance_support_end_date(Date.today - 3.years) fake_extended_support_end_date(Date.today + 2.years) @@ -109,7 +109,7 @@ def test_to_status_extended_support def test_to_status_support_ended os.hosts << host host.operatingsystem.update(:name => "RedHat", :major => "9", :minor => "0") - host.operatingsystem.expects(:rhel_eos_schedule_index).returns(release) + host.expects(:rhel_eos_schedule_index).returns(release) fake_full_support_end_date(Date.today - 5.years) fake_maintenance_support_end_date(Date.today - 3.years) fake_extended_support_end_date(Date.today - 1.year) @@ -149,13 +149,12 @@ def test_eos_date_no_extended_support end def test_relevant - os.hosts << host + host.expects(:rhel_eos_schedule_index).returns('RHEL9') assert status.relevant? end def test_relevant_non_rhel - os.update(:name => "CentOS_Stream") - os.hosts << host + host.expects(:rhel_eos_schedule_index).returns(nil) refute status.relevant? end end