summaryrefslogtreecommitdiff
path: root/lib/chef/file_content_management
diff options
context:
space:
mode:
authorSerdar Sutay <serdar@opscode.com>2014-11-14 12:35:05 -0800
committerSerdar Sutay <serdar@opscode.com>2014-11-14 12:35:05 -0800
commitf5ec7e9cc0e269eaac284d87f3c3b33a0cf68b6a (patch)
treed625255c4b47ed9c37740c478e3adccf71eb1c17 /lib/chef/file_content_management
parent88a210b46a02aa82f8bf80fab7091b23da7720a3 (diff)
downloadchef-f5ec7e9cc0e269eaac284d87f3c3b33a0cf68b6a.tar.gz
Introduct :auto mode for :file_staging_uses_destdir which tries the dest_dir first and falls back to tmpdir when unsuccessful.
Diffstat (limited to 'lib/chef/file_content_management')
-rw-r--r--lib/chef/file_content_management/tempfile.rb37
1 files changed, 32 insertions, 5 deletions
diff --git a/lib/chef/file_content_management/tempfile.rb b/lib/chef/file_content_management/tempfile.rb
index 61a5ce2a7c..1673dd7a1b 100644
--- a/lib/chef/file_content_management/tempfile.rb
+++ b/lib/chef/file_content_management/tempfile.rb
@@ -17,6 +17,7 @@
#
require "tempfile"
+require 'pry'
class Chef
class FileContentManagement
@@ -35,7 +36,20 @@ class Chef
private
def tempfile_open
- tf = ::Tempfile.open(tempfile_basename, tempfile_dirname)
+ tf = nil
+
+ tempfile_dirnames.each do |tempfile_dirname|
+ begin
+ tf = ::Tempfile.open(tempfile_basename, tempfile_dirname)
+ break
+ rescue Exception => e
+ Chef::Log.debug("Can not create temp file for staging under '#{tempfile_dirname}'.")
+ Chef::Log.debug(e.message)
+ end
+ end
+
+ raise "Staging tempfile can not be created!" if tf.nil?
+
# We always process the tempfile in binmode so that we
# preserve the line endings of the content.
tf.binmode
@@ -53,16 +67,29 @@ class Chef
basename
end
- def tempfile_dirname
+ # Returns the possible directories for the tempfile to be created in.
+ def tempfile_dirnames
# in why-run mode we need to create a Tempfile to compare against, which we will never
# wind up deploying, but our enclosing directory for the destdir may not exist yet, so
# instead we can reliably always create a Tempfile to compare against in Dir::tmpdir
- if Chef::Config[:file_staging_uses_destdir] && !Chef::Config[:why_run]
- ::File.dirname(@new_resource.path)
+ if Chef::Config[:why_run]
+ [ Dir::tmpdir ]
else
- Dir::tmpdir
+ case Chef::Config[:file_staging_uses_destdir]
+ when :auto
+ # In auto mode we try the destination directory first and fallback to ENV['TMP'] if
+ # that doesn't work.
+ [ ::File.dirname(@new_resource.path), Dir::tmpdir ]
+ when true
+ [ ::File.dirname(@new_resource.path) ]
+ when false
+ [ Dir::tmpdir ]
+ else
+ raise "Unknown setting '#{Chef::Config[:file_staging_uses_destdir]}' for Chef::Config[:file_staging_uses_destdir]. Possible values are :auto, true or false."
+ end
end
end
+
end
end
end