diff options
author | Lamont Granquist <lamont@scriptkiddie.org> | 2015-04-11 12:48:22 -0700 |
---|---|---|
committer | Lamont Granquist <lamont@scriptkiddie.org> | 2015-04-15 17:50:15 -0700 |
commit | e3a6565927e854cd5968bd3a6bd2248ec1245549 (patch) | |
tree | 590bfa3f9c3a4992096c0ccb679fcc7deda74243 /spec/unit | |
parent | a959404b15ba6bdc98063cfa0c70e6f9eec9ccee (diff) | |
download | chef-e3a6565927e854cd5968bd3a6bd2248ec1245549.tar.gz |
add resource_resolver and resource_priority_map
also wire them up through the Chef class.
Diffstat (limited to 'spec/unit')
-rw-r--r-- | spec/unit/chef_class_spec.rb | 91 | ||||
-rw-r--r-- | spec/unit/provider_resolver_spec.rb | 1 | ||||
-rw-r--r-- | spec/unit/recipe_spec.rb | 39 | ||||
-rw-r--r-- | spec/unit/resource_spec.rb | 12 |
4 files changed, 137 insertions, 6 deletions
diff --git a/spec/unit/chef_class_spec.rb b/spec/unit/chef_class_spec.rb new file mode 100644 index 0000000000..2528246be6 --- /dev/null +++ b/spec/unit/chef_class_spec.rb @@ -0,0 +1,91 @@ +# +# Author:: Lamont Granquist (<lamont@chef.io>) +# Copyright:: Copyright (c) 2015 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. +# + +require 'spec_helper' + +describe "Chef class" do + let(:platform) { "debian" } + + let(:node) do + node = Chef::Node.new + node.automatic['platform'] = platform + node + end + + let(:run_context) do + Chef::RunContext.new(node, nil, nil) + end + + let(:resource_priority_map) do + double("Chef::Platform::ResourcePriorityMap") + end + + let(:provider_priority_map) do + double("Chef::Platform::ProviderPriorityMap") + end + + before do + Chef.set_run_context(run_context) + Chef.set_node(node) + Chef.set_resource_priority_map(resource_priority_map) + Chef.set_provider_priority_map(provider_priority_map) + end + + after do + Chef.reset! + end + + context "priority maps" do + context "#get_provider_priority_array" do + it "should use the current node to get the right priority_map" do + expect(provider_priority_map).to receive(:get_priority_array).with(node, :http_request).and_return("stuff") + expect(Chef.get_provider_priority_array(:http_request)).to eql("stuff") + end + end + context "#get_resource_priority_array" do + it "should use the current node to get the right priority_map" do + expect(resource_priority_map).to receive(:get_priority_array).with(node, :http_request).and_return("stuff") + expect(Chef.get_resource_priority_array(:http_request)).to eql("stuff") + end + end + context "#set_provider_priority_array" do + it "should delegate to the provider_priority_map" do + expect(provider_priority_map).to receive(:set_priority_array).with(:http_request, ["a", "b"], platform: "debian").and_return("stuff") + expect(Chef.set_provider_priority_array(:http_request, ["a", "b"], platform: "debian")).to eql("stuff") + end + end + context "#set_priority_map_for_resource" do + it "should delegate to the resource_priority_map" do + expect(resource_priority_map).to receive(:set_priority_array).with(:http_request, ["a", "b"], platform: "debian").and_return("stuff") + expect(Chef.set_resource_priority_array(:http_request, ["a", "b"], platform: "debian")).to eql("stuff") + end + end + end + + context "#run_context" do + it "should return the injected RunContext" do + expect(Chef.run_context).to eql(run_context) + end + end + + context "#node" do + it "should return the injected Node" do + expect(Chef.node).to eql(node) + end + end +end diff --git a/spec/unit/provider_resolver_spec.rb b/spec/unit/provider_resolver_spec.rb index 63c381f08e..718eebfdf4 100644 --- a/spec/unit/provider_resolver_spec.rb +++ b/spec/unit/provider_resolver_spec.rb @@ -18,6 +18,7 @@ require 'spec_helper' require 'chef/mixin/convert_to_class_name' +require 'chef/provider_resolver' include Chef::Mixin::ConvertToClassName diff --git a/spec/unit/recipe_spec.rb b/spec/unit/recipe_spec.rb index b370e12732..7442f4477e 100644 --- a/spec/unit/recipe_spec.rb +++ b/spec/unit/recipe_spec.rb @@ -20,6 +20,7 @@ # require 'spec_helper' +require 'chef/platform/resource_priority_map' describe Chef::Recipe do @@ -136,6 +137,44 @@ describe Chef::Recipe do res.kind_of?(YourMom) end + describe "when there is more than one resource that resolves on a node" do + before do + node.automatic[:platform] = "nbc_sports" + Sounders = Class.new(Chef::Resource) + Sounders.provides :football, platform: "nbc_sports" + TottenhamHotspur = Class.new(Chef::Resource) + TottenhamHotspur.provides :football, platform: "nbc_sports" + end + + after do + Object.send(:remove_const, :Sounders) + Object.send(:remove_const, :TottenhamHotspur) + end + + it "warns if resolution of the two resources is ambiguous" do + expect(Chef::Log).to receive(:warn).at_least(:once).with(/Ambiguous resource precedence/) + res1 = recipe.football "club world cup" + expect(res1.name).to eql("club world cup") + # the class of res1 is not defined. + end + + it "selects one if it is given priority" do + expect(Chef::Log).not_to receive(:warn) + Chef::Platform::ResourcePriorityMap.instance.send(:priority, :football, TottenhamHotspur, platform: "nbc_sports") + res1 = recipe.football "club world cup" + expect(res1.name).to eql("club world cup") + expect(res1).to be_a_kind_of(TottenhamHotspur) + end + + it "selects the other one if it is given priority" do + expect(Chef::Log).not_to receive(:warn) + Chef::Platform::ResourcePriorityMap.instance.send(:priority, :football, Sounders, platform: "nbc_sports") + res1 = recipe.football "club world cup" + expect(res1.name).to eql("club world cup") + expect(res1).to be_a_kind_of(Sounders) + end + end + end end diff --git a/spec/unit/resource_spec.rb b/spec/unit/resource_spec.rb index 8214021f65..6b2d6c89d3 100644 --- a/spec/unit/resource_spec.rb +++ b/spec/unit/resource_spec.rb @@ -709,22 +709,22 @@ describe Chef::Resource do end it 'adds mappings for a single platform' do - expect(Chef::Resource.node_map).to receive(:set).with( - :dinobot, Chef::Resource::Klz, { platform: ['autobots'] } + expect(Chef::Resource::Klz.node_map).to receive(:set).with( + :dinobot, true, { platform: ['autobots'] } ) klz.provides :dinobot, platform: ['autobots'] end it 'adds mappings for multiple platforms' do - expect(Chef::Resource.node_map).to receive(:set).with( - :energy, Chef::Resource::Klz, { platform: ['autobots', 'decepticons']} + expect(Chef::Resource::Klz.node_map).to receive(:set).with( + :energy, true, { platform: ['autobots', 'decepticons']} ) klz.provides :energy, platform: ['autobots', 'decepticons'] end it 'adds mappings for all platforms' do - expect(Chef::Resource.node_map).to receive(:set).with( - :tape_deck, Chef::Resource::Klz, {} + expect(Chef::Resource::Klz.node_map).to receive(:set).with( + :tape_deck, true, {} ) klz.provides :tape_deck end |