summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteven Danna <steve@opscode.com>2015-01-19 09:44:46 +0000
committerBryan McLellan <btm@opscode.com>2015-02-17 08:46:37 -0500
commit664172ea426c2c0dfd965b69a0e1ae75af34a89f (patch)
tree1dabbe4a594adb0a941dfbb28787bee98e46cd34
parent671b5d63236841a74ba0c15879027c35e488a849 (diff)
downloadchef-664172ea426c2c0dfd965b69a0e1ae75af34a89f.tar.gz
Add Chef::GuardInterpreter.for_resource method to reduce duplication
-rw-r--r--lib/chef/guard_interpreter.rb32
-rw-r--r--lib/chef/guard_interpreter/resource_guard_interpreter.rb2
-rw-r--r--lib/chef/resource/conditional.rb15
-rw-r--r--lib/chef/resource/file/verification.rb7
-rw-r--r--spec/unit/guard_interpreter_spec.rb41
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