diff --git a/.rubocop_todo.yml b/.rubocop_todo.yml index f99e494e..2a3b54e7 100644 --- a/.rubocop_todo.yml +++ b/.rubocop_todo.yml @@ -1,6 +1,6 @@ # This configuration was generated by # `rubocop --auto-gen-config` -# on 2023-07-06 14:12:32 UTC using RuboCop version 1.50.2. +# on 2024-06-09 13:09:14 UTC using RuboCop version 1.63.5. # The point is for the user to remove these configuration records # one by one as the offenses are removed from the code base. # Note that changes in the inspected code, or installation of new @@ -12,7 +12,7 @@ Performance/MapCompact: Exclude: - 'lib/rspec-puppet-facts.rb' -# Offense count: 32 +# Offense count: 29 # Configuration parameters: Prefixes, AllowedPatterns. # Prefixes: when, with, without RSpec/ContextWording: @@ -29,7 +29,7 @@ RSpec/ExpectInHook: Exclude: - 'spec/rspec_puppet_facts_spec.rb' -# Offense count: 20 +# Offense count: 8 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: EnforcedStyle. # SupportedStyles: single_line_only, single_statement_only, disallow, require_implicit @@ -52,14 +52,14 @@ RSpec/MessageSpies: RSpec/MultipleExpectations: Max: 2 -# Offense count: 46 +# Offense count: 49 # Configuration parameters: EnforcedStyle, IgnoreSharedExamples. # SupportedStyles: always, named_only RSpec/NamedSubject: Exclude: - 'spec/rspec_puppet_facts_spec.rb' -# Offense count: 14 +# Offense count: 13 # Configuration parameters: AllowedGroups. RSpec/NestedGroups: Max: 6 diff --git a/lib/rspec-puppet-facts.rb b/lib/rspec-puppet-facts.rb index de1ec930..6577fb63 100644 --- a/lib/rspec-puppet-facts.rb +++ b/lib/rspec-puppet-facts.rb @@ -119,7 +119,7 @@ def on_supported_os_implementation(opts = {}) # facter data (see FacterDB 0.5.2 for Facter releases 3.8 and 3.9). In this situation we need to # cycle through and downgrade Facter versions per platform type until we find matching Facter data. filter.each do |filter_spec| - versions = FacterDB.get_facts(filter_spec).to_h { |facts| [Gem::Version.new(facts[:facterversion]), facts] } + versions = FacterDB.get_facts(filter_spec, symbolize_keys: !RSpec.configuration.facterdb_string_keys).to_h { |facts| [Gem::Version.new(facts[:facterversion]), facts] } version, facts = versions.select { |v, _f| strict_requirement =~ v }.max_by { |v, _f| v } @@ -144,7 +144,7 @@ def on_supported_os_implementation(opts = {}) os_facts_hash = {} received_facts.map do |facts| - os_fact = facts[:os] + os_fact = RSpec.configuration.facterdb_string_keys ? facts['os'] : facts[:os] unless os_fact RspecPuppetFacts.warning "No os fact was found in FacterDB for: #{facts}" next @@ -156,8 +156,6 @@ def on_supported_os_implementation(opts = {}) os_facts_hash[os] = RspecPuppetFacts.with_custom_facts(os, facts) end - return stringify_keys(os_facts_hash) if RSpec.configuration.facterdb_string_keys - os_facts_hash end @@ -264,6 +262,7 @@ def self.common_facts if augeas? @common_facts[:augeasversion] = Augeas.open(nil, nil, Augeas::NO_MODL_AUTOLOAD).get('/augeas/version') end + @common_facts = stringify_keys(@common_facts) if RSpec.configuration.facterdb_string_keys @common_facts end @@ -424,6 +423,7 @@ def self.facter_version_for_puppet_version(puppet_version) RSpec.configure do |c| c.add_setting :default_facter_version, - :default => RspecPuppetFacts.facter_version_for_puppet_version(Puppet.version) - c.add_setting :facterdb_string_keys, :default => false + default: RspecPuppetFacts.facter_version_for_puppet_version(Puppet.version) + c.add_setting :facterdb_string_keys, + default: false end diff --git a/rspec-puppet-facts.gemspec b/rspec-puppet-facts.gemspec index 32184f07..83560a60 100644 --- a/rspec-puppet-facts.gemspec +++ b/rspec-puppet-facts.gemspec @@ -27,6 +27,6 @@ Gem::Specification.new do |s| s.add_runtime_dependency 'deep_merge', '~> 1.2' s.add_runtime_dependency 'facter', '< 5' - s.add_runtime_dependency 'facterdb', '>= 0.5.0', '< 2' + s.add_runtime_dependency 'facterdb', '~> 2.1' s.add_runtime_dependency 'puppet', '>= 7', '< 9' end diff --git a/spec/fixtures/metadata.json b/spec/fixtures/metadata.json index 54687e40..61ddbf59 100644 --- a/spec/fixtures/metadata.json +++ b/spec/fixtures/metadata.json @@ -15,16 +15,16 @@ { "operatingsystem": "Debian", "operatingsystemrelease": [ - "7", - "8" + "11", + "12" ] }, { "operatingsystem": "RedHat", "operatingsystemrelease": [ - "5", - "6", - "7" + "7", + "8", + "9" ] } ], diff --git a/spec/rspec_puppet_facts_spec.rb b/spec/rspec_puppet_facts_spec.rb index 63f08460..c40a3498 100644 --- a/spec/rspec_puppet_facts_spec.rb +++ b/spec/rspec_puppet_facts_spec.rb @@ -140,7 +140,7 @@ :supported_os => [ { "operatingsystem" => "Debian", - "operatingsystemrelease" => ['7'], + "operatingsystemrelease" => ['12'], }, ], }, @@ -161,7 +161,7 @@ end it 'returns a fact set with all the keys as Strings' do - expect(get_keys.call(result['debian-7-x86_64'])).to all(be_a(String)) + expect(get_keys.call(result['debian-12-x86_64'])).to all(be_a(String)) end end @@ -171,7 +171,7 @@ end it 'returns a fact set with all the keys as Symbols or Strings' do - expect(get_keys.call(result['debian-7-x86_64'])).to all(be_a(Symbol).or(be_a(String))) + expect(get_keys.call(result['debian-12-x86_64'])).to all(be_a(Symbol).or(be_a(String))) end end end @@ -215,20 +215,20 @@ it 'returns supported OS' do expect(subject.keys.sort).to eq %w( - debian-7-x86_64 - debian-8-x86_64 - redhat-5-x86_64 - redhat-6-x86_64 + debian-11-x86_64 + debian-12-x86_64 redhat-7-x86_64 + redhat-8-x86_64 + redhat-9-x86_64 ) end it 'is able to filter the received OS facts' do allow(described_class).to receive(:spec_facts_os_filter).and_return('redhat') expect(subject.keys.sort).to eq %w( - redhat-5-x86_64 - redhat-6-x86_64 redhat-7-x86_64 + redhat-8-x86_64 + redhat-9-x86_64 ) end end @@ -268,15 +268,15 @@ { "operatingsystem" => "Debian", "operatingsystemrelease" => [ - "7", - "8", + "11", + "12", ], }, { "operatingsystem" => "RedHat", "operatingsystemrelease" => [ - "5", - "6", + "8", + "9", ], }, ], @@ -294,18 +294,18 @@ it 'returns supported OS' do expect(subject.keys.sort).to eq %w( - debian-7-x86_64 - debian-8-x86_64 - redhat-5-x86_64 - redhat-6-x86_64 + debian-11-x86_64 + debian-12-x86_64 + redhat-8-x86_64 + redhat-9-x86_64 ) end it 'is able to filter the received OS facts' do allow(described_class).to receive(:spec_facts_os_filter).and_return('redhat') expect(subject.keys.sort).to eq %w( - redhat-5-x86_64 - redhat-6-x86_64 + redhat-8-x86_64 + redhat-9-x86_64 ) end end @@ -315,7 +315,7 @@ on_supported_os( { :supported_os => [ - { 'operatingsystem' => 'RedHat', 'operatingsystemrelease' => '7' }, + { 'operatingsystem' => 'RedHat', 'operatingsystemrelease' => '9' }, ], }, ) @@ -330,7 +330,7 @@ end it 'returns a fact set for the specified release' do - expect(factsets).to include('redhat-7-x86_64' => include(:operatingsystemmajrelease => '7')) + expect(factsets).to include('redhat-9-x86_64' => include(:operatingsystemmajrelease => '9')) end end @@ -342,9 +342,9 @@ { "operatingsystem" => "Ubuntu", "operatingsystemrelease" => [ - "12.04", - "14.04", - "16.04", + "18.04", + "20.04", + "22.04", ], }, ], @@ -353,7 +353,7 @@ } let(:expected_fact_sets) do - ['ubuntu-12.04-x86_64', 'ubuntu-14.04-x86_64', 'ubuntu-16.04-x86_64'] + ['ubuntu-18.04-x86_64', 'ubuntu-20.04-x86_64', 'ubuntu-22.04-x86_64'] end it 'returns a hash' do @@ -436,16 +436,17 @@ context 'When testing Solaris 11' do subject { on_supported_os( - { - :supported_os => [ - { - "operatingsystem" => "Solaris", - "operatingsystemrelease" => [ - "11", - ], - }, + { + :supported_os => [ + { + "operatingsystem" => "Solaris", + "operatingsystemrelease" => [ + "11", ], - }, + }, + ], + facterversion: '4.0', + }, ) } @@ -454,13 +455,13 @@ end it 'has 1 elements' do + pending('2024-06-07: we dont have a suitable solaris 11 factset in facterdb') expect(subject.size).to eq 1 end it 'returns supported OS' do - expect(subject.keys.sort).to eq %w( - solaris-11-i86pc - ) + pending('2024-06-07: we dont have a suitable solaris 11 factset in facterdb') + expect(subject.keys.sort).to eq %w(solaris-11-sun4v) end end @@ -486,15 +487,15 @@ end it 'has 1 elements' do + pending('2024-06-07: we dont have a suitable AIX factset in facterdb') expect(subject.size).to eq 1 end it 'returns supported OS' do # NOTE: See FACT-1827 for details on the IBM,8284-22A part # That has to match whatever hardware generated the facts file. - expect(subject.keys.sort).to eq %w( - aix-7100-IBM,8284-22A - ) + pending('2024-06-07: we dont have a suitable solaris 11 factset in facterdb') + expect(subject.keys.sort).to eq %w(aix-7100-IBM,8284-22A) end end @@ -513,14 +514,14 @@ ) end - let(:facterversion) { '3.8.0' } + let(:facterversion) { '4.2' } context 'with a standard release' do - let(:release) { ['7'] } + let(:release) { ['10'] } it { is_expected.to be_a(Hash) } it { is_expected.to have_attributes(:size => 1) } - it { is_expected.to include('windows-7-x86_64' => an_instance_of(Hash)) } + it { is_expected.to include('windows-10-x86_64' => an_instance_of(Hash)) } end context 'with a revision release' do @@ -569,10 +570,12 @@ end it 'has 1 elements' do + pending('2024-06-7: facterdb has no factset with space in the system release') expect(subject.size).to eq 1 end it 'returns supported OS' do + pending('2024-06-7: facterdb has no factset with space in the system release') expect(subject.keys.sort).to eq [ 'sles-11-x86_64', ] @@ -609,14 +612,14 @@ { "operatingsystem" => "Debian", "operatingsystemrelease" => [ - "8", + "12", ], }, { - "operatingsystem" => "Archlinux", + "operatingsystem" => "Gentoo", }, ], - :facterversion => '3.14', + facterversion: '4.6', }, ) } @@ -630,7 +633,7 @@ end it 'returns supported OS' do - expect(subject.keys.sort).to include(a_string_matching(/\Aarchlinux-\d+-x86_64/), 'debian-8-x86_64') + expect(subject.keys.sort).to include(a_string_matching(/\Agentoo-\d+-x86_64/), 'debian-12-x86_64') end end @@ -659,7 +662,7 @@ 'os.hardware' => "x86_64", } - expect(FacterDB).to receive(:get_facts).with(filter).once + expect(FacterDB).to receive(:get_facts).with(filter, symbolize_keys: true).once subject end @@ -672,13 +675,13 @@ subject do on_supported_os( supported_os: [ - { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[7] }, + { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[9] }, ], ) end before do - RSpec.configuration.default_facter_version = '3.1.6' + RSpec.configuration.default_facter_version = '4.6.1' end after do @@ -688,8 +691,8 @@ it 'returns facts from the specified default Facter version' do is_expected.to match( - 'centos-7-x86_64' => include( - :facterversion => /\A3\.1\./, + 'centos-9-x86_64' => include( + :facterversion => /\A4\.6\./, ), ) end @@ -699,21 +702,21 @@ subject do on_supported_os( supported_os: [ - { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[7] }, + { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[9] }, ], - facterversion: "3.15", + facterversion: "4.7.99", ) end before do - allow(Facter).to receive(:version).and_return('3.14.1') + allow(Facter).to receive(:version).and_return('4.6') end it 'returns facts from a facter version matching version and below' do is_expected.to match( - 'centos-7-x86_64' => include( - :facterversion => /\A3\.14\./, + 'centos-9-x86_64' => include( + :facterversion => /\A4\.[0-7]\./, ), ) end @@ -729,71 +732,33 @@ end end - context 'With a custom facterversion (3.1) in the options hash' do - subject do - on_supported_os( - supported_os: [ - { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[7] }, - ], - facterversion: '3.1', - ) - end - - it 'returns facts from a facter version matching 3.1' do - is_expected.to match( - 'centos-7-x86_64' => include(:facterversion => '3.1.6'), - ) - end - end - - context 'With a custom facterversion (3.1.2) in the options hash' do + context 'With a custom facterversion (4.6) in the options hash' do subject do on_supported_os( supported_os: [ - { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[7] }, + { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[9] }, ], - facterversion: '3.1.2', + facterversion: '4.6', ) end - it 'returns facts from a facter version matching 3.1' do - is_expected.to match( - 'centos-7-x86_64' => include(:facterversion => '3.1.6'), - ) + it 'returns facts from a facter version matching 4.6' do + is_expected.to match('centos-9-x86_64' => include(:facterversion => '4.6.1')) end end - context 'With a custom facterversion (3.3) in the options hash' do + context 'With a custom facterversion (4.6.1) in the options hash' do subject do on_supported_os( supported_os: [ - { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[7] }, + { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[9] }, ], - facterversion: '3.3', + facterversion: '4.6.1', ) end - it 'returns facts from a facter version matching 3.3' do - is_expected.to match( - 'centos-7-x86_64' => include(:facterversion => '3.3.0'), - ) - end - end - - context 'With a custom facterversion (3.3.2) in the options hash' do - subject do - on_supported_os( - supported_os: [ - { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[7] }, - ], - facterversion: '3.3.2', - ) - end - - it 'returns facts from a facter version matching 3.3' do - is_expected.to match( - 'centos-7-x86_64' => include(:facterversion => '3.3.0'), - ) + it 'returns facts from a facter version matching 4.6.1' do + is_expected.to match('centos-9-x86_64' => include(:facterversion => '4.6.1')) end end @@ -817,32 +782,28 @@ subject do on_supported_os( supported_os: [ - { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[7] }, - { 'operatingsystem' => 'OpenSuSE', 'operatingsystemrelease' => %w[42] }, + { 'operatingsystem' => 'CentOS', 'operatingsystemrelease' => %w[9] }, + { 'operatingsystem' => 'Debian', 'operatingsystemrelease' => %w[12] }, ], - facterversion: '3.9.5', + facterversion: '4.6.1', ) end before do allow(FacterDB).to receive(:get_facts).and_call_original allow(FacterDB).to receive(:get_facts).with( - {'os.name'=>"CentOS", 'os.release.full'=>"/^7/", 'os.hardware'=>"x86_64"}, + {'os.name'=>"CentOS", 'os.release.full'=>"/^9/", 'os.hardware'=>"x86_64"}, symbolize_keys: true, ).and_wrap_original do |m, *args| - m.call(*args).reject { |facts| facts[:facterversion].start_with?('3.9.') } + m.call(*args).reject { |facts| facts[:facterversion].start_with?('4.6.') } end end - it 'returns CentOS facts from a facter version matching 3.8' do - is_expected.to include( - 'centos-7-x86_64' => include(:facterversion => '3.8.0'), - ) + it 'returns CentOS facts from a facter version matching 4.5' do + is_expected.to include('centos-9-x86_64' => include(facterversion: '4.5.2')) end - it 'returns OpenSuSE facts from a facter version matching 3.9' do - is_expected.to include( - 'opensuse-42-x86_64' => include(:facterversion => '3.9.2'), - ) + it 'returns Debian facts from a facter version matching 4.6.1' do + is_expected.to include('debian-12-x86_64' => include(facterversion: '4.6.1'),) end end end @@ -855,8 +816,8 @@ { "operatingsystem" => "RedHat", "operatingsystemrelease" => [ - "6", - "7", + "8", + "9", ], }, ], @@ -870,12 +831,12 @@ it 'adds a simple fact and value' do add_custom_fact 'root_home', '/root' - expect(subject['redhat-7-x86_64'][:root_home]).to eq '/root' + expect(subject['redhat-9-x86_64'][:root_home]).to eq '/root' end it 'merges a fact value into fact when merge_facts passed' do add_custom_fact :identity, { 'user' => 'test_user' }, merge_facts: true - expect(subject['redhat-7-x86_64'][:identity]).to eq( + expect(subject['redhat-9-x86_64'][:identity]).to eq( { "gid"=>0, "group"=>"root", @@ -887,32 +848,32 @@ it 'overwrites fact' do add_custom_fact :identity, { 'user' => 'other_user' } - expect(subject['redhat-7-x86_64'][:identity]).to eq( + expect(subject['redhat-9-x86_64'][:identity]).to eq( { "user"=>"other_user" }) end it 'confines a fact to a particular operating system' do - add_custom_fact 'root_home', '/root', :confine => 'redhat-7-x86_64' - expect(subject['redhat-7-x86_64'][:root_home]).to eq '/root' - expect(subject['redhat-6-x86_64'][:root_home]).to be_nil + add_custom_fact 'root_home', '/root', :confine => 'redhat-9-x86_64' + expect(subject['redhat-9-x86_64'][:root_home]).to eq '/root' + expect(subject['redhat-8-x86_64'][:root_home]).to be_nil end it 'excludes a fact from a particular operating system' do - add_custom_fact 'root_home', '/root', :exclude => 'redhat-7-x86_64' - expect(subject['redhat-7-x86_64'][:root_home]).to be_nil - expect(subject['redhat-6-x86_64'][:root_home]).to eq '/root' + add_custom_fact 'root_home', '/root', :exclude => 'redhat-9-x86_64' + expect(subject['redhat-9-x86_64'][:root_home]).to be_nil + expect(subject['redhat-8-x86_64'][:root_home]).to eq '/root' end it 'takes a proc as a value' do add_custom_fact 'root_home', ->(_os, _facts) { '/root' } - expect(subject['redhat-7-x86_64'][:root_home]).to eq '/root' + expect(subject['redhat-9-x86_64'][:root_home]).to eq '/root' end it 'accepts sym fact key and stores fact key as sym' do add_custom_fact :root_home, ->(_os, _facts) { '/root' } - expect(subject['redhat-7-x86_64'][:root_home]).to eq '/root' + expect(subject['redhat-9-x86_64'][:root_home]).to eq '/root' end end