summaryrefslogtreecommitdiffstats
path: root/lib/facter/util
diff options
context:
space:
mode:
authorNigel Kersten <nigelk@google.com>2009-07-23 08:34:47 -0700
committerPaul Nasrat <pnasrat@googlemail.com>2009-08-07 11:08:42 +0100
commitbe9e484c0daaf4befb0dfbcf85bda08ce6c1effd (patch)
tree08ab3dd6012df3d198364e66480d9b829a7fcb6d /lib/facter/util
parentf3ad66f69979cd107025b6edd07bbe6c958d447b (diff)
downloadfacter-be9e484c0daaf4befb0dfbcf85bda08ce6c1effd.tar.gz
facter-be9e484c0daaf4befb0dfbcf85bda08ce6c1effd.tar.xz
facter-be9e484c0daaf4befb0dfbcf85bda08ce6c1effd.zip
Update OS X minor version fact to cope with '10.x' values and provide test coverage
switch %x{} call to Facter::Util::Resolution.exec for better testing
Diffstat (limited to 'lib/facter/util')
-rw-r--r--lib/facter/util/macosx.rb10
1 files changed, 7 insertions, 3 deletions
diff --git a/lib/facter/util/macosx.rb b/lib/facter/util/macosx.rb
index f5f83f3..6754f18 100644
--- a/lib/facter/util/macosx.rb
+++ b/lib/facter/util/macosx.rb
@@ -56,12 +56,16 @@ module Facter::Util::Macosx
def self.sw_vers
ver = Hash.new
[ "productName", "productVersion", "buildVersion" ].each do |option|
- ver["macosx_#{option}"] = %x{sw_vers -#{option}}.strip
+ ver["macosx_#{option}"] = Facter::Util::Resolution.exec("/usr/bin/sw_vers -#{option}").strip
end
productversion = ver["macosx_productVersion"]
if not productversion.nil?
- ver["macosx_productversion_major"] = productversion.scan(/(\d+\.\d+)/)[0][0]
- ver["macosx_productversion_minor"] = productversion.scan(/(\d+)\.(\d+)\.(\d+)/)[0].last
+ versions = productversion.scan(/(\d+)\.(\d+)\.*(\d*)/)[0]
+ ver["macosx_productversion_major"] = "#{versions[0]}.#{versions[1]}"
+ if versions[2].empty? # 10.x should be treated as 10.x.0
+ versions[2] = "0"
+ end
+ ver["macosx_productversion_minor"] = versions[2]
end
ver
end