diff options
| author | Stormwind <stormwind@stormwinds-page.de> | 2012-12-23 12:23:14 +0100 | 
|---|---|---|
| committer | Stormwind <stormwind@stormwinds-page.de> | 2012-12-23 12:23:14 +0100 | 
| commit | 65b1d3a1dab95be5ac82d9e0c6a75b743bc89ce0 (patch) | |
| tree | e41fd0ab8deedbf77187f92448f453a1e8425ebc /spec | |
| parent | ca2273e700e65b3d035f47042314ebcbfc9fd220 (diff) | |
Remove 1.8 fixes
The fixes for Ruby 1.8 will take place in a seperate gem. So I remove
all the changes here.
Diffstat (limited to 'spec')
| -rw-r--r-- | spec/unit/uri/decode_www_form_18_spec.rb | 147 | 
1 files changed, 0 insertions, 147 deletions
| diff --git a/spec/unit/uri/decode_www_form_18_spec.rb b/spec/unit/uri/decode_www_form_18_spec.rb deleted file mode 100644 index 21e1b7c..0000000 --- a/spec/unit/uri/decode_www_form_18_spec.rb +++ /dev/null @@ -1,147 +0,0 @@ -# encoding: UTF-8 - -require 'spec_helper' - -describe URI, '#decode_www_form_18' do - -  it 'seperates parameter into an array' do -    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::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::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::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::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::decode_www_form_18("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::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::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::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::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::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::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::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::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::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::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::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::decode_www_form_18("foo=bar=foo&bar=foo=bar") -    }.to raise_error( -      ArgumentError, -      "invalid data of application/x-www-form-urlencoded "+ -       "(foo=bar=foo&bar=foo=bar)" -    ) -  end - -  it 'throws an error, if more than one & without an = in between' do -    expect { -      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)" -    ) -  end - -  it 'throws an error, if more than one ; without an = in between' do -    expect { -      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)" -    ) -  end - -end | 
