diff options
author | Andrew Parker <andy@puppetlabs.com> | 2013-12-18 10:49:39 -0800 |
---|---|---|
committer | Andrew Parker <andy@puppetlabs.com> | 2013-12-18 10:49:39 -0800 |
commit | 1cf4b04b3392aa5bf5d9ca9a4f3eec3e194f3d08 (patch) | |
tree | f0dd96ce45e5dac8bf397e4e737886e540ee9ed6 /spec/unit/puppet/parser/functions | |
parent | 7dc0fb68e283945f35164a9aeb9f4fb4cfd48050 (diff) | |
parent | 1077881873024a5d2f53d3b4c4159ee49ae38c7a (diff) |
Merge pull request #211 from jhoblitt/function_is_bool
(#23381) add is_bool() function
Diffstat (limited to 'spec/unit/puppet/parser/functions')
-rw-r--r-- | spec/unit/puppet/parser/functions/is_bool_spec.rb | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/spec/unit/puppet/parser/functions/is_bool_spec.rb b/spec/unit/puppet/parser/functions/is_bool_spec.rb new file mode 100644 index 0000000..c94e83a --- /dev/null +++ b/spec/unit/puppet/parser/functions/is_bool_spec.rb @@ -0,0 +1,44 @@ +#! /usr/bin/env ruby -S rspec +require 'spec_helper' + +describe "the is_bool function" do + let(:scope) { PuppetlabsSpec::PuppetInternals.scope } + + it "should exist" do + Puppet::Parser::Functions.function("is_bool").should == "function_is_bool" + end + + it "should raise a ParseError if there is less than 1 arguments" do + lambda { scope.function_is_bool([]) }.should( raise_error(Puppet::ParseError)) + end + + it "should return true if passed a TrueClass" do + result = scope.function_is_bool([true]) + result.should(eq(true)) + end + + it "should return true if passed a FalseClass" do + result = scope.function_is_bool([false]) + result.should(eq(true)) + end + + it "should return false if passed the string 'true'" do + result = scope.function_is_bool(['true']) + result.should(eq(false)) + end + + it "should return false if passed the string 'false'" do + result = scope.function_is_bool(['false']) + result.should(eq(false)) + end + + it "should return false if passed an array" do + result = scope.function_is_bool([["a","b"]]) + result.should(eq(false)) + end + + it "should return false if passed a hash" do + result = scope.function_is_bool([{"a" => "b"}]) + result.should(eq(false)) + end +end |