summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/chef/resource/conditional.rb5
-rw-r--r--spec/unit/resource/conditional_spec.rb9
2 files changed, 14 insertions, 0 deletions
diff --git a/lib/chef/resource/conditional.rb b/lib/chef/resource/conditional.rb
index e6623be5dd..ad082c82d1 100644
--- a/lib/chef/resource/conditional.rb
+++ b/lib/chef/resource/conditional.rb
@@ -52,6 +52,11 @@ class Chef
@block = nil
when nil
raise ArgumentError, "only_if/not_if requires either a command or a block" unless block_given?
+ if parent_resource.guard_interpreter != :default
+ msg = "#{parent_resource.name} was given a guard_interpreter of #{parent_resource.guard_interpreter}, "
+ msg << "but not given a command as a string. guard_interpreter does not support blocks."
+ raise ArgumentError, msg
+ end
@guard_interpreter = nil
@command, @command_opts = nil, nil
@block = block
diff --git a/spec/unit/resource/conditional_spec.rb b/spec/unit/resource/conditional_spec.rb
index 4df185bcd6..92ca53118b 100644
--- a/spec/unit/resource/conditional_spec.rb
+++ b/spec/unit/resource/conditional_spec.rb
@@ -27,6 +27,15 @@ describe Chef::Resource::Conditional do
@parent_resource = Chef::Resource.new(nil, Chef::Node.new)
end
+ it "raises an exception when a guard_interpreter is specified and a block is given" do
+ @parent_resource.guard_interpreter :canadian_mounties
+ expect { Chef::Resource::Conditional.send(:new, :always, @parent_resource, nil, {}) { True } }.to raise_error(ArgumentError, /does not support blocks/)
+ end
+
+ it "raises an exception when neither a block or command is given" do
+ expect { Chef::Resource::Conditional.send(:new, :always, @parent_resource, nil, {})}.to raise_error(ArgumentError, /requires either a command or a block/)
+ end
+
describe "when created as an `only_if`" do
describe "after running a successful command" do
before do