(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:
Steve Huff 2013-03-29 15:06:36 -04:00
parent 4a5218a8af
commit 8d217f0012
2 changed files with 56 additions and 7 deletions

View file

@ -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

View file

@ -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