Use value of variable instead of return statement Extended unit test for checking handling of JAVA_TOOL_OPTIONS
59 lines
1.9 KiB
Ruby
59 lines
1.9 KiB
Ruby
# Fact: java_version
|
|
#
|
|
# Purpose: get full java version string
|
|
#
|
|
# Resolution:
|
|
# Tests for presence of java, returns nil if not present
|
|
# returns output of "java -version" and splits on \n + '"'
|
|
#
|
|
# Caveats:
|
|
# none
|
|
#
|
|
# Notes:
|
|
# None
|
|
Facter.add(:java_version) do
|
|
# the OS-specific overrides need to be able to return nil,
|
|
# to indicate "no java available". Usually returning nil
|
|
# would mean that facter falls back to a lower priority
|
|
# resolution, which would then trigger MODULES-2637. To
|
|
# avoid that, we confine the "default" here to not run
|
|
# on those OS.
|
|
# Additionally, facter versions prior to 2.0.1 only support
|
|
# positive matches, so this needs to be done manually in setcode.
|
|
setcode do
|
|
unless [ 'openbsd', 'darwin' ].include? Facter.value(:operatingsystem).downcase
|
|
version = nil
|
|
if Facter::Util::Resolution.which('java')
|
|
Facter::Util::Resolution.exec('java -Xmx12m -version 2>&1').lines.each { |line| version = $~[1] if /^.+ version \"(.+)\"$/ =~ line }
|
|
end
|
|
version
|
|
end
|
|
end
|
|
end
|
|
|
|
Facter.add(:java_version) do
|
|
confine :operatingsystem => 'OpenBSD'
|
|
has_weight 100
|
|
setcode do
|
|
Facter::Util::Resolution.with_env("PATH" => '/usr/local/jdk-1.7.0/jre/bin:/usr/local/jre-1.7.0/bin') do
|
|
version = nil
|
|
if Facter::Util::Resolution.which('java')
|
|
Facter::Util::Resolution.exec('java -Xmx12m -version 2>&1').lines.each { |line| version = $~[1] if /^.+ version \"(.+)\"$/ =~ line }
|
|
end
|
|
version
|
|
end
|
|
end
|
|
end
|
|
|
|
Facter.add(:java_version) do
|
|
confine :operatingsystem => 'Darwin'
|
|
has_weight 100
|
|
setcode do
|
|
unless /Unable to find any JVMs matching version/ =~ Facter::Util::Resolution.exec('/usr/libexec/java_home --failfast 2>&1')
|
|
version = nil
|
|
Facter::Util::Resolution.exec('java -Xmx12m -version 2>&1').lines.each { |line| version = $~[1] if /^.+ version \"(.+)\"$/ =~ line }
|
|
version
|
|
end
|
|
end
|
|
end
|