aboutsummaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorStormwind <stormwind@stormwinds-page.de>2012-12-22 11:44:26 +0100
committerStormwind <stormwind@stormwinds-page.de>2012-12-22 11:44:26 +0100
commit443958f8859a47751f7e57deff6b3eda0c13e5ad (patch)
treebd23c285edd841952cc80461e54e37dd242ed75a /spec
parentb20c0c527c89ec08548849163388d43207609fcd (diff)
Add patch for URI decode_www_form
Plus some specs. This should it make later possible to make Zero work with Ruby 1.8. But at the moment it only routes to the original decode_www_form method, if it exists. Otherwise it returns an empty Array. So this will still fail on the 1.8 versions at the moment.
Diffstat (limited to 'spec')
-rw-r--r--spec/unit/uri/parse_query_string_spec.rb111
1 files changed, 111 insertions, 0 deletions
diff --git a/spec/unit/uri/parse_query_string_spec.rb b/spec/unit/uri/parse_query_string_spec.rb
new file mode 100644
index 0000000..a2c078b
--- /dev/null
+++ b/spec/unit/uri/parse_query_string_spec.rb
@@ -0,0 +1,111 @@
+# encoding: UTF-8
+
+require 'spec_helper'
+
+describe URI, '#parse_query_string' do
+
+ it 'seperates parameter into an array' do
+ result = URI::parse_query_string("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.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.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.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.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")
+
+ # does not work, probably should?
+ #result.should eq([['foo', '']])
+ }.to raise_error(
+ ArgumentError,
+ "invalid data of application/x-www-form-urlencoded (foo)"
+ )
+ end
+
+ it 'accepts empty values' do
+ result = URI::parse_query_string("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.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")
+
+ # 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öö")
+
+ # 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.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.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.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.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.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.should eq([['foo[]', 'foo'], ['foo[]', 'bar']])
+ end
+
+end