(19864) num2bool match fix
This is a bit more heavy-handed than I might like, but it does appear to do the right things: * accepts numeric input appropriately, truncating floats * matches string input against a regex, then coerces number-looking strings to int * makes a best effort to coerce anything else to a string, then subjects it to the same treatment * raises an error in the event of incorrect number of arguments or non-number-looking strings I've also included some additional unit tests.
This commit is contained in:
parent
4a5218a8af
commit
8d217f0012
2 changed files with 56 additions and 7 deletions
|
@ -13,13 +13,32 @@ become true.
|
|||
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
|
||||
|
|
|
@ -16,6 +16,10 @@ describe "the num2bool function" do
|
|||
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)
|
||||
|
@ -26,6 +30,16 @@ describe "the num2bool function" do
|
|||
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)
|
||||
|
@ -36,6 +50,16 @@ describe "the num2bool function" do
|
|||
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)
|
||||
|
@ -46,8 +70,14 @@ describe "the num2bool function" do
|
|||
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
|
||||
|
|
Loading…
Reference in a new issue