raise(Puppet::ParseError, "num2bool(): Wrong number of arguments " +
"given (#{arguments.size} for 1)") if arguments.size != 1
- # we need to get an Integer out of this
- begin
- number = arguments[0].to_i
- rescue NoMethodError
- raise(Puppet::ParseError, 'num2bool(): Unable to parse number: ' + $!)
+ number = arguments[0]
+
+ case number
+ when Numeric
+ # Yay, it's a number
+ when String
+ # Deal with strings later
+ else
+ begin
+ number = number.to_s
+ rescue NoMethodError
+ raise(Puppet::ParseError, 'num2bool(): Unable to parse argument: ' + $!)
+ end
+ end
+
+ case number
+ when String
+ # Only accept strings that look somewhat like numbers
+ unless number =~ /^-?\d+/
+ raise(Puppet::ParseError, "num2bool(): '#{number}' does not look like a number")
+ end
end
+ # Truncate floats
+ number = number.to_i
+
# Return true for any positive number and false otherwise
return number > 0 ? true : false
end
lambda { scope.function_num2bool(["foo","bar"]) }.should( raise_error(Puppet::ParseError))
end
+ it "should raise a ParseError if passed something non-numeric" do
+ lambda { scope.function_num2bool(["xyzzy"]) }.should( raise_error(Puppet::ParseError))
+ end
+
it "should return true if passed string 1" do
result = scope.function_num2bool(["1"])
result.should(be_true)
result.should(be_true)
end
+ it "should return true if passed array with string 1" do
+ result = scope.function_num2bool([["1"]])
+ result.should(be_true)
+ end
+
+ it "should return true if passed array with number 1" do
+ result = scope.function_num2bool([[1]])
+ result.should(be_true)
+ end
+
it "should return false if passed string 0" do
result = scope.function_num2bool(["0"])
result.should(be_false)
result.should(be_false)
end
+ it "should return false if passed array with string 0" do
+ result = scope.function_num2bool([["0"]])
+ result.should(be_false)
+ end
+
+ it "should return false if passed array with number 0" do
+ result = scope.function_num2bool([[0]])
+ result.should(be_false)
+ end
+
it "should return false if passed string -1" do
result = scope.function_num2bool(["-1"])
result.should(be_false)
result.should(be_false)
end
- it "should return false if passed something non-numeric" do
- result = scope.function_num2bool(["xyzzy"])
+ it "should return false if passed array with string -1" do
+ result = scope.function_num2bool([["-1"]])
result.should(be_false)
end
+
+ it "should return false if passed array with number -1" do
+ result = scope.function_num2bool([[-1]])
+ result.should(be_false)
+ end
+
end