summaryrefslogtreecommitdiff
path: root/spec/unit
diff options
context:
space:
mode:
authorLamont Granquist <lamont@scriptkiddie.org>2018-02-23 11:20:50 -0800
committerLamont Granquist <lamont@scriptkiddie.org>2018-02-23 11:20:50 -0800
commitc60c5009e887e650c747581f90b6c68dfae44234 (patch)
tree12a0691332a1bdffeebb70915884cad8fe85da8a /spec/unit
parenta50bfb54e2d570c73cf44cd021432e689e8efbe8 (diff)
downloadchef-c60c5009e887e650c747581f90b6c68dfae44234.tar.gz
Revert "Per-container deep merge caching"lcg/revert-lazy-attributes
This reverts commit 0c29acc106ca774e230c8ef45694c8bffd166b69.
Diffstat (limited to 'spec/unit')
-rw-r--r--spec/unit/node/attribute_spec.rb79
-rw-r--r--spec/unit/node/immutable_collections_spec.rb42
-rw-r--r--spec/unit/node/vivid_mash_spec.rb37
3 files changed, 47 insertions, 111 deletions
diff --git a/spec/unit/node/attribute_spec.rb b/spec/unit/node/attribute_spec.rb
index cbb9540486..557c469216 100644
--- a/spec/unit/node/attribute_spec.rb
+++ b/spec/unit/node/attribute_spec.rb
@@ -171,7 +171,6 @@ describe Chef::Node::Attribute do
}
@automatic_hash = { "week" => "friday" }
@attributes = Chef::Node::Attribute.new(@attribute_hash, @default_hash, @override_hash, @automatic_hash, node)
- allow(node).to receive(:attributes).and_return(@attributes)
end
describe "initialize" do
@@ -180,14 +179,13 @@ describe Chef::Node::Attribute do
end
it "should take an Automatioc, Normal, Default and Override hash" do
- expect { Chef::Node::Attribute.new({}, {}, {}, {}, node) }.not_to raise_error
+ expect { Chef::Node::Attribute.new({}, {}, {}, {}) }.not_to raise_error
end
[ :normal, :default, :override, :automatic ].each do |accessor|
it "should set #{accessor}" do
- @attributes = Chef::Node::Attribute.new({ :normal => true }, { :default => true }, { :override => true }, { :automatic => true }, node)
- allow(node).to receive(:attributes).and_return(@attributes)
- expect(@attributes.send(accessor)).to eq({ accessor.to_s => true })
+ na = Chef::Node::Attribute.new({ :normal => true }, { :default => true }, { :override => true }, { :automatic => true })
+ expect(na.send(accessor)).to eq({ accessor.to_s => true })
end
end
@@ -332,8 +330,7 @@ describe Chef::Node::Attribute do
end
it "merges nested hashes between precedence levels" do
- @attributes = Chef::Node::Attribute.new({}, {}, {}, {}, node)
- allow(node).to receive(:attributes).and_return(@attributes)
+ @attributes = Chef::Node::Attribute.new({}, {}, {}, {})
@attributes.env_default = { "a" => { "b" => { "default" => "default" } } }
@attributes.normal = { "a" => { "b" => { "normal" => "normal" } } }
@attributes.override = { "a" => { "override" => "role" } }
@@ -587,10 +584,8 @@ describe Chef::Node::Attribute do
"one" => { "six" => "seven" },
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should yield each top level key" do
@@ -637,10 +632,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should yield each top level key and value, post merge rules" do
@@ -677,10 +670,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to each_key" do
@@ -715,10 +706,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to each_pair" do
@@ -753,10 +742,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to each_value" do
@@ -799,10 +786,9 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
+ @empty = Chef::Node::Attribute.new({}, {}, {}, {})
end
it "should respond to empty?" do
@@ -810,9 +796,7 @@ describe Chef::Node::Attribute do
end
it "should return true when there are no keys" do
- @attributes = Chef::Node::Attribute.new({}, {}, {}, {}, node)
- allow(node).to receive(:attributes).and_return(@attributes)
- expect(@attributes.empty?).to eq(true)
+ expect(@empty.empty?).to eq(true)
end
it "should return false when there are keys" do
@@ -836,10 +820,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to fetch" do
@@ -895,10 +877,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to has_value?" do
@@ -942,10 +922,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to index" do
@@ -985,10 +963,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to values" do
@@ -1023,10 +999,8 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
end
it "should respond to select" do
@@ -1075,11 +1049,10 @@ describe Chef::Node::Attribute do
"one" => "six",
"snack" => "cookies",
},
- {},
- node
+ {}
)
- allow(node).to receive(:attributes).and_return(@attributes)
+ @empty = Chef::Node::Attribute.new({}, {}, {}, {})
end
it "should respond to size" do
@@ -1091,9 +1064,7 @@ describe Chef::Node::Attribute do
end
it "should return 0 for an empty attribute" do
- @attributes = Chef::Node::Attribute.new({}, {}, {}, {}, node)
- allow(node).to receive(:attributes).and_return(@attributes)
- expect(@attributes.size).to eq(0)
+ expect(@empty.size).to eq(0)
end
it "should return the number of pairs" do
@@ -1121,9 +1092,8 @@ describe Chef::Node::Attribute do
describe "to_s" do
it "should output simple attributes" do
- @attributes = Chef::Node::Attribute.new(nil, nil, nil, nil, node)
- allow(node).to receive(:attributes).and_return(@attributes)
- expect(@attributes.to_s).to eq("{}")
+ attributes = Chef::Node::Attribute.new(nil, nil, nil, nil)
+ expect(attributes.to_s).to eq("{}")
end
it "should output merged attributes" do
@@ -1135,9 +1105,8 @@ describe Chef::Node::Attribute do
"b" => 3,
"c" => 4,
}
- @attributes = Chef::Node::Attribute.new(nil, default_hash, override_hash, nil, node)
- allow(node).to receive(:attributes).and_return(@attributes)
- expect(@attributes.to_s).to eq('{"b"=>3, "c"=>4, "a"=>1}')
+ attributes = Chef::Node::Attribute.new(nil, default_hash, override_hash, nil)
+ expect(attributes.to_s).to eq('{"a"=>1, "b"=>3, "c"=>4}')
end
end
diff --git a/spec/unit/node/immutable_collections_spec.rb b/spec/unit/node/immutable_collections_spec.rb
index d7427cd983..273c3d2704 100644
--- a/spec/unit/node/immutable_collections_spec.rb
+++ b/spec/unit/node/immutable_collections_spec.rb
@@ -20,18 +20,13 @@ require "spec_helper"
require "chef/node/immutable_collections"
describe Chef::Node::ImmutableMash do
-
before do
- @data_in = { "key" =>
- { "top" => { "second_level" => "some value" },
- "top_level_2" => %w{array of values},
- "top_level_3" => [{ "hash_array" => 1, "hash_array_b" => 2 }],
- "top_level_4" => { "level2" => { "key" => "value" } },
- },
+ @data_in = { "top" => { "second_level" => "some value" },
+ "top_level_2" => %w{array of values},
+ "top_level_3" => [{ "hash_array" => 1, "hash_array_b" => 2 }],
+ "top_level_4" => { "level2" => { "key" => "value" } },
}
- @node = Chef::Node.new()
- @node.attributes.default = @data_in
- @immutable_mash = @node["key"]
+ @immutable_mash = Chef::Node::ImmutableMash.new(@data_in)
end
it "does not have any unaudited methods" do
@@ -67,9 +62,9 @@ describe Chef::Node::ImmutableMash do
# we only ever absorb VividMashes from other precedence levels, which already have
# been coerced to only have string keys, so we do not need to do that work twice (performance).
it "does not call convert_value like Mash/VividMash" do
- @node.attributes.default = { test: "foo", "test2" => "bar" }
- expect(@node[:test]).to eql("foo")
- expect(@node["test2"]).to eql("bar")
+ @mash = Chef::Node::ImmutableMash.new({ test: "foo", "test2" => "bar" })
+ expect(@mash[:test]).to eql("foo")
+ expect(@mash["test2"]).to eql("bar")
end
describe "to_hash" do
@@ -90,9 +85,7 @@ describe Chef::Node::ImmutableMash do
end
it "should create a mash with the same content" do
- puts @copy.class
- puts @immutable_mash.class
- expect(@immutable_mash).to eq(@copy)
+ expect(@copy).to eq(@immutable_mash)
end
it "should allow mutation" do
@@ -187,11 +180,9 @@ end
describe Chef::Node::ImmutableArray do
before do
- @node = Chef::Node.new()
- @node.attributes.default = { "key" => ["level1", %w{foo bar baz} + Array(1..3) + [nil, true, false, [ "el", 0, nil ] ], { "m" => "m" }] }
- @immutable_array = @node["key"][1]
- @immutable_mash = @node["key"][2]
- @immutable_nested_array = @node["key"]
+ @immutable_array = Chef::Node::ImmutableArray.new(%w{foo bar baz} + Array(1..3) + [nil, true, false, [ "el", 0, nil ] ])
+ immutable_mash = Chef::Node::ImmutableMash.new({ "m" => "m" })
+ @immutable_nested_array = Chef::Node::ImmutableArray.new(["level1", @immutable_array, immutable_mash])
end
##
@@ -268,7 +259,7 @@ describe Chef::Node::ImmutableArray do
end
it "should create an array with the same content" do
- expect(@immutable_nested_array).to eq(@copy)
+ expect(@copy).to eq(@immutable_nested_array)
end
it "should allow mutation" do
@@ -333,11 +324,4 @@ describe Chef::Node::ImmutableArray do
expect(@immutable_array[1, 2]).to eql(%w{bar baz})
end
end
-
- describe "uniq" do
- it "works" do
- @node.attributes.default = { "key" => %w{foo bar foo baz bar} }
- expect(@node["key"].uniq).to eql(%w{foo bar baz})
- end
- end
end
diff --git a/spec/unit/node/vivid_mash_spec.rb b/spec/unit/node/vivid_mash_spec.rb
index 651cfa0058..4898c22380 100644
--- a/spec/unit/node/vivid_mash_spec.rb
+++ b/spec/unit/node/vivid_mash_spec.rb
@@ -1,5 +1,5 @@
#
-# Copyright:: Copyright 2016-2017, Chef Software Inc.
+# Copyright:: Copyright 2016, Chef Software Inc.
# License:: Apache License, Version 2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
@@ -60,7 +60,7 @@ describe Chef::Node::VividMash do
end
it "deep converts values through arrays" do
- expect(root).to receive(:reset_cache).with(no_args)
+ expect(root).to receive(:reset_cache).with("foo")
vivid["foo"] = [ { :bar => true } ]
expect(vivid["foo"].class).to eql(Chef::Node::AttrArray)
expect(vivid["foo"][0].class).to eql(Chef::Node::VividMash)
@@ -68,7 +68,7 @@ describe Chef::Node::VividMash do
end
it "deep converts values through nested arrays" do
- expect(root).to receive(:reset_cache).with(no_args)
+ expect(root).to receive(:reset_cache).with("foo")
vivid["foo"] = [ [ { :bar => true } ] ]
expect(vivid["foo"].class).to eql(Chef::Node::AttrArray)
expect(vivid["foo"][0].class).to eql(Chef::Node::AttrArray)
@@ -77,7 +77,7 @@ describe Chef::Node::VividMash do
end
it "deep converts values through hashes" do
- expect(root).to receive(:reset_cache).with(no_args)
+ expect(root).to receive(:reset_cache).with("foo")
vivid["foo"] = { baz: { :bar => true } }
expect(vivid["foo"]).to be_an_instance_of(Chef::Node::VividMash)
expect(vivid["foo"]["baz"]).to be_an_instance_of(Chef::Node::VividMash)
@@ -184,55 +184,42 @@ describe Chef::Node::VividMash do
it "should deeply autovivify" do
expect(root).to receive(:reset_cache).at_least(:once).with("one")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five", "six")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five", "six", "seven")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five", "six", "seven", "eight")
vivid.write("one", "five", "six", "seven", "eight", "nine", "ten")
expect(vivid["one"]["five"]["six"]["seven"]["eight"]["nine"]).to eql("ten")
end
it "should raise an exception if you overwrite an array with a hash" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
expect(root).to receive(:reset_cache).at_least(:once).with("array")
vivid.write("array", "five", "six")
expect(vivid).to eql({ "one" => { "two" => { "three" => "four" } }, "array" => { "five" => "six" }, "nil" => nil })
end
it "should raise an exception if you traverse through an array with a hash" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
expect(root).to receive(:reset_cache).at_least(:once).with("array")
- expect(root).to receive(:reset_cache).at_least(:once).with("array", "five")
vivid.write("array", "five", "six", "seven")
expect(vivid).to eql({ "one" => { "two" => { "three" => "four" } }, "array" => { "five" => { "six" => "seven" } }, "nil" => nil })
end
it "should raise an exception if you overwrite a string with a hash" do
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "two")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "two", "three")
+ expect(root).to receive(:reset_cache).at_least(:once).with("one")
vivid.write("one", "two", "three", "four", "five")
expect(vivid).to eql({ "one" => { "two" => { "three" => { "four" => "five" } } }, "array" => [ 0, 1, 2 ], "nil" => nil })
end
it "should raise an exception if you traverse through a string with a hash" do
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "two")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "two", "three")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "two", "three", "four")
+ expect(root).to receive(:reset_cache).at_least(:once).with("one")
vivid.write("one", "two", "three", "four", "five", "six")
expect(vivid).to eql({ "one" => { "two" => { "three" => { "four" => { "five" => "six" } } } }, "array" => [ 0, 1, 2 ], "nil" => nil })
end
it "should raise an exception if you overwrite a nil with a hash" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
expect(root).to receive(:reset_cache).at_least(:once).with("nil")
vivid.write("nil", "one", "two")
expect(vivid).to eql({ "one" => { "two" => { "three" => "four" } }, "array" => [ 0, 1, 2 ], "nil" => { "one" => "two" } })
end
it "should raise an exception if you traverse through a nil with a hash" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
expect(root).to receive(:reset_cache).at_least(:once).with("nil")
- expect(root).to receive(:reset_cache).at_least(:once).with("nil", "one")
vivid.write("nil", "one", "two", "three")
expect(vivid).to eql({ "one" => { "two" => { "three" => "four" } }, "array" => [ 0, 1, 2 ], "nil" => { "one" => { "two" => "three" } } })
end
@@ -253,10 +240,6 @@ describe Chef::Node::VividMash do
it "should deeply autovivify" do
expect(root).to receive(:reset_cache).at_least(:once).with("one")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five", "six")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five", "six", "seven")
- expect(root).to receive(:reset_cache).at_least(:once).with("one", "five", "six", "seven", "eight")
vivid.write!("one", "five", "six", "seven", "eight", "nine", "ten")
expect(vivid["one"]["five"]["six"]["seven"]["eight"]["nine"]).to eql("ten")
end
@@ -312,7 +295,7 @@ describe Chef::Node::VividMash do
end
it "should unlink hashes" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
+ expect(root).to receive(:reset_cache).at_least(:once).with("one")
expect( vivid.unlink("one") ).to eql({ "two" => { "three" => "four" } })
expect(vivid).to eql({ "array" => [ 0, 1, 2 ], "nil" => nil })
end
@@ -324,7 +307,7 @@ describe Chef::Node::VividMash do
end
it "should unlink nil" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
+ expect(root).to receive(:reset_cache).at_least(:once).with("nil")
expect(vivid.unlink("nil")).to eql(nil)
expect(vivid).to eql({ "one" => { "two" => { "three" => "four" } }, "array" => [ 0, 1, 2 ] })
end
@@ -344,7 +327,7 @@ describe Chef::Node::VividMash do
end
it "should unlink! hashes" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
+ expect(root).to receive(:reset_cache).at_least(:once).with("one")
expect( vivid.unlink!("one") ).to eql({ "two" => { "three" => "four" } })
expect(vivid).to eql({ "array" => [ 0, 1, 2 ], "nil" => nil })
end
@@ -356,7 +339,7 @@ describe Chef::Node::VividMash do
end
it "should unlink! nil" do
- expect(root).to receive(:reset_cache).at_least(:once).with(no_args)
+ expect(root).to receive(:reset_cache).at_least(:once).with("nil")
expect(vivid.unlink!("nil")).to eql(nil)
expect(vivid).to eql({ "one" => { "two" => { "three" => "four" } }, "array" => [ 0, 1, 2 ] })
end