summaryrefslogtreecommitdiff
path: root/spec/unit/uri/parse_query_string_spec.rb
blob: a2c078b230df41b2b4a4adb1118995e98ba27a9b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
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