summaryrefslogtreecommitdiffstats
path: root/spec/lib/puppet_spec/files.rb
diff options
context:
space:
mode:
authorDaniel Pittman <daniel@puppetlabs.com>2011-04-08 15:24:38 -0700
committerDaniel Pittman <daniel@puppetlabs.com>2011-04-08 15:24:38 -0700
commitab5f1e8ffbe6503687c6f46bcaed9316da0151b9 (patch)
tree922bf531dcd3bf5ea3581c44370574f11c875e8e /spec/lib/puppet_spec/files.rb
parent87f4e0a1ce60ddb443a5eda459793c5acb7fce1e (diff)
parentf9271b918833b250da304efa8efdd0fdb64e89ca (diff)
downloadpuppet-ab5f1e8ffbe6503687c6f46bcaed9316da0151b9.tar.gz
puppet-ab5f1e8ffbe6503687c6f46bcaed9316da0151b9.tar.xz
puppet-ab5f1e8ffbe6503687c6f46bcaed9316da0151b9.zip
Merge branch 'maint/next/improve-test-suite-performance' into next
Diffstat (limited to 'spec/lib/puppet_spec/files.rb')
-rw-r--r--spec/lib/puppet_spec/files.rb56
1 files changed, 33 insertions, 23 deletions
diff --git a/spec/lib/puppet_spec/files.rb b/spec/lib/puppet_spec/files.rb
index 38c51a572..30fb4fc42 100644
--- a/spec/lib/puppet_spec/files.rb
+++ b/spec/lib/puppet_spec/files.rb
@@ -3,41 +3,51 @@ require 'tempfile'
# A support module for testing files.
module PuppetSpec::Files
+ # This code exists only to support tests that run as root, pretty much.
+ # Once they have finally been eliminated this can all go... --daniel 2011-04-08
+ if Puppet.features.posix? then
+ def self.in_tmp(path)
+ path =~ /^\/tmp/ or path =~ /^\/var\/folders/
+ end
+ elsif Puppet.features.microsoft_windows?
+ def self.in_tmp(path)
+ tempdir = File.expand_path(File.join(Dir::LOCAL_APPDATA, "Temp"))
+ path =~ /^#{tempdir}/
+ end
+ else
+ fail "Help! Can't find in_tmp for this platform"
+ end
+
def self.cleanup
- if defined?($tmpfiles)
- $tmpfiles.each do |file|
- file = File.expand_path(file)
- if Puppet.features.posix? and file !~ /^\/tmp/ and file !~ /^\/var\/folders/
- puts "Not deleting tmpfile #{file} outside of /tmp or /var/folders"
- next
- elsif Puppet.features.microsoft_windows?
- tempdir = File.expand_path(File.join(Dir::LOCAL_APPDATA, "Temp"))
- if file !~ /^#{tempdir}/
- puts "Not deleting tmpfile #{file} outside of #{tempdir}"
- next
- end
- end
- if FileTest.exist?(file)
- system("chmod -R 755 '#{file}'")
- system("rm -rf '#{file}'")
- end
+ $global_tempfiles ||= []
+ while path = $global_tempfiles.pop do
+ fail "Not deleting tmpfile #{path} outside regular tmpdir" unless in_tmp(path)
+
+ begin
+ FileUtils.rm_r path, :secure => true
+ rescue Errno::ENOENT
+ # nothing to do
end
- $tmpfiles.clear
end
end
def tmpfile(name)
+ # Generate a temporary file, just for the name...
source = Tempfile.new(name)
path = source.path
source.close!
- $tmpfiles ||= []
- $tmpfiles << path
+
+ # ...record it for cleanup,
+ $global_tempfiles ||= []
+ $global_tempfiles << File.expand_path(path)
+
+ # ...and bam.
path
end
def tmpdir(name)
- file = tmpfile(name)
- FileUtils.mkdir_p(file)
- file
+ path = tmpfile(name)
+ FileUtils.mkdir_p(path)
+ path
end
end