diff options
author | Steven Danna <steve@opscode.com> | 2015-01-19 09:44:46 +0000 |
---|---|---|
committer | Bryan McLellan <btm@opscode.com> | 2015-02-17 08:46:37 -0500 |
commit | 664172ea426c2c0dfd965b69a0e1ae75af34a89f (patch) | |
tree | 1dabbe4a594adb0a941dfbb28787bee98e46cd34 | |
parent | 671b5d63236841a74ba0c15879027c35e488a849 (diff) | |
download | chef-664172ea426c2c0dfd965b69a0e1ae75af34a89f.tar.gz |
Add Chef::GuardInterpreter.for_resource method to reduce duplication
-rw-r--r-- | lib/chef/guard_interpreter.rb | 32 | ||||
-rw-r--r-- | lib/chef/guard_interpreter/resource_guard_interpreter.rb | 2 | ||||
-rw-r--r-- | lib/chef/resource/conditional.rb | 15 | ||||
-rw-r--r-- | lib/chef/resource/file/verification.rb | 7 | ||||
-rw-r--r-- | spec/unit/guard_interpreter_spec.rb | 41 |
5 files changed, 78 insertions, 19 deletions
diff --git a/lib/chef/guard_interpreter.rb b/lib/chef/guard_interpreter.rb new file mode 100644 index 0000000000..b968f273b9 --- /dev/null +++ b/lib/chef/guard_interpreter.rb @@ -0,0 +1,32 @@ +# +# Author:: Steven Danna (<steve@chef.io>) +# Copyright:: Copyright (c) 2015 Chef Software, 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 'chef/guard_interpreter/default_guard_interpreter' +require 'chef/guard_interpreter/resource_guard_interpreter' + +class Chef + class GuardInterpreter + def self.for_resource(resource, command, command_opts) + if resource.guard_interpreter == :default + Chef::GuardInterpreter::DefaultGuardInterpreter.new(command, command_opts) + else + Chef::GuardInterpreter::ResourceGuardInterpreter.new(resource, command, command_opts) + end + end + end +end diff --git a/lib/chef/guard_interpreter/resource_guard_interpreter.rb b/lib/chef/guard_interpreter/resource_guard_interpreter.rb index fb545c95eb..1e2a534c18 100644 --- a/lib/chef/guard_interpreter/resource_guard_interpreter.rb +++ b/lib/chef/guard_interpreter/resource_guard_interpreter.rb @@ -16,7 +16,7 @@ # limitations under the License. # -require 'chef/guard_interpreter/default_guard_interpreter' +require 'chef/guard_interpreter' class Chef class GuardInterpreter diff --git a/lib/chef/resource/conditional.rb b/lib/chef/resource/conditional.rb index cdc2638ef0..35bdae8d69 100644 --- a/lib/chef/resource/conditional.rb +++ b/lib/chef/resource/conditional.rb @@ -17,7 +17,7 @@ # require 'chef/mixin/shell_out' -require 'chef/guard_interpreter/resource_guard_interpreter' +require 'chef/guard_interpreter' class Chef class Resource @@ -56,7 +56,7 @@ class Chef def configure case @command when String,Array - @guard_interpreter = new_guard_interpreter(@parent_resource, @command, @command_opts, &@block) + @guard_interpreter = Chef::GuardInterpreter.for_resource(@parent_resource, @command, @command_opts) @block = nil when nil # We should have a block if we get here @@ -122,17 +122,6 @@ class Chef "#{@positivity} { #code block }" end end - - private - - def new_guard_interpreter(parent_resource, command, opts) - if parent_resource.guard_interpreter == :default - guard_interpreter = Chef::GuardInterpreter::DefaultGuardInterpreter.new(command, opts) - else - guard_interpreter = Chef::GuardInterpreter::ResourceGuardInterpreter.new(parent_resource, command, opts) - end - end - end end end diff --git a/lib/chef/resource/file/verification.rb b/lib/chef/resource/file/verification.rb index 4071aaaeaa..f1ca0f1883 100644 --- a/lib/chef/resource/file/verification.rb +++ b/lib/chef/resource/file/verification.rb @@ -17,6 +17,7 @@ # require 'chef/exceptions' +require 'chef/guard_interpreter' require 'chef/mixin/descendants_tracker' class Chef @@ -106,11 +107,7 @@ class Chef # the same set of options that the not_if/only_if blocks do def verify_command(path, opts) command = @command % {:file => path} - interpreter = if @parent_resource.guard_interpreter == :default - Chef::GuardInterpreter::DefaultGuardInterpreter.new(command, @command_opts) - else - Chef::GuardInterpreter::ResourceGuardInterpreter.new(@parent_resource, command, @command_opts) - end + interpreter = Chef::GuardInterpreter.for_resource(@parent_resource, command, @command_opts) interpreter.evaluate end diff --git a/spec/unit/guard_interpreter_spec.rb b/spec/unit/guard_interpreter_spec.rb new file mode 100644 index 0000000000..a7fe064948 --- /dev/null +++ b/spec/unit/guard_interpreter_spec.rb @@ -0,0 +1,41 @@ +# +# Author:: Steven Danna (steve@chef.io) +# Copyright:: Copyright (c) 2015 Chef Software, 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::GuardInterpreter do + describe "#for_resource" do + let (:resource) { Chef::Resource.new("foo")} + + it "returns a DefaultGuardInterpreter if the resource has guard_interpreter set to :default" do + resource.guard_interpreter :default + interpreter = Chef::GuardInterpreter.for_resource(resource, "", {}) + expect(interpreter.class).to eq(Chef::GuardInterpreter::DefaultGuardInterpreter) + end + + it "returns a ResourceGuardInterpreter if the resource has guard_interpreter set to !:default" do + resource.guard_interpreter :foobar + # Mock the resource guard interpreter to avoid having to set up a lot of state + # currently we are only testing that we get the correct class of object back + rgi = double("Chef::GuardInterpreter::ResourceGuardInterpreter") + allow(Chef::GuardInterpreter::ResourceGuardInterpreter).to receive(:new).and_return(rgi) + interpreter = Chef::GuardInterpreter.for_resource(resource, "", {}) + expect(interpreter).to eq(rgi) + end + end +end |