summaryrefslogtreecommitdiff
path: root/lib/facter/virtualenv_version.rb
diff options
context:
space:
mode:
authorkwadronaut <kwadronaut@leap.se>2014-07-29 19:08:36 +0200
committerkwadronaut <kwadronaut@leap.se>2014-07-29 19:08:36 +0200
commitba32e368e22078cac65d27531a1cf7d0962ec984 (patch)
treed28ae4bd79d5d4f61ecf3d8b8cd55c9e306b960d /lib/facter/virtualenv_version.rb
parent78c4e8d748138833ba07b71bcfc1ea538c4a2dfb (diff)
parent1696203589b66cc374bd8f5f21e82d5b92eb391b (diff)
Update: Merge remote-tracking branch 'upstream/master'HEADmaster
Diffstat (limited to 'lib/facter/virtualenv_version.rb')
-rw-r--r--lib/facter/virtualenv_version.rb27
1 files changed, 27 insertions, 0 deletions
diff --git a/lib/facter/virtualenv_version.rb b/lib/facter/virtualenv_version.rb
new file mode 100644
index 0000000..04736ed
--- /dev/null
+++ b/lib/facter/virtualenv_version.rb
@@ -0,0 +1,27 @@
+# Make virtualenv version available as a fact
+# Works with virualenv loaded and without, pip installed and package installed
+require 'puppet'
+pkg = Puppet::Type.type(:package).new(:name => "virtualenv")
+Facter.add("virtualenv_version") do
+ has_weight 100
+ setcode do
+ begin
+ Facter::Util::Resolution.exec('virtualenv --version')
+ rescue
+ false
+ end
+ end
+end
+
+Facter.add("virtualenv_version") do
+ has_weight 50
+ setcode do
+ begin
+ unless [:absent,'purged'].include?(pkg.retrieve[pkg.property(:ensure)])
+ /^.*(\d+\.\d+\.\d+).*$/.match(pkg.retrieve[pkg.property(:ensure)])[1]
+ end
+ rescue
+ false
+ end
+ end
+end