summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorsdelano <stephen@opscode.com>2012-12-04 10:18:46 -0800
committersdelano <stephen@opscode.com>2012-12-04 22:36:34 -0800
commit79483e7a65edf8f135d41061e918ed40db3b9960 (patch)
tree3c00df0d22e8cfd6ca2f787ebd1e8f42dc3421fe
parentae2bdb24a669460fee27df904a11679b6921c838 (diff)
downloadchef-CHEF-3660-and-windows-jenkins.tar.gz
CHEF-3660: Add FileUtils::Entry_ monkey patchCHEF-3660-and-windows-jenkins
This change is equivalent to the changes made to core Ruby at: - https://github.com/ruby/ruby/commit/7d89ecdc523aab7b9908501b6743da2c26a53825
-rw-r--r--chef/lib/chef/monkey_patches/fileutils.rb63
-rw-r--r--chef/lib/chef/provider/deploy.rb1
2 files changed, 64 insertions, 0 deletions
diff --git a/chef/lib/chef/monkey_patches/fileutils.rb b/chef/lib/chef/monkey_patches/fileutils.rb
new file mode 100644
index 0000000000..4b2b24bb34
--- /dev/null
+++ b/chef/lib/chef/monkey_patches/fileutils.rb
@@ -0,0 +1,63 @@
+#
+# Author:: Stephen Delano (<stephen@opscode.com>)
+# Copyright:: Copyright (c) 2012 Opscode, Inc.
+# License:: Apache License, Version 2.0
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+# == FileUtils::Entry_ (Patch)
+# On Ruby 1.9.3 and earlier, FileUtils.cp_r(foo, bar, :preserve => true) fails
+# when attempting to copy a directory containing symlinks. This has been
+# patched in the trunk of Ruby, and this is a monkey patch of the offending
+# code.
+
+require 'fileutils'
+
+class FileUtils::Entry_
+ def copy_metadata(path)
+ st = lstat()
+ if !st.symlink?
+ File.utime st.atime, st.mtime, path
+ end
+ begin
+ if st.symlink?
+ begin
+ File.lchown st.uid, st.gid, path
+ rescue NotImplementedError
+ end
+ else
+ File.chown st.uid, st.gid, path
+ end
+ rescue Errno::EPERM
+ # clear setuid/setgid
+ if st.symlink?
+ begin
+ File.lchmod st.mode & 01777, path
+ rescue NotImplementedError
+ end
+ else
+ File.chmod st.mode & 01777, path
+ end
+ else
+ if st.symlink?
+ begin
+ File.lchmod st.mode, path
+ rescue NotImplementedError
+ end
+ else
+ File.chmod st.mode, path
+ end
+ end
+ end
+end
diff --git a/chef/lib/chef/provider/deploy.rb b/chef/lib/chef/provider/deploy.rb
index 4c189b4cb1..b93b8b9d4f 100644
--- a/chef/lib/chef/provider/deploy.rb
+++ b/chef/lib/chef/provider/deploy.rb
@@ -18,6 +18,7 @@
require "chef/mixin/command"
require "chef/mixin/from_file"
+require "chef/monkey_patches/fileutils"
require "chef/provider/git"
require "chef/provider/subversion"