summaryrefslogtreecommitdiffstats
path: root/spec/unit/interface
diff options
context:
space:
mode:
authorDaniel Pittman <daniel@puppetlabs.com>2011-07-20 12:35:22 -0700
committerDaniel Pittman <daniel@puppetlabs.com>2011-07-20 17:07:10 -0700
commitfd6a653cb32cb03e339655862c526fd5dccbfcf0 (patch)
tree30e7f89b5a2e9cfa96a1da2e209d0f88c4d30dc9 /spec/unit/interface
parentb75b1c19ecf6c278b065d203ac8486fa598caa8b (diff)
downloadpuppet-fd6a653cb32cb03e339655862c526fd5dccbfcf0.tar.gz
puppet-fd6a653cb32cb03e339655862c526fd5dccbfcf0.tar.xz
puppet-fd6a653cb32cb03e339655862c526fd5dccbfcf0.zip
(#7123) Support runtime setting of 'default' on actions.
Given the inheritance model for actions, we are sometimes going to need to set them to 'default' at runtime, rather than during their static declaration. Add tests to verify that this works correctly, and update the code to ensure that happens. This gives up caching of the default action, but this should be an extremely rare operation - pretty much only CLI invocation, really. Reviewed-By: Pieter van de Bruggen <pieter@puppetlabs.com>
Diffstat (limited to 'spec/unit/interface')
-rwxr-xr-xspec/unit/interface/action_spec.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/spec/unit/interface/action_spec.rb b/spec/unit/interface/action_spec.rb
index dbbf84778..d71a7d000 100755
--- a/spec/unit/interface/action_spec.rb
+++ b/spec/unit/interface/action_spec.rb
@@ -597,4 +597,22 @@ describe Puppet::Interface::Action do
end
end
end
+
+ context "runtime manipulations" do
+ subject do
+ Puppet::Interface.new(:runtime_manipulations, '1.0.0') do
+ action :foo do
+ when_invoked do |options| options end
+ end
+ end
+ end
+
+ let :action do subject.get_action :foo end
+
+ it "should be the face default action if default is set true" do
+ subject.get_default_action.should be_nil
+ action.default = true
+ subject.get_default_action.should == action
+ end
+ end
end