From: Raphaƫl Pinson Date: Wed, 15 Oct 2014 13:44:50 +0000 (+0200) Subject: Refactor facts to improve performance: X-Git-Tag: 1.7.0~1^2~1^2^2 X-Git-Url: https://review.fuel-infra.org/gitweb?a=commitdiff_plain;h=d090ae4ebb9041bc46e161f698732a6bc9d28399;hp=841ed61ba282b8673175cbb0ddd46c81f1ee823f;p=puppet-modules%2Fpuppetlabs-apt.git Refactor facts to improve performance: * Add an apt_has_updates boolean fact * Make other facts depend on it --- diff --git a/lib/facter/apt_package_updates.rb b/lib/facter/apt_package_updates.rb deleted file mode 100644 index 97c75c6..0000000 --- a/lib/facter/apt_package_updates.rb +++ /dev/null @@ -1,13 +0,0 @@ -Facter.add("apt_package_updates") do - confine :osfamily => 'Debian' - setcode do - if File.executable?("/usr/lib/update-notifier/apt-check") - packages = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check -p 2>&1') - packages = packages.split("\n") - if Facter.version < '2.0.0' - packages = packages.join(',') - end - packages - end - end -end diff --git a/lib/facter/apt_security_updates.rb b/lib/facter/apt_security_updates.rb deleted file mode 100644 index 19bae75..0000000 --- a/lib/facter/apt_security_updates.rb +++ /dev/null @@ -1,9 +0,0 @@ -Facter.add("apt_security_updates") do - confine :osfamily => 'Debian' - setcode do - if File.executable?("/usr/lib/update-notifier/apt-check") - updates = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check 2>&1') - Integer(updates.strip.split(';')[1]) - end - end -end diff --git a/lib/facter/apt_updates.rb b/lib/facter/apt_updates.rb index ee17738..75670bc 100644 --- a/lib/facter/apt_updates.rb +++ b/lib/facter/apt_updates.rb @@ -1,9 +1,37 @@ -Facter.add("apt_updates") do +apt_package_updates = nil +Facter.add("apt_has_updates") do confine :osfamily => 'Debian' + if File.executable?("/usr/lib/update-notifier/apt-check") + apt_package_updates = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check 2>&1').split(';') + end + + setcode do + apt_package_updates != ['0', '0'] unless apt_package_updates.nil? + end +end + +Facter.add("apt_package_updates") do + confine :apt_has_updates => true setcode do - if File.executable?("/usr/lib/update-notifier/apt-check") - updates = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check 2>&1') - Integer(updates.strip.split(';')[0]) + packages = Facter::Util::Resolution.exec('/usr/lib/update-notifier/apt-check -p 2>&1').split("\n") + if Facter.version < '2.0.0' + packages.join(',') + else + packages end end end + +Facter.add("apt_updates") do + confine :apt_has_updates => true + setcode do + Integer(apt_package_updates[0]) + end +end + +Facter.add("apt_security_updates") do + confine :apt_has_updates => true + setcode do + Integer(apt_package_updates[1]) + end +end diff --git a/spec/unit/facter/apt_has_updates_spec.rb b/spec/unit/facter/apt_has_updates_spec.rb new file mode 100644 index 0000000..9a444db --- /dev/null +++ b/spec/unit/facter/apt_has_updates_spec.rb @@ -0,0 +1,34 @@ +require 'spec_helper' + +describe 'apt_has_updates fact' do + subject { Facter.fact(:apt_has_updates).value } + after(:each) { Facter.clear } + + describe 'on non-Debian distro' do + before { + Facter.fact(:osfamily).expects(:value).returns 'RedHat' + } + it { should be_nil } + end + + describe 'on Debian based distro missing update-notifier-common' do + before { + Facter.fact(:osfamily).expects(:value).returns 'Debian' + File.stubs(:executable?) # Stub all other calls + File.expects(:executable?).with('/usr/lib/update-notifier/apt-check').returns false + } + it { should be_nil } + end + + describe 'on Debian based distro' do + before { + Facter.fact(:osfamily).expects(:value).returns 'Debian' + File.stubs(:executable?) # Stub all other calls + Facter::Util::Resolution.stubs(:exec) # Catch all other calls + File.expects(:executable?).with('/usr/lib/update-notifier/apt-check').returns true + Facter::Util::Resolution.expects(:exec).with('/usr/lib/update-notifier/apt-check 2>&1').returns "4;3" + } + it { should be true } + end +end + diff --git a/spec/unit/facter/apt_package_updates_spec.rb b/spec/unit/facter/apt_package_updates_spec.rb index dfa0927..5c7a624 100644 --- a/spec/unit/facter/apt_package_updates_spec.rb +++ b/spec/unit/facter/apt_package_updates_spec.rb @@ -4,26 +4,28 @@ describe 'apt_package_updates fact' do subject { Facter.fact(:apt_package_updates).value } after(:each) { Facter.clear } - describe 'on Debian based distro missing update-notifier-common' do + describe 'when apt has no updates' do before { - Facter.fact(:osfamily).stubs(:value).returns 'Debian' - File.stubs(:executable?).returns false - } - it { should == nil } + Facter.fact(:apt_has_updates).stubs(:value).returns false + } + it { should be nil } end - describe 'on Debian based distro' do + describe 'when apt has updates' do before { - Facter.fact(:osfamily).stubs(:value).returns 'Debian' - File.stubs(:executable?).returns true - Facter::Util::Resolution.stubs(:exec).returns "puppet-common\nlinux-generic\nlinux-image-generic" - } - it { - if Facter.version < '2.0.0' - should == 'puppet-common,linux-generic,linux-image-generic' - else - should == ['puppet-common', 'linux-generic', 'linux-image-generic'] - end - } + Facter.fact(:osfamily).stubs(:value).returns 'Debian' + File.stubs(:executable?) # Stub all other calls + Facter::Util::Resolution.stubs(:exec) # Catch all other calls + File.expects(:executable?).with('/usr/lib/update-notifier/apt-check').returns true + Facter::Util::Resolution.expects(:exec).with('/usr/lib/update-notifier/apt-check 2>&1').returns "1;2" + Facter::Util::Resolution.expects(:exec).with('/usr/lib/update-notifier/apt-check -p 2>&1').returns "puppet-common\nlinux-generic\nlinux-image-generic" + } + it { + if Facter.version < '2.0.0' + should == 'puppet-common,linux-generic,linux-image-generic' + else + should == ['puppet-common', 'linux-generic', 'linux-image-generic'] + end + } end end diff --git a/spec/unit/facter/apt_security_updates_spec.rb b/spec/unit/facter/apt_security_updates_spec.rb index 999603b..4bc760f 100644 --- a/spec/unit/facter/apt_security_updates_spec.rb +++ b/spec/unit/facter/apt_security_updates_spec.rb @@ -4,21 +4,22 @@ describe 'apt_security_updates fact' do subject { Facter.fact(:apt_security_updates).value } after(:each) { Facter.clear } - describe 'on Debian based distro missing update-notifier-common' do + describe 'when apt has no updates' do before { - Facter.fact(:osfamily).stubs(:value).returns 'Debian' - File.stubs(:executable?).returns false - } - it { should == nil } + Facter.fact(:apt_has_updates).stubs(:value).returns false + } + it { should be nil } end - describe 'on Debian based distro' do + describe 'when apt has security updates' do before { - Facter.fact(:osfamily).stubs(:value).returns 'Debian' - File.stubs(:executable?).returns true - Facter::Util::Resolution.stubs(:exec).returns '14;7' - } - it { should == 7 } + Facter.fact(:osfamily).stubs(:value).returns 'Debian' + File.stubs(:executable?) # Stub all other calls + Facter::Util::Resolution.stubs(:exec) # Catch all other calls + File.expects(:executable?).with('/usr/lib/update-notifier/apt-check').returns true + Facter::Util::Resolution.expects(:exec).with('/usr/lib/update-notifier/apt-check 2>&1').returns "14;7" + } + it { should == 7 } end end diff --git a/spec/unit/facter/apt_updates_spec.rb b/spec/unit/facter/apt_updates_spec.rb index 2f343bd..7e9b77f 100644 --- a/spec/unit/facter/apt_updates_spec.rb +++ b/spec/unit/facter/apt_updates_spec.rb @@ -4,21 +4,22 @@ describe 'apt_updates fact' do subject { Facter.fact(:apt_updates).value } after(:each) { Facter.clear } - describe 'on Debian based distro missing update-notifier-common' do + describe 'when apt has no updates' do before { - Facter.fact(:osfamily).stubs(:value).returns 'Debian' - File.stubs(:executable?).returns false - } - it { should == nil } + Facter.fact(:apt_has_updates).stubs(:value).returns false + } + it { should be nil } end - describe 'on Debian based distro' do + describe 'when apt has updates' do before { - Facter.fact(:osfamily).stubs(:value).returns 'Debian' - File.stubs(:executable?).returns true - Facter::Util::Resolution.stubs(:exec).returns '14;7' - } - it { should == 14 } + Facter.fact(:osfamily).stubs(:value).returns 'Debian' + File.stubs(:executable?) # Stub all other calls + Facter::Util::Resolution.stubs(:exec) # Catch all other calls + File.expects(:executable?).with('/usr/lib/update-notifier/apt-check').returns true + Facter::Util::Resolution.expects(:exec).with('/usr/lib/update-notifier/apt-check 2>&1').returns "14;7" + } + it { should == 14 } end end