summaryrefslogtreecommitdiff
path: root/spec/unit/puppet/parser
diff options
context:
space:
mode:
authorAndrew Parker <andy@puppetlabs.com>2013-12-18 10:49:39 -0800
committerAndrew Parker <andy@puppetlabs.com>2013-12-18 10:49:39 -0800
commit1cf4b04b3392aa5bf5d9ca9a4f3eec3e194f3d08 (patch)
treef0dd96ce45e5dac8bf397e4e737886e540ee9ed6 /spec/unit/puppet/parser
parent7dc0fb68e283945f35164a9aeb9f4fb4cfd48050 (diff)
parent1077881873024a5d2f53d3b4c4159ee49ae38c7a (diff)
Merge pull request #211 from jhoblitt/function_is_bool
(#23381) add is_bool() function
Diffstat (limited to 'spec/unit/puppet/parser')
-rw-r--r--spec/unit/puppet/parser/functions/is_bool_spec.rb44
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