summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSerdar Sutay <serdar@opscode.com>2014-11-08 22:45:21 -0800
committerSerdar Sutay <serdar@opscode.com>2014-11-08 22:45:21 -0800
commit708e2896e76aa79f1630b15b4a08bfcb9f044474 (patch)
tree9e55454fae4e674bfa89f484c390565a9a3c1f75
parent60739dd573795624679101eedcd431998befa9b4 (diff)
parenta929b1fed40f98a4c9077f7a73fc9afafba17357 (diff)
downloadchef-708e2896e76aa79f1630b15b4a08bfcb9f044474.tar.gz
Merge pull request #2388 from opscode/sersut/port-nil-attr-revert
Merge pull request #2387 from opscode/sersut/revert-attr-nil-override
-rw-r--r--lib/chef/mixin/deep_merge.rb9
-rw-r--r--spec/unit/mixin/deep_merge_spec.rb14
2 files changed, 3 insertions, 20 deletions
diff --git a/lib/chef/mixin/deep_merge.rb b/lib/chef/mixin/deep_merge.rb
index 5e3327a526..a8a4737758 100644
--- a/lib/chef/mixin/deep_merge.rb
+++ b/lib/chef/mixin/deep_merge.rb
@@ -29,6 +29,7 @@ class Chef
class InvalidSubtractiveMerge < ArgumentError; end
+
OLD_KNOCKOUT_PREFIX = "!merge:".freeze
# Regex to match the "knockout prefix" that was used to indicate
@@ -85,12 +86,8 @@ class Chef
when Hash
if dest.kind_of?(Hash)
source.each do |src_key, src_value|
- if dest.has_key? src_key
- if dest[src_key].nil?
- dest[src_key] = nil
- else
- dest[src_key] = deep_merge!(src_value, dest[src_key])
- end
+ if dest[src_key]
+ dest[src_key] = deep_merge!(src_value, dest[src_key])
else # dest[src_key] doesn't exist so we take whatever source has
raise_if_knockout_used!(src_value)
dest[src_key] = src_value
diff --git a/spec/unit/mixin/deep_merge_spec.rb b/spec/unit/mixin/deep_merge_spec.rb
index dbc49e68f2..76f5c68a29 100644
--- a/spec/unit/mixin/deep_merge_spec.rb
+++ b/spec/unit/mixin/deep_merge_spec.rb
@@ -236,20 +236,6 @@ describe Chef::Mixin::DeepMerge, "deep_merge!" do
@dm.deep_merge!(hash_src, hash_dst)
hash_dst.should == {"item" => "orange"}
end
-
- it 'should overwrite hashes with nil' do
- hash_src = {"item" => { "1" => "2"}, "other" => true }
- hash_dst = {"item" => nil }
- @dm.deep_merge!(hash_src, hash_dst)
- hash_dst.should == {"item" => nil, "other" => true }
- end
-
- it 'should overwrite strings with nil' do
- hash_src = {"item" => "to_overwrite", "other" => false }
- hash_dst = {"item" => nil }
- @dm.deep_merge!(hash_src, hash_dst)
- hash_dst.should == {"item" => nil, "other" => false }
- end
end # deep_merge!
# Chef specific