diff options
| author | Daniel Pittman <daniel@puppetlabs.com> | 2011-04-14 15:20:38 -0700 |
|---|---|---|
| committer | Daniel Pittman <daniel@puppetlabs.com> | 2011-04-15 15:14:29 -0700 |
| commit | dca1f077dd7a818aee447222a7649742f2b1575f (patch) | |
| tree | b8083451556f444d8e580f298704499063e4aa6e /spec/unit/interface/option_builder_spec.rb | |
| parent | 0c60aa28d2d15e7e718792871af3350c3a1fa5c7 (diff) | |
(#6978) Add before and after decorators to actions from options.
Options can now add before_action and after_action blocks; these are invoked
before or after any action is invoked on the face. This allows these options
to declare common behaviour and have it automatically applied to the actions
invoked.
Option hooks have no defined order of invocation: they will run in a
completely random order. Where there are dependencies they should be on the
value of the options hash passed to the invocation, not on side-effects of the
other invocations.
You are not able to influence the arguments, options, or calling of the action
body in a before or after decorator. This is by design.
The invocation passes to the hook:
1. The action object representing this action.
2. The arguments to the action, as an array.
3. The options for the action, as a hash.
Paired-With: Max Martin <max@puppetlabs.com>
Diffstat (limited to 'spec/unit/interface/option_builder_spec.rb')
| -rwxr-xr-x | spec/unit/interface/option_builder_spec.rb | 31 |
1 files changed, 18 insertions, 13 deletions
diff --git a/spec/unit/interface/option_builder_spec.rb b/spec/unit/interface/option_builder_spec.rb index fae48324e..0bcbed82c 100755 --- a/spec/unit/interface/option_builder_spec.rb +++ b/spec/unit/interface/option_builder_spec.rb @@ -8,22 +8,27 @@ describe Puppet::Interface::OptionBuilder do should be_an_instance_of Puppet::Interface::Option end - describe "when using the DSL block" do - it "should work with an empty block" do - option = Puppet::Interface::OptionBuilder.build(face, "--foo") do - # This block deliberately left blank. - end + it "should work with an empty block" do + option = Puppet::Interface::OptionBuilder.build(face, "--foo") do + # This block deliberately left blank. + end + + option.should be_an_instance_of Puppet::Interface::Option + end - option.should be_an_instance_of Puppet::Interface::Option + it "should support documentation declarations" do + text = "this is the description" + option = Puppet::Interface::OptionBuilder.build(face, "--foo") do + desc text end + option.should be_an_instance_of Puppet::Interface::Option + option.desc.should == text + end - it "should support documentation declarations" do - text = "this is the description" - option = Puppet::Interface::OptionBuilder.build(face, "--foo") do - desc text - end - option.should be_an_instance_of Puppet::Interface::Option - option.desc.should == text + it "should support a before_action hook" do + option = Puppet::Interface::OptionBuilder.build(face, "--foo") do + before_action do :whatever end end + option.before_action.should be_an_instance_of UnboundMethod end end |
