URI.escape for the array case was incorrect.

The previous commit to uriescape() changed the implementation to use the ruby default escape list for URI.escape(), but did not change the call triggered when uriescape() was called on an array, triggering ruby errors.
This commit is contained in:
Bryon Roché 2014-08-08 16:59:37 -07:00 committed by Morgan Haskel
parent 055083c117
commit 41baef8502
2 changed files with 8 additions and 1 deletions

View file

@ -22,7 +22,7 @@ module Puppet::Parser::Functions
if value.is_a?(Array) if value.is_a?(Array)
# Numbers in Puppet are often string-encoded which is troublesome ... # Numbers in Puppet are often string-encoded which is troublesome ...
result = value.collect { |i| i.is_a?(String) ? URI.escape(i,unsafe) : i } result = value.collect { |i| i.is_a?(String) ? URI.escape(i) : i }
else else
result = URI.escape(value) result = URI.escape(value)
end end

View file

@ -17,6 +17,13 @@ describe "the uriescape function" do
expect(result).to(eq(':/?%23[]@!$&\'()*+,;=%20%22%7B%7D')) expect(result).to(eq(':/?%23[]@!$&\'()*+,;=%20%22%7B%7D'))
end end
it "should uriescape an array of strings, while not touching up nonstrings" do
teststring = ":/?#[]@!$&'()*+,;= \"{}"
expectstring = ':/?%23[]@!$&\'()*+,;=%20%22%7B%7D'
result = scope.function_uriescape([[teststring, teststring, 1]])
expect(result).to(eq([expectstring, expectstring, 1]))
end
it "should do nothing if a string is already safe" do it "should do nothing if a string is already safe" do
result = scope.function_uriescape(["ABCdef"]) result = scope.function_uriescape(["ABCdef"])
expect(result).to(eq('ABCdef')) expect(result).to(eq('ABCdef'))