0
0
Fork 0

Replace 'parse_query_string' with 'decode_www_form_18' in test

This commit is contained in:
Stormwind 2012-12-22 19:58:59 +01:00
parent fac934af6d
commit 96f2b7a6c4
1 changed files with 23 additions and 21 deletions

View File

@ -2,41 +2,41 @@
require 'spec_helper'
describe URI, '#parse_query_string' do
describe URI, '#decode_www_form_18' do
it 'seperates parameter into an array' do
result = URI::parse_query_string("foo=bar&bar=foo")
result = URI::decode_www_form_18("foo=bar&bar=foo")
result.should eq([['foo', 'bar'], ['bar', 'foo']])
end
it 'can handle more than two equal parameter names' do
result = URI::parse_query_string("foo=bar1&foo=bar2")
result = URI::decode_www_form_18("foo=bar1&foo=bar2")
result.should eq([['foo', 'bar1'], ['foo', 'bar2']])
end
it 'can handle whitespaces in query string' do
result = URI::parse_query_string("foo=bar&bar=bar%20foo")
result = URI::decode_www_form_18("foo=bar&bar=bar%20foo")
result.should eq([['foo', 'bar'], ['bar', 'bar foo']])
end
it 'accepts semi-colons as seperators' do
result = URI::parse_query_string("foo=bar;bar=foo")
result = URI::decode_www_form_18("foo=bar;bar=foo")
result.should eq([['foo', 'bar'], ['bar', 'foo']])
end
it 'seperates & and ; mixed queries properly' do
result = URI::parse_query_string("foo=bar&bar=foo;baz=foo")
result = URI::decode_www_form_18("foo=bar&bar=foo;baz=foo")
result.should eq([['foo', 'bar'], ['bar', 'foo'], ['baz', 'foo']])
end
it 'does not accept only a normal string as query string' do
expect{
result = URI::parse_query_string("foo")
result = URI::decode_www_form_18("foo")
# does not work, probably should?
#result.should eq([['foo', '']])
@ -47,76 +47,78 @@ describe URI, '#parse_query_string' do
end
it 'accepts empty values' do
result = URI::parse_query_string("foo=bar&bar=&baz=foo")
result = URI::decode_www_form_18("foo=bar&bar=&baz=foo")
result.should eq([['foo', 'bar'], ['bar', ''], ['baz', 'foo']])
end
it 'understands plus as whitespace' do
result = URI::parse_query_string("foo=bar&bar=bar+foo")
result = URI::decode_www_form_18("foo=bar&bar=bar+foo")
result.should eq([['foo', 'bar'], ['bar', 'bar foo']])
end
it 'does not accept whitespaces in query string' do
result = URI::parse_query_string("foo=bar&bar=bar foo&baz=foo")
result = URI::decode_www_form_18("foo=bar&bar=bar foo&baz=foo")
# Works, it probably shouldn't?
result.should eq([['foo', 'bar'], ['bar', 'bar foo'], ['baz', 'foo']])
end
it 'can handle non ascii letters in query string' do
result = URI::parse_query_string("foo=bär&bar=föö")
result = URI::decode_www_form_18("foo=bär&bar=föö")
# Works, but it maybe shouldn't?
result.should eq([['foo', 'bär'], ['bar', 'föö']])
end
it 'can handle escaped non ascii letters in query string' do
result = URI::parse_query_string("foo=b%C3%A4r&bar=f%C3%B6%C3%B6")
result = URI::decode_www_form_18("foo=b%C3%A4r&bar=f%C3%B6%C3%B6")
result.should eq([['foo', 'bär'], ['bar', 'föö']])
end
it 'accepts - in query string' do
result = URI::parse_query_string("foo-bar=bar&bar=foo-bar")
result = URI::decode_www_form_18("foo-bar=bar&bar=foo-bar")
puts (URI::decode_www_form_18("foo-bar=bar&bar=foo-bar") == [['foo-bar', 'bar'], ['bar', 'foo-bar']]).inspect
result.should eq([['foo-bar', 'bar'], ['bar', 'foo-bar']])
end
it 'accepts . in query string' do
result = URI::parse_query_string("foo.bar=bar&bar=foo.bar")
result = URI::decode_www_form_18("foo.bar=bar&bar=foo.bar")
result.should eq([['foo.bar', 'bar'], ['bar', 'foo.bar']])
end
it 'accepts ~ in query string' do
result = URI::parse_query_string("foo~bar=bar&bar=foo~bar")
result = URI::decode_www_form_18("foo~bar=bar&bar=foo~bar")
result.should eq([['foo~bar', 'bar'], ['bar', 'foo~bar']])
end
it 'accepts _ in query string' do
result = URI::parse_query_string("foo_bar=bar&bar=foo_bar")
result = URI::decode_www_form_18("foo_bar=bar&bar=foo_bar")
result.should eq([['foo_bar', 'bar'], ['bar', 'foo_bar']])
end
it 'handles [ ] in query string' do
result = URI::parse_query_string("foo[]=foo&foo[]=bar")
result = URI::decode_www_form_18("foo[]=foo&foo[]=bar")
result.should eq([['foo[]', 'foo'], ['foo[]', 'bar']])
end
it 'returns an empty array, if query string is empty' do
result = URI::parse_query_string("")
result = URI::decode_www_form_18("")
result.should eq([])
end
it 'throws an error, if more than one = without an & or ; in between' do
expect {
result = URI::parse_query_string("foo=bar=foo&bar=foo=bar")
result = URI::decode_www_form_18("foo=bar=foo&bar=foo=bar")
}.to raise_error(
ArgumentError,
"invalid data of application/x-www-form-urlencoded "+
@ -126,7 +128,7 @@ describe URI, '#parse_query_string' do
it 'throws an error, if more than one & without an = in between' do
expect {
result = URI::parse_query_string("foo&bar=foo&bar")
result = URI::decode_www_form_18("foo&bar=foo&bar")
}.to raise_error(
ArgumentError,
"invalid data of application/x-www-form-urlencoded (foo&bar=foo&bar)"
@ -135,7 +137,7 @@ describe URI, '#parse_query_string' do
it 'throws an error, if more than one ; without an = in between' do
expect {
result = URI::parse_query_string("foo;bar=foo;bar")
result = URI::decode_www_form_18("foo;bar=foo;bar")
}.to raise_error(
ArgumentError,
"invalid data of application/x-www-form-urlencoded (foo;bar=foo;bar)"