diff options
author | Ashley Penney <ashley.penney@puppetlabs.com> | 2014-05-08 13:58:53 -0400 |
---|---|---|
committer | Ashley Penney <ashley.penney@puppetlabs.com> | 2014-05-08 13:58:53 -0400 |
commit | e2297a1ea6b711ca930a21adc56aefe7c602826f (patch) | |
tree | a731fa4c18deac09565cb696b73b29b27c520d98 /spec/functions/pick_spec.rb | |
parent | 17a912ea0afb3fb018170477856c25a95009f2cc (diff) | |
parent | 96e43e69d8496926ad4951534e75b204bb279f22 (diff) | |
download | puppet-stdlib-e2297a1ea6b711ca930a21adc56aefe7c602826f.tar.gz puppet-stdlib-e2297a1ea6b711ca930a21adc56aefe7c602826f.tar.bz2 |
Merge pull request #250 from hunner/move_unit
Move unit tests to spec/functions
Diffstat (limited to 'spec/functions/pick_spec.rb')
-rwxr-xr-x | spec/functions/pick_spec.rb | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/spec/functions/pick_spec.rb b/spec/functions/pick_spec.rb new file mode 100755 index 0000000..f53fa80 --- /dev/null +++ b/spec/functions/pick_spec.rb @@ -0,0 +1,34 @@ +#!/usr/bin/env ruby -S rspec +require 'spec_helper' + +describe "the pick function" do + let(:scope) { PuppetlabsSpec::PuppetInternals.scope } + + it "should exist" do + Puppet::Parser::Functions.function("pick").should == "function_pick" + end + + it 'should return the correct value' do + scope.function_pick(['first', 'second']).should == 'first' + end + + it 'should return the correct value if the first value is empty' do + scope.function_pick(['', 'second']).should == 'second' + end + + it 'should remove empty string values' do + scope.function_pick(['', 'first']).should == 'first' + end + + it 'should remove :undef values' do + scope.function_pick([:undef, 'first']).should == 'first' + end + + it 'should remove :undefined values' do + scope.function_pick([:undefined, 'first']).should == 'first' + end + + it 'should error if no values are passed' do + expect { scope.function_pick([]) }.to( raise_error(Puppet::ParseError, "pick(): must receive at least one non empty value")) + end +end |