addressable 2.5.0 → 2.8.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/CHANGELOG.md +40 -0
- data/Gemfile +13 -17
- data/README.md +14 -15
- data/Rakefile +5 -3
- data/addressable.gemspec +37 -0
- data/lib/addressable.rb +2 -0
- data/lib/addressable/idna.rb +2 -0
- data/lib/addressable/idna/native.rb +4 -2
- data/lib/addressable/idna/pure.rb +54 -53
- data/lib/addressable/template.rb +63 -83
- data/lib/addressable/uri.rb +128 -64
- data/lib/addressable/version.rb +3 -1
- data/spec/addressable/idna_spec.rb +23 -7
- data/spec/addressable/net_http_compat_spec.rb +2 -0
- data/spec/addressable/security_spec.rb +2 -0
- data/spec/addressable/template_spec.rb +75 -2
- data/spec/addressable/uri_spec.rb +408 -215
- data/spec/spec_helper.rb +12 -0
- data/tasks/clobber.rake +2 -0
- data/tasks/gem.rake +8 -7
- data/tasks/git.rake +2 -0
- data/tasks/metrics.rake +2 -0
- data/tasks/profile.rake +72 -0
- data/tasks/rspec.rake +3 -1
- data/tasks/yard.rake +2 -0
- metadata +22 -16
- data/spec/addressable/rack_mount_compat_spec.rb +0 -104
data/lib/addressable/version.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# encoding:utf-8
|
2
4
|
#--
|
3
5
|
# Copyright (C) Bob Aman
|
@@ -21,7 +23,7 @@ if !defined?(Addressable::VERSION)
|
|
21
23
|
module Addressable
|
22
24
|
module VERSION
|
23
25
|
MAJOR = 2
|
24
|
-
MINOR =
|
26
|
+
MINOR = 8
|
25
27
|
TINY = 0
|
26
28
|
|
27
29
|
STRING = [MAJOR, MINOR, TINY].join('.')
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# coding: utf-8
|
2
4
|
# Copyright (C) Bob Aman
|
3
5
|
#
|
@@ -26,9 +28,9 @@ shared_examples_for "converting from unicode to ASCII" do
|
|
26
28
|
expect(Addressable::IDNA.to_ascii("www.google.com")).to eq("www.google.com")
|
27
29
|
end
|
28
30
|
|
29
|
-
|
30
|
-
it "should convert '#{
|
31
|
-
expect(Addressable::IDNA.to_ascii(
|
31
|
+
long = 'AcinusFallumTrompetumNullunCreditumVisumEstAtCuadLongumEtCefallum.com'
|
32
|
+
it "should convert '#{long}' correctly" do
|
33
|
+
expect(Addressable::IDNA.to_ascii(long)).to eq(long)
|
32
34
|
end
|
33
35
|
|
34
36
|
it "should convert 'www.詹姆斯.com' correctly" do
|
@@ -134,6 +136,12 @@ shared_examples_for "converting from unicode to ASCII" do
|
|
134
136
|
)).to eq("xn--4ud")
|
135
137
|
end
|
136
138
|
|
139
|
+
it "should convert '🌹🌹🌹.ws' correctly" do
|
140
|
+
expect(Addressable::IDNA.to_ascii(
|
141
|
+
"\360\237\214\271\360\237\214\271\360\237\214\271.ws"
|
142
|
+
)).to eq("xn--2h8haa.ws")
|
143
|
+
end
|
144
|
+
|
137
145
|
it "should handle two adjacent '.'s correctly" do
|
138
146
|
expect(Addressable::IDNA.to_ascii(
|
139
147
|
"example..host"
|
@@ -142,9 +150,9 @@ shared_examples_for "converting from unicode to ASCII" do
|
|
142
150
|
end
|
143
151
|
|
144
152
|
shared_examples_for "converting from ASCII to unicode" do
|
145
|
-
|
146
|
-
it "should convert '#{
|
147
|
-
expect(Addressable::IDNA.to_unicode(
|
153
|
+
long = 'AcinusFallumTrompetumNullunCreditumVisumEstAtCuadLongumEtCefallum.com'
|
154
|
+
it "should convert '#{long}' correctly" do
|
155
|
+
expect(Addressable::IDNA.to_unicode(long)).to eq(long)
|
148
156
|
end
|
149
157
|
|
150
158
|
it "should return the identity conversion when punycode decode fails" do
|
@@ -231,6 +239,12 @@ shared_examples_for "converting from ASCII to unicode" do
|
|
231
239
|
)).to eq("\341\206\265")
|
232
240
|
end
|
233
241
|
|
242
|
+
it "should convert '🌹🌹🌹.ws' correctly" do
|
243
|
+
expect(Addressable::IDNA.to_unicode(
|
244
|
+
"xn--2h8haa.ws"
|
245
|
+
)).to eq("\360\237\214\271\360\237\214\271\360\237\214\271.ws")
|
246
|
+
end
|
247
|
+
|
234
248
|
it "should handle two adjacent '.'s correctly" do
|
235
249
|
expect(Addressable::IDNA.to_unicode(
|
236
250
|
"example..host"
|
@@ -280,7 +294,9 @@ begin
|
|
280
294
|
it_should_behave_like "converting from unicode to ASCII"
|
281
295
|
it_should_behave_like "converting from ASCII to unicode"
|
282
296
|
end
|
283
|
-
rescue LoadError
|
297
|
+
rescue LoadError => error
|
298
|
+
raise error if ENV["CI"] && TestHelper.native_supported?
|
299
|
+
|
284
300
|
# Cannot test the native implementation without libidn support.
|
285
301
|
warn('Could not load native IDN implementation.')
|
286
302
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# coding: utf-8
|
2
4
|
# Copyright (C) Bob Aman
|
3
5
|
#
|
@@ -17,6 +19,7 @@
|
|
17
19
|
require "spec_helper"
|
18
20
|
|
19
21
|
require "bigdecimal"
|
22
|
+
require "timeout"
|
20
23
|
require "addressable/template"
|
21
24
|
|
22
25
|
shared_examples_for 'expands' do |tests|
|
@@ -82,7 +85,7 @@ describe "Type conversion" do
|
|
82
85
|
:hello => 1234,
|
83
86
|
:nothing => nil,
|
84
87
|
:sym => :symbolic,
|
85
|
-
:decimal => BigDecimal
|
88
|
+
:decimal => BigDecimal('1')
|
86
89
|
}
|
87
90
|
}
|
88
91
|
|
@@ -91,7 +94,7 @@ describe "Type conversion" do
|
|
91
94
|
'{hello}' => '1234',
|
92
95
|
'{nothing}' => '',
|
93
96
|
'{sym}' => 'symbolic',
|
94
|
-
'{decimal}' => '0.1E1'
|
97
|
+
'{decimal}' => RUBY_VERSION < '2.4.0' ? '0.1E1' : '0.1e1'
|
95
98
|
}
|
96
99
|
end
|
97
100
|
|
@@ -949,6 +952,36 @@ describe Addressable::Template do
|
|
949
952
|
)
|
950
953
|
end
|
951
954
|
end
|
955
|
+
context "issue #307 - partial_expand form query with nil params" do
|
956
|
+
subject do
|
957
|
+
Addressable::Template.new("http://example.com/{?one,two,three}/")
|
958
|
+
end
|
959
|
+
it "builds a new pattern with two=nil" do
|
960
|
+
expect(subject.partial_expand(two: nil).pattern).to eq(
|
961
|
+
"http://example.com/{?one}{&three}/"
|
962
|
+
)
|
963
|
+
end
|
964
|
+
it "builds a new pattern with one=nil and two=nil" do
|
965
|
+
expect(subject.partial_expand(one: nil, two: nil).pattern).to eq(
|
966
|
+
"http://example.com/{?three}/"
|
967
|
+
)
|
968
|
+
end
|
969
|
+
it "builds a new pattern with one=1 and two=nil" do
|
970
|
+
expect(subject.partial_expand(one: 1, two: nil).pattern).to eq(
|
971
|
+
"http://example.com/?one=1{&three}/"
|
972
|
+
)
|
973
|
+
end
|
974
|
+
it "builds a new pattern with one=nil and two=2" do
|
975
|
+
expect(subject.partial_expand(one: nil, two: 2).pattern).to eq(
|
976
|
+
"http://example.com/?two=2{&three}/"
|
977
|
+
)
|
978
|
+
end
|
979
|
+
it "builds a new pattern with one=nil" do
|
980
|
+
expect(subject.partial_expand(one: nil).pattern).to eq(
|
981
|
+
"http://example.com/{?two}{&three}/"
|
982
|
+
)
|
983
|
+
end
|
984
|
+
end
|
952
985
|
context "partial_expand with query string" do
|
953
986
|
subject {
|
954
987
|
Addressable::Template.new("http://example.com/{?two,one}/")
|
@@ -969,6 +1002,24 @@ describe Addressable::Template do
|
|
969
1002
|
)
|
970
1003
|
end
|
971
1004
|
end
|
1005
|
+
context "partial expand with unicode values" do
|
1006
|
+
subject do
|
1007
|
+
Addressable::Template.new("http://example.com/{resource}/{query}/")
|
1008
|
+
end
|
1009
|
+
it "normalizes unicode by default" do
|
1010
|
+
template = subject.partial_expand("query" => "Cafe\u0301")
|
1011
|
+
expect(template.pattern).to eq(
|
1012
|
+
"http://example.com/{resource}/Caf%C3%A9/"
|
1013
|
+
)
|
1014
|
+
end
|
1015
|
+
|
1016
|
+
it "does not normalize unicode when byte semantics requested" do
|
1017
|
+
template = subject.partial_expand({"query" => "Cafe\u0301"}, nil, false)
|
1018
|
+
expect(template.pattern).to eq(
|
1019
|
+
"http://example.com/{resource}/Cafe%CC%81/"
|
1020
|
+
)
|
1021
|
+
end
|
1022
|
+
end
|
972
1023
|
end
|
973
1024
|
describe "Partial expand with strings" do
|
974
1025
|
context "partial_expand with two simple values" do
|
@@ -1013,6 +1064,20 @@ describe Addressable::Template do
|
|
1013
1064
|
end
|
1014
1065
|
end
|
1015
1066
|
describe "Expand" do
|
1067
|
+
context "expand with unicode values" do
|
1068
|
+
subject do
|
1069
|
+
Addressable::Template.new("http://example.com/search/{query}/")
|
1070
|
+
end
|
1071
|
+
it "normalizes unicode by default" do
|
1072
|
+
uri = subject.expand("query" => "Cafe\u0301").to_str
|
1073
|
+
expect(uri).to eq("http://example.com/search/Caf%C3%A9/")
|
1074
|
+
end
|
1075
|
+
|
1076
|
+
it "does not normalize unicode when byte semantics requested" do
|
1077
|
+
uri = subject.expand({ "query" => "Cafe\u0301" }, nil, false).to_str
|
1078
|
+
expect(uri).to eq("http://example.com/search/Cafe%CC%81/")
|
1079
|
+
end
|
1080
|
+
end
|
1016
1081
|
context "expand with a processor" do
|
1017
1082
|
subject {
|
1018
1083
|
Addressable::Template.new("http://example.com/search/{query}/")
|
@@ -1276,6 +1341,14 @@ describe Addressable::Template do
|
|
1276
1341
|
expect(subject).not_to match("foo_bar*")
|
1277
1342
|
expect(subject).not_to match("foo_bar:20")
|
1278
1343
|
end
|
1344
|
+
|
1345
|
+
it 'should parse in a reasonable time' do
|
1346
|
+
expect do
|
1347
|
+
Timeout.timeout(0.1) do
|
1348
|
+
expect(subject).not_to match("0"*25 + "!")
|
1349
|
+
end
|
1350
|
+
end.not_to raise_error
|
1351
|
+
end
|
1279
1352
|
end
|
1280
1353
|
context "VARIABLE_LIST" do
|
1281
1354
|
subject { Addressable::Template::VARIABLE_LIST }
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# coding: utf-8
|
2
4
|
# Copyright (C) Bob Aman
|
3
5
|
#
|
@@ -63,124 +65,116 @@ end
|
|
63
65
|
|
64
66
|
describe Addressable::URI, "when created with a non-numeric port number" do
|
65
67
|
it "should raise an error" do
|
66
|
-
expect
|
68
|
+
expect do
|
67
69
|
Addressable::URI.new(:port => "bogus")
|
68
|
-
end
|
70
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
69
71
|
end
|
70
72
|
end
|
71
73
|
|
72
74
|
describe Addressable::URI, "when created with a invalid encoded port number" do
|
73
75
|
it "should raise an error" do
|
74
|
-
expect
|
76
|
+
expect do
|
75
77
|
Addressable::URI.new(:port => "%eb")
|
76
|
-
end
|
78
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
77
79
|
end
|
78
80
|
end
|
79
81
|
|
80
82
|
describe Addressable::URI, "when created with a non-string scheme" do
|
81
83
|
it "should raise an error" do
|
82
|
-
expect
|
84
|
+
expect do
|
83
85
|
Addressable::URI.new(:scheme => :bogus)
|
84
|
-
end
|
86
|
+
end.to raise_error(TypeError)
|
85
87
|
end
|
86
88
|
end
|
87
89
|
|
88
90
|
describe Addressable::URI, "when created with a non-string user" do
|
89
91
|
it "should raise an error" do
|
90
|
-
expect
|
92
|
+
expect do
|
91
93
|
Addressable::URI.new(:user => :bogus)
|
92
|
-
end
|
94
|
+
end.to raise_error(TypeError)
|
93
95
|
end
|
94
96
|
end
|
95
97
|
|
96
98
|
describe Addressable::URI, "when created with a non-string password" do
|
97
99
|
it "should raise an error" do
|
98
|
-
expect
|
100
|
+
expect do
|
99
101
|
Addressable::URI.new(:password => :bogus)
|
100
|
-
end
|
102
|
+
end.to raise_error(TypeError)
|
101
103
|
end
|
102
104
|
end
|
103
105
|
|
104
106
|
describe Addressable::URI, "when created with a non-string userinfo" do
|
105
107
|
it "should raise an error" do
|
106
|
-
expect
|
108
|
+
expect do
|
107
109
|
Addressable::URI.new(:userinfo => :bogus)
|
108
|
-
end
|
110
|
+
end.to raise_error(TypeError)
|
109
111
|
end
|
110
112
|
end
|
111
113
|
|
112
114
|
describe Addressable::URI, "when created with a non-string host" do
|
113
115
|
it "should raise an error" do
|
114
|
-
expect
|
116
|
+
expect do
|
115
117
|
Addressable::URI.new(:host => :bogus)
|
116
|
-
end
|
117
|
-
end
|
118
|
-
end
|
119
|
-
|
120
|
-
describe Addressable::URI, "when created with a non-string authority" do
|
121
|
-
it "should raise an error" do
|
122
|
-
expect(lambda do
|
123
|
-
Addressable::URI.new(:authority => :bogus)
|
124
|
-
end).to raise_error(TypeError)
|
118
|
+
end.to raise_error(TypeError)
|
125
119
|
end
|
126
120
|
end
|
127
121
|
|
128
122
|
describe Addressable::URI, "when created with a non-string authority" do
|
129
123
|
it "should raise an error" do
|
130
|
-
expect
|
124
|
+
expect do
|
131
125
|
Addressable::URI.new(:authority => :bogus)
|
132
|
-
end
|
126
|
+
end.to raise_error(TypeError)
|
133
127
|
end
|
134
128
|
end
|
135
129
|
|
136
130
|
describe Addressable::URI, "when created with a non-string path" do
|
137
131
|
it "should raise an error" do
|
138
|
-
expect
|
132
|
+
expect do
|
139
133
|
Addressable::URI.new(:path => :bogus)
|
140
|
-
end
|
134
|
+
end.to raise_error(TypeError)
|
141
135
|
end
|
142
136
|
end
|
143
137
|
|
144
138
|
describe Addressable::URI, "when created with a non-string query" do
|
145
139
|
it "should raise an error" do
|
146
|
-
expect
|
140
|
+
expect do
|
147
141
|
Addressable::URI.new(:query => :bogus)
|
148
|
-
end
|
142
|
+
end.to raise_error(TypeError)
|
149
143
|
end
|
150
144
|
end
|
151
145
|
|
152
146
|
describe Addressable::URI, "when created with a non-string fragment" do
|
153
147
|
it "should raise an error" do
|
154
|
-
expect
|
148
|
+
expect do
|
155
149
|
Addressable::URI.new(:fragment => :bogus)
|
156
|
-
end
|
150
|
+
end.to raise_error(TypeError)
|
157
151
|
end
|
158
152
|
end
|
159
153
|
|
160
154
|
describe Addressable::URI, "when created with a scheme but no hierarchical " +
|
161
155
|
"segment" do
|
162
156
|
it "should raise an error" do
|
163
|
-
expect
|
157
|
+
expect do
|
164
158
|
Addressable::URI.parse("http:")
|
165
|
-
end
|
159
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
166
160
|
end
|
167
161
|
end
|
168
162
|
|
169
163
|
describe Addressable::URI, "quote handling" do
|
170
164
|
describe 'in host name' do
|
171
165
|
it "should raise an error for single quote" do
|
172
|
-
expect
|
166
|
+
expect do
|
173
167
|
Addressable::URI.parse("http://local\"host/")
|
174
|
-
end
|
168
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
175
169
|
end
|
176
170
|
end
|
177
171
|
end
|
178
172
|
|
179
173
|
describe Addressable::URI, "newline normalization" do
|
180
174
|
it "should not accept newlines in scheme" do
|
181
|
-
expect
|
175
|
+
expect do
|
182
176
|
Addressable::URI.parse("ht%0atp://localhost/")
|
183
|
-
end
|
177
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
184
178
|
end
|
185
179
|
|
186
180
|
it "should not unescape newline in path" do
|
@@ -205,47 +199,47 @@ describe Addressable::URI, "newline normalization" do
|
|
205
199
|
|
206
200
|
it "should not accept newline in hostname" do
|
207
201
|
uri = Addressable::URI.parse("http://localhost/")
|
208
|
-
expect
|
202
|
+
expect do
|
209
203
|
uri.host = "local\nhost"
|
210
|
-
end
|
204
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
211
205
|
end
|
212
206
|
end
|
213
207
|
|
214
208
|
describe Addressable::URI, "when created with ambiguous path" do
|
215
209
|
it "should raise an error" do
|
216
|
-
expect
|
210
|
+
expect do
|
217
211
|
Addressable::URI.parse("::http")
|
218
|
-
end
|
212
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
219
213
|
end
|
220
214
|
end
|
221
215
|
|
222
216
|
describe Addressable::URI, "when created with an invalid host" do
|
223
217
|
it "should raise an error" do
|
224
|
-
expect
|
218
|
+
expect do
|
225
219
|
Addressable::URI.new(:host => "<invalid>")
|
226
|
-
end
|
220
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
227
221
|
end
|
228
222
|
end
|
229
223
|
|
230
224
|
describe Addressable::URI, "when created with a host consisting of " +
|
231
225
|
"sub-delims characters" do
|
232
226
|
it "should not raise an error" do
|
233
|
-
expect
|
227
|
+
expect do
|
234
228
|
Addressable::URI.new(
|
235
229
|
:host => Addressable::URI::CharacterClasses::SUB_DELIMS.gsub(/\\/, '')
|
236
230
|
)
|
237
|
-
end
|
231
|
+
end.not_to raise_error
|
238
232
|
end
|
239
233
|
end
|
240
234
|
|
241
235
|
describe Addressable::URI, "when created with a host consisting of " +
|
242
236
|
"unreserved characters" do
|
243
237
|
it "should not raise an error" do
|
244
|
-
expect
|
238
|
+
expect do
|
245
239
|
Addressable::URI.new(
|
246
240
|
:host => Addressable::URI::CharacterClasses::UNRESERVED.gsub(/\\/, '')
|
247
241
|
)
|
248
|
-
end
|
242
|
+
end.not_to raise_error
|
249
243
|
end
|
250
244
|
end
|
251
245
|
|
@@ -275,83 +269,83 @@ describe Addressable::URI, "when created from nil components" do
|
|
275
269
|
end
|
276
270
|
|
277
271
|
it "should raise an error if the scheme is set to whitespace" do
|
278
|
-
expect
|
272
|
+
expect do
|
279
273
|
@uri.scheme = "\t \n"
|
280
|
-
end
|
274
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'\t \n'/)
|
281
275
|
end
|
282
276
|
|
283
277
|
it "should raise an error if the scheme is set to all digits" do
|
284
|
-
expect
|
278
|
+
expect do
|
285
279
|
@uri.scheme = "123"
|
286
|
-
end
|
280
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'123'/)
|
287
281
|
end
|
288
282
|
|
289
283
|
it "should raise an error if the scheme begins with a digit" do
|
290
|
-
expect
|
284
|
+
expect do
|
291
285
|
@uri.scheme = "1scheme"
|
292
|
-
end
|
286
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'1scheme'/)
|
293
287
|
end
|
294
288
|
|
295
289
|
it "should raise an error if the scheme begins with a plus" do
|
296
|
-
expect
|
290
|
+
expect do
|
297
291
|
@uri.scheme = "+scheme"
|
298
|
-
end
|
292
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'\+scheme'/)
|
299
293
|
end
|
300
294
|
|
301
295
|
it "should raise an error if the scheme begins with a dot" do
|
302
|
-
expect
|
296
|
+
expect do
|
303
297
|
@uri.scheme = ".scheme"
|
304
|
-
end
|
298
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'\.scheme'/)
|
305
299
|
end
|
306
300
|
|
307
301
|
it "should raise an error if the scheme begins with a dash" do
|
308
|
-
expect
|
302
|
+
expect do
|
309
303
|
@uri.scheme = "-scheme"
|
310
|
-
end
|
304
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'-scheme'/)
|
311
305
|
end
|
312
306
|
|
313
307
|
it "should raise an error if the scheme contains an illegal character" do
|
314
|
-
expect
|
308
|
+
expect do
|
315
309
|
@uri.scheme = "scheme!"
|
316
|
-
end
|
310
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'scheme!'/)
|
317
311
|
end
|
318
312
|
|
319
313
|
it "should raise an error if the scheme contains whitespace" do
|
320
|
-
expect
|
314
|
+
expect do
|
321
315
|
@uri.scheme = "sch eme"
|
322
|
-
end
|
316
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /'sch eme'/)
|
323
317
|
end
|
324
318
|
|
325
319
|
it "should raise an error if the scheme contains a newline" do
|
326
|
-
expect
|
320
|
+
expect do
|
327
321
|
@uri.scheme = "sch\neme"
|
328
|
-
end
|
322
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
329
323
|
end
|
330
324
|
|
331
325
|
it "should raise an error if set into an invalid state" do
|
332
|
-
expect
|
326
|
+
expect do
|
333
327
|
@uri.user = "user"
|
334
|
-
end
|
328
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
335
329
|
end
|
336
330
|
|
337
331
|
it "should raise an error if set into an invalid state" do
|
338
|
-
expect
|
332
|
+
expect do
|
339
333
|
@uri.password = "pass"
|
340
|
-
end
|
334
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
341
335
|
end
|
342
336
|
|
343
337
|
it "should raise an error if set into an invalid state" do
|
344
|
-
expect
|
338
|
+
expect do
|
345
339
|
@uri.scheme = "http"
|
346
340
|
@uri.fragment = "fragment"
|
347
|
-
end
|
341
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
348
342
|
end
|
349
343
|
|
350
344
|
it "should raise an error if set into an invalid state" do
|
351
|
-
expect
|
345
|
+
expect do
|
352
346
|
@uri.fragment = "fragment"
|
353
347
|
@uri.scheme = "http"
|
354
|
-
end
|
348
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
355
349
|
end
|
356
350
|
end
|
357
351
|
|
@@ -963,6 +957,10 @@ describe Addressable::URI, "when frozen" do
|
|
963
957
|
expect(@uri.normalize.query).to eq("a=1")
|
964
958
|
end
|
965
959
|
|
960
|
+
it "returns '/%70a%74%68?a=%31' for #request_uri" do
|
961
|
+
expect(@uri.request_uri).to eq("/%70a%74%68?a=%31")
|
962
|
+
end
|
963
|
+
|
966
964
|
it "returns '1%323' for #fragment" do
|
967
965
|
expect(@uri.fragment).to eq("1%323")
|
968
966
|
end
|
@@ -1017,31 +1015,31 @@ describe Addressable::URI, "when created from string components" do
|
|
1017
1015
|
end
|
1018
1016
|
|
1019
1017
|
it "should raise an error if invalid components omitted" do
|
1020
|
-
expect
|
1018
|
+
expect do
|
1021
1019
|
@uri.omit(:bogus)
|
1022
|
-
end
|
1023
|
-
expect
|
1020
|
+
end.to raise_error(ArgumentError)
|
1021
|
+
expect do
|
1024
1022
|
@uri.omit(:scheme, :bogus, :path)
|
1025
|
-
end
|
1023
|
+
end.to raise_error(ArgumentError)
|
1026
1024
|
end
|
1027
1025
|
end
|
1028
1026
|
|
1029
1027
|
describe Addressable::URI, "when created with a nil host but " +
|
1030
1028
|
"non-nil authority components" do
|
1031
1029
|
it "should raise an error" do
|
1032
|
-
expect
|
1030
|
+
expect do
|
1033
1031
|
Addressable::URI.new(:user => "user", :password => "pass", :port => 80)
|
1034
|
-
end
|
1032
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1035
1033
|
end
|
1036
1034
|
end
|
1037
1035
|
|
1038
1036
|
describe Addressable::URI, "when created with both an authority and a user" do
|
1039
1037
|
it "should raise an error" do
|
1040
|
-
expect
|
1038
|
+
expect do
|
1041
1039
|
Addressable::URI.new(
|
1042
1040
|
:user => "user", :authority => "user@example.com:80"
|
1043
1041
|
)
|
1044
|
-
end
|
1042
|
+
end.to raise_error(ArgumentError)
|
1045
1043
|
end
|
1046
1044
|
end
|
1047
1045
|
|
@@ -1079,33 +1077,33 @@ end
|
|
1079
1077
|
|
1080
1078
|
describe Addressable::URI, "when created with a host with a backslash" do
|
1081
1079
|
it "should raise an error" do
|
1082
|
-
expect
|
1080
|
+
expect do
|
1083
1081
|
Addressable::URI.new(:authority => "example\\example")
|
1084
|
-
end
|
1082
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1085
1083
|
end
|
1086
1084
|
end
|
1087
1085
|
|
1088
1086
|
describe Addressable::URI, "when created with a host with a slash" do
|
1089
1087
|
it "should raise an error" do
|
1090
|
-
expect
|
1088
|
+
expect do
|
1091
1089
|
Addressable::URI.new(:authority => "example/example")
|
1092
|
-
end
|
1090
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1093
1091
|
end
|
1094
1092
|
end
|
1095
1093
|
|
1096
1094
|
describe Addressable::URI, "when created with a host with a space" do
|
1097
1095
|
it "should raise an error" do
|
1098
|
-
expect
|
1096
|
+
expect do
|
1099
1097
|
Addressable::URI.new(:authority => "example example")
|
1100
|
-
end
|
1098
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1101
1099
|
end
|
1102
1100
|
end
|
1103
1101
|
|
1104
1102
|
describe Addressable::URI, "when created with both a userinfo and a user" do
|
1105
1103
|
it "should raise an error" do
|
1106
|
-
expect
|
1104
|
+
expect do
|
1107
1105
|
Addressable::URI.new(:user => "user", :userinfo => "user:pass")
|
1108
|
-
end
|
1106
|
+
end.to raise_error(ArgumentError)
|
1109
1107
|
end
|
1110
1108
|
end
|
1111
1109
|
|
@@ -1197,18 +1195,18 @@ describe Addressable::URI, "when parsed from something that looks " +
|
|
1197
1195
|
"like a URI object" do
|
1198
1196
|
it "should parse without error" do
|
1199
1197
|
uri = Addressable::URI.parse(Fake::URI::HTTP.new("http://example.com/"))
|
1200
|
-
expect
|
1198
|
+
expect do
|
1201
1199
|
Addressable::URI.parse(uri)
|
1202
|
-
end
|
1200
|
+
end.not_to raise_error
|
1203
1201
|
end
|
1204
1202
|
end
|
1205
1203
|
|
1206
1204
|
describe Addressable::URI, "when parsed from a standard library URI object" do
|
1207
1205
|
it "should parse without error" do
|
1208
1206
|
uri = Addressable::URI.parse(URI.parse("http://example.com/"))
|
1209
|
-
expect
|
1207
|
+
expect do
|
1210
1208
|
Addressable::URI.parse(uri)
|
1211
|
-
end
|
1209
|
+
end.not_to raise_error
|
1212
1210
|
end
|
1213
1211
|
end
|
1214
1212
|
|
@@ -1368,9 +1366,9 @@ describe Addressable::URI, "when parsed from " +
|
|
1368
1366
|
end
|
1369
1367
|
|
1370
1368
|
it "should not allow request URI assignment" do
|
1371
|
-
expect
|
1369
|
+
expect do
|
1372
1370
|
@uri.request_uri = "/"
|
1373
|
-
end
|
1371
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1374
1372
|
end
|
1375
1373
|
|
1376
1374
|
it "should have a query of 'objectClass?one'" do
|
@@ -1392,9 +1390,9 @@ describe Addressable::URI, "when parsed from " +
|
|
1392
1390
|
end
|
1393
1391
|
|
1394
1392
|
it "should raise an error if omission would create an invalid URI" do
|
1395
|
-
expect
|
1393
|
+
expect do
|
1396
1394
|
@uri.omit(:authority, :path)
|
1397
|
-
end
|
1395
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1398
1396
|
end
|
1399
1397
|
|
1400
1398
|
it "should have an origin of 'ldap://[2001:db8::7]'" do
|
@@ -1780,9 +1778,9 @@ describe Addressable::URI, "when parsed from " +
|
|
1780
1778
|
|
1781
1779
|
it "should not be roughly equal to the string " +
|
1782
1780
|
"'http://example.com:bogus/'" do
|
1783
|
-
expect
|
1781
|
+
expect do
|
1784
1782
|
expect(@uri === "http://example.com:bogus/").to eq(false)
|
1785
|
-
end
|
1783
|
+
end.not_to raise_error
|
1786
1784
|
end
|
1787
1785
|
|
1788
1786
|
it "should result in itself when joined with itself" do
|
@@ -1812,21 +1810,21 @@ describe Addressable::URI, "when parsed from " +
|
|
1812
1810
|
end
|
1813
1811
|
|
1814
1812
|
it "should not allow origin assignment without scheme" do
|
1815
|
-
expect
|
1813
|
+
expect do
|
1816
1814
|
@uri.origin = "example.com"
|
1817
|
-
end
|
1815
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1818
1816
|
end
|
1819
1817
|
|
1820
1818
|
it "should not allow origin assignment without host" do
|
1821
|
-
expect
|
1819
|
+
expect do
|
1822
1820
|
@uri.origin = "http://"
|
1823
|
-
end
|
1821
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
1824
1822
|
end
|
1825
1823
|
|
1826
1824
|
it "should not allow origin assignment with bogus type" do
|
1827
|
-
expect
|
1825
|
+
expect do
|
1828
1826
|
@uri.origin = :bogus
|
1829
|
-
end
|
1827
|
+
end.to raise_error(TypeError)
|
1830
1828
|
end
|
1831
1829
|
|
1832
1830
|
# Section 6.2.3 of RFC 3986
|
@@ -1882,9 +1880,9 @@ describe Addressable::URI, "when parsed from " +
|
|
1882
1880
|
end
|
1883
1881
|
|
1884
1882
|
it "when joined with a bogus object a TypeError should be raised" do
|
1885
|
-
expect
|
1883
|
+
expect do
|
1886
1884
|
@uri.join(42)
|
1887
|
-
end
|
1885
|
+
end.to raise_error(TypeError)
|
1888
1886
|
end
|
1889
1887
|
|
1890
1888
|
it "should have the correct username after assignment" do
|
@@ -1979,15 +1977,29 @@ end
|
|
1979
1977
|
|
1980
1978
|
# Section 5.1.2 of RFC 2616
|
1981
1979
|
describe Addressable::URI, "when parsed from " +
|
1982
|
-
"'
|
1980
|
+
"'HTTP://www.w3.org/pub/WWW/TheProject.html'" do
|
1983
1981
|
before do
|
1984
|
-
@uri = Addressable::URI.parse("
|
1982
|
+
@uri = Addressable::URI.parse("HTTP://www.w3.org/pub/WWW/TheProject.html")
|
1985
1983
|
end
|
1986
1984
|
|
1987
1985
|
it "should have the correct request URI" do
|
1988
1986
|
expect(@uri.request_uri).to eq("/pub/WWW/TheProject.html")
|
1989
1987
|
end
|
1990
1988
|
|
1989
|
+
it "should have the correct request URI after assignment" do
|
1990
|
+
@uri.request_uri = "/pub/WWW/TheProject.html?"
|
1991
|
+
expect(@uri.request_uri).to eq("/pub/WWW/TheProject.html?")
|
1992
|
+
expect(@uri.path).to eq("/pub/WWW/TheProject.html")
|
1993
|
+
expect(@uri.query).to eq("")
|
1994
|
+
end
|
1995
|
+
|
1996
|
+
it "should have the correct request URI after assignment" do
|
1997
|
+
@uri.request_uri = "/some/where/else.html"
|
1998
|
+
expect(@uri.request_uri).to eq("/some/where/else.html")
|
1999
|
+
expect(@uri.path).to eq("/some/where/else.html")
|
2000
|
+
expect(@uri.query).to eq(nil)
|
2001
|
+
end
|
2002
|
+
|
1991
2003
|
it "should have the correct request URI after assignment" do
|
1992
2004
|
@uri.request_uri = "/some/where/else.html?query?string"
|
1993
2005
|
expect(@uri.request_uri).to eq("/some/where/else.html?query?string")
|
@@ -2003,20 +2015,20 @@ describe Addressable::URI, "when parsed from " +
|
|
2003
2015
|
end
|
2004
2016
|
|
2005
2017
|
it "should raise an error if the site value is set to something bogus" do
|
2006
|
-
expect
|
2018
|
+
expect do
|
2007
2019
|
@uri.site = 42
|
2008
|
-
end
|
2020
|
+
end.to raise_error(TypeError)
|
2009
2021
|
end
|
2010
2022
|
|
2011
2023
|
it "should raise an error if the request URI is set to something bogus" do
|
2012
|
-
expect
|
2024
|
+
expect do
|
2013
2025
|
@uri.request_uri = 42
|
2014
|
-
end
|
2026
|
+
end.to raise_error(TypeError)
|
2015
2027
|
end
|
2016
2028
|
|
2017
2029
|
it "should correctly convert to a hash" do
|
2018
2030
|
expect(@uri.to_hash).to eq({
|
2019
|
-
:scheme => "
|
2031
|
+
:scheme => "HTTP",
|
2020
2032
|
:user => nil,
|
2021
2033
|
:password => nil,
|
2022
2034
|
:host => "www.w3.org",
|
@@ -2060,9 +2072,9 @@ describe Addressable::URI, "when parsing IPv6 addresses" do
|
|
2060
2072
|
|
2061
2073
|
it "should raise an error for " +
|
2062
2074
|
"'http://[<invalid>]/'" do
|
2063
|
-
expect
|
2075
|
+
expect do
|
2064
2076
|
Addressable::URI.parse("http://[<invalid>]/")
|
2065
|
-
end
|
2077
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
2066
2078
|
end
|
2067
2079
|
end
|
2068
2080
|
|
@@ -2088,9 +2100,9 @@ describe Addressable::URI, "when assigning IPv6 address" do
|
|
2088
2100
|
it "should not allow to set bare IPv6 address as host" do
|
2089
2101
|
uri = Addressable::URI.parse("http://[::1]/")
|
2090
2102
|
skip "not checked"
|
2091
|
-
expect
|
2103
|
+
expect do
|
2092
2104
|
uri.host = '3ffe:1900:4545:3:200:f8ff:fe21:67cf'
|
2093
|
-
end
|
2105
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
2094
2106
|
end
|
2095
2107
|
end
|
2096
2108
|
|
@@ -2122,9 +2134,9 @@ describe Addressable::URI, "when parsing IPvFuture addresses" do
|
|
2122
2134
|
|
2123
2135
|
it "should raise an error for " +
|
2124
2136
|
"'http://[v0.<invalid>]/'" do
|
2125
|
-
expect
|
2137
|
+
expect do
|
2126
2138
|
Addressable::URI.parse("http://[v0.<invalid>]/")
|
2127
|
-
end
|
2139
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
2128
2140
|
end
|
2129
2141
|
end
|
2130
2142
|
|
@@ -2468,9 +2480,9 @@ describe Addressable::URI, "when parsed from " +
|
|
2468
2480
|
end
|
2469
2481
|
|
2470
2482
|
it "should not raise an exception when normalized" do
|
2471
|
-
expect
|
2483
|
+
expect do
|
2472
2484
|
@uri.normalize
|
2473
|
-
end
|
2485
|
+
end.not_to raise_error
|
2474
2486
|
end
|
2475
2487
|
|
2476
2488
|
it "should be considered to be in normal form" do
|
@@ -2522,9 +2534,9 @@ describe Addressable::URI, "when parsed from " +
|
|
2522
2534
|
end
|
2523
2535
|
|
2524
2536
|
it "should not raise an exception when normalized" do
|
2525
|
-
expect
|
2537
|
+
expect do
|
2526
2538
|
@uri.normalize
|
2527
|
-
end
|
2539
|
+
end.not_to raise_error
|
2528
2540
|
end
|
2529
2541
|
|
2530
2542
|
it "should be considered to be in normal form" do
|
@@ -2547,9 +2559,9 @@ describe Addressable::URI, "when parsed from " +
|
|
2547
2559
|
end
|
2548
2560
|
|
2549
2561
|
it "should not raise an exception when normalized" do
|
2550
|
-
expect
|
2562
|
+
expect do
|
2551
2563
|
@uri.normalize
|
2552
|
-
end
|
2564
|
+
end.not_to raise_error
|
2553
2565
|
end
|
2554
2566
|
|
2555
2567
|
it "should be considered to be in normal form" do
|
@@ -2585,9 +2597,9 @@ describe Addressable::URI, "when parsed from " +
|
|
2585
2597
|
end
|
2586
2598
|
|
2587
2599
|
it "should raise an error if encoding with an unexpected return type" do
|
2588
|
-
expect
|
2600
|
+
expect do
|
2589
2601
|
Addressable::URI.normalized_encode(@uri, Integer)
|
2590
|
-
end
|
2602
|
+
end.to raise_error(TypeError)
|
2591
2603
|
end
|
2592
2604
|
|
2593
2605
|
it "if percent encoded should be 'http://example.com/C%25CC%25A7'" do
|
@@ -2603,9 +2615,9 @@ describe Addressable::URI, "when parsed from " +
|
|
2603
2615
|
end
|
2604
2616
|
|
2605
2617
|
it "should raise an error if encoding with an unexpected return type" do
|
2606
|
-
expect
|
2618
|
+
expect do
|
2607
2619
|
Addressable::URI.encode(@uri, Integer)
|
2608
|
-
end
|
2620
|
+
end.to raise_error(TypeError)
|
2609
2621
|
end
|
2610
2622
|
|
2611
2623
|
it "should be identical to its duplicate" do
|
@@ -2740,9 +2752,9 @@ describe Addressable::URI, "when parsed from " +
|
|
2740
2752
|
|
2741
2753
|
it "should not be roughly equal to the string " +
|
2742
2754
|
"'http://example.com:bogus/'" do
|
2743
|
-
expect
|
2755
|
+
expect do
|
2744
2756
|
expect(@uri === "http://example.com:bogus/").to eq(false)
|
2745
|
-
end
|
2757
|
+
end.not_to raise_error
|
2746
2758
|
end
|
2747
2759
|
|
2748
2760
|
it "should result in itself when joined with itself" do
|
@@ -3088,9 +3100,9 @@ describe Addressable::URI, "when parsed from " +
|
|
3088
3100
|
end
|
3089
3101
|
|
3090
3102
|
it "should become invalid when normalized" do
|
3091
|
-
expect
|
3103
|
+
expect do
|
3092
3104
|
@uri.normalize
|
3093
|
-
end
|
3105
|
+
end.to raise_error(Addressable::URI::InvalidURIError, /authority/)
|
3094
3106
|
end
|
3095
3107
|
|
3096
3108
|
it "should have a path of '/..//example.com'" do
|
@@ -3328,12 +3340,12 @@ describe Addressable::URI, "when parsed from " +
|
|
3328
3340
|
end
|
3329
3341
|
|
3330
3342
|
it "should raise an error if routing is attempted" do
|
3331
|
-
expect
|
3343
|
+
expect do
|
3332
3344
|
@uri.route_to("http://example.com/")
|
3333
|
-
end
|
3334
|
-
expect
|
3345
|
+
end.to raise_error(ArgumentError, /relative\/path\/to\/resource/)
|
3346
|
+
expect do
|
3335
3347
|
@uri.route_from("http://example.com/")
|
3336
|
-
end
|
3348
|
+
end.to raise_error(ArgumentError, /relative\/path\/to\/resource/)
|
3337
3349
|
end
|
3338
3350
|
|
3339
3351
|
it "when joined with 'another/relative/path' should be " +
|
@@ -3930,9 +3942,9 @@ describe Addressable::URI, "when parsed from " +
|
|
3930
3942
|
end
|
3931
3943
|
|
3932
3944
|
it "should raise an error if assigning a bogus object to the hostname" do
|
3933
|
-
expect
|
3945
|
+
expect do
|
3934
3946
|
@uri.hostname = Object.new
|
3935
|
-
end
|
3947
|
+
end.to raise_error(TypeError)
|
3936
3948
|
end
|
3937
3949
|
|
3938
3950
|
it "should have the correct port after assignment" do
|
@@ -4011,9 +4023,9 @@ describe Addressable::URI, "when parsed from " +
|
|
4011
4023
|
end
|
4012
4024
|
|
4013
4025
|
it "should raise an error if query values are set to a bogus type" do
|
4014
|
-
expect
|
4026
|
+
expect do
|
4015
4027
|
@uri.query_values = "bogus"
|
4016
|
-
end
|
4028
|
+
end.to raise_error(TypeError)
|
4017
4029
|
end
|
4018
4030
|
|
4019
4031
|
it "should have the correct fragment after assignment" do
|
@@ -4085,39 +4097,39 @@ describe Addressable::URI, "when parsed from " +
|
|
4085
4097
|
end
|
4086
4098
|
|
4087
4099
|
it "should fail to merge with bogus values" do
|
4088
|
-
expect
|
4100
|
+
expect do
|
4089
4101
|
@uri.merge(:port => "bogus")
|
4090
|
-
end
|
4102
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
4091
4103
|
end
|
4092
4104
|
|
4093
4105
|
it "should fail to merge with bogus values" do
|
4094
|
-
expect
|
4106
|
+
expect do
|
4095
4107
|
@uri.merge(:authority => "bar@baz:bogus")
|
4096
|
-
end
|
4108
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
4097
4109
|
end
|
4098
4110
|
|
4099
4111
|
it "should fail to merge with bogus parameters" do
|
4100
|
-
expect
|
4112
|
+
expect do
|
4101
4113
|
@uri.merge(42)
|
4102
|
-
end
|
4114
|
+
end.to raise_error(TypeError)
|
4103
4115
|
end
|
4104
4116
|
|
4105
4117
|
it "should fail to merge with bogus parameters" do
|
4106
|
-
expect
|
4118
|
+
expect do
|
4107
4119
|
@uri.merge("http://example.com/")
|
4108
|
-
end
|
4120
|
+
end.to raise_error(TypeError)
|
4109
4121
|
end
|
4110
4122
|
|
4111
4123
|
it "should fail to merge with both authority and subcomponents" do
|
4112
|
-
expect
|
4124
|
+
expect do
|
4113
4125
|
@uri.merge(:authority => "foo:bar@baz:42", :port => "42")
|
4114
|
-
end
|
4126
|
+
end.to raise_error(ArgumentError)
|
4115
4127
|
end
|
4116
4128
|
|
4117
4129
|
it "should fail to merge with both userinfo and subcomponents" do
|
4118
|
-
expect
|
4130
|
+
expect do
|
4119
4131
|
@uri.merge(:userinfo => "foo:bar", :user => "foo")
|
4120
|
-
end
|
4132
|
+
end.to raise_error(ArgumentError)
|
4121
4133
|
end
|
4122
4134
|
|
4123
4135
|
it "should be identical to its duplicate" do
|
@@ -4250,6 +4262,36 @@ describe Addressable::URI, "when parsed from " +
|
|
4250
4262
|
end
|
4251
4263
|
end
|
4252
4264
|
|
4265
|
+
describe Addressable::URI, "when parsed from 'https://example.com/?q=a+b'" do
|
4266
|
+
before do
|
4267
|
+
@uri = Addressable::URI.parse("https://example.com/?q=a+b")
|
4268
|
+
end
|
4269
|
+
|
4270
|
+
it "should have query_values of {'q' => 'a b'}" do
|
4271
|
+
expect(@uri.query_values).to eq("q" => "a b")
|
4272
|
+
end
|
4273
|
+
end
|
4274
|
+
|
4275
|
+
describe Addressable::URI, "when parsed from 'example.com?q=a+b'" do
|
4276
|
+
before do
|
4277
|
+
@uri = Addressable::URI.parse("example.com?q=a+b")
|
4278
|
+
end
|
4279
|
+
|
4280
|
+
it "should have query_values of {'q' => 'a b'}" do
|
4281
|
+
expect(@uri.query_values).to eq("q" => "a b")
|
4282
|
+
end
|
4283
|
+
end
|
4284
|
+
|
4285
|
+
describe Addressable::URI, "when parsed from 'mailto:?q=a+b'" do
|
4286
|
+
before do
|
4287
|
+
@uri = Addressable::URI.parse("mailto:?q=a+b")
|
4288
|
+
end
|
4289
|
+
|
4290
|
+
it "should have query_values of {'q' => 'a+b'}" do
|
4291
|
+
expect(@uri.query_values).to eq("q" => "a+b")
|
4292
|
+
end
|
4293
|
+
end
|
4294
|
+
|
4253
4295
|
describe Addressable::URI, "when parsed from " +
|
4254
4296
|
"'http://example.com/?q=a%2bb'" do
|
4255
4297
|
before do
|
@@ -4291,6 +4333,46 @@ describe Addressable::URI, "when parsed from " +
|
|
4291
4333
|
end
|
4292
4334
|
end
|
4293
4335
|
|
4336
|
+
describe Addressable::URI, "when parsed from 'http://example/?b=1&a=2&c=3'" do
|
4337
|
+
before do
|
4338
|
+
@uri = Addressable::URI.parse("http://example/?b=1&a=2&c=3")
|
4339
|
+
end
|
4340
|
+
|
4341
|
+
it "should have a sorted normalized query of 'a=2&b=1&c=3'" do
|
4342
|
+
expect(@uri.normalized_query(:sorted)).to eq("a=2&b=1&c=3")
|
4343
|
+
end
|
4344
|
+
end
|
4345
|
+
|
4346
|
+
describe Addressable::URI, "when parsed from 'http://example/?&a&&c&'" do
|
4347
|
+
before do
|
4348
|
+
@uri = Addressable::URI.parse("http://example/?&a&&c&")
|
4349
|
+
end
|
4350
|
+
|
4351
|
+
it "should have a compacted normalized query of 'a&c'" do
|
4352
|
+
expect(@uri.normalized_query(:compacted)).to eq("a&c")
|
4353
|
+
end
|
4354
|
+
end
|
4355
|
+
|
4356
|
+
describe Addressable::URI, "when parsed from 'http://example.com/?a=1&a=1'" do
|
4357
|
+
before do
|
4358
|
+
@uri = Addressable::URI.parse("http://example.com/?a=1&a=1")
|
4359
|
+
end
|
4360
|
+
|
4361
|
+
it "should have a compacted normalized query of 'a=1'" do
|
4362
|
+
expect(@uri.normalized_query(:compacted)).to eq("a=1")
|
4363
|
+
end
|
4364
|
+
end
|
4365
|
+
|
4366
|
+
describe Addressable::URI, "when parsed from 'http://example.com/?a=1&a=2'" do
|
4367
|
+
before do
|
4368
|
+
@uri = Addressable::URI.parse("http://example.com/?a=1&a=2")
|
4369
|
+
end
|
4370
|
+
|
4371
|
+
it "should have a compacted normalized query of 'a=1&a=2'" do
|
4372
|
+
expect(@uri.normalized_query(:compacted)).to eq("a=1&a=2")
|
4373
|
+
end
|
4374
|
+
end
|
4375
|
+
|
4294
4376
|
describe Addressable::URI, "when parsed from " +
|
4295
4377
|
"'http://example.com/sound%2bvision'" do
|
4296
4378
|
before do
|
@@ -4402,10 +4484,10 @@ describe Addressable::URI, "when parsed from " +
|
|
4402
4484
|
end
|
4403
4485
|
|
4404
4486
|
it "should raise an error after nil assignment of authority segment" do
|
4405
|
-
expect
|
4487
|
+
expect do
|
4406
4488
|
# This would create an invalid URI
|
4407
4489
|
@uri.authority = nil
|
4408
|
-
end
|
4490
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
4409
4491
|
end
|
4410
4492
|
end
|
4411
4493
|
|
@@ -4634,12 +4716,12 @@ describe Addressable::URI, "when parsed from " +
|
|
4634
4716
|
end
|
4635
4717
|
|
4636
4718
|
it "should raise an error if routing is attempted" do
|
4637
|
-
expect
|
4719
|
+
expect do
|
4638
4720
|
@uri.route_to("http://example.com/")
|
4639
|
-
end
|
4640
|
-
expect
|
4721
|
+
end.to raise_error(ArgumentError, /\/\/example.com\//)
|
4722
|
+
expect do
|
4641
4723
|
@uri.route_from("http://example.com/")
|
4642
|
-
end
|
4724
|
+
end.to raise_error(ArgumentError, /\/\/example.com\//)
|
4643
4725
|
end
|
4644
4726
|
|
4645
4727
|
it "should have a 'null' origin" do
|
@@ -4733,9 +4815,9 @@ end
|
|
4733
4815
|
describe Addressable::URI, "when parsed from " +
|
4734
4816
|
"'http://under_score.example.com/'" do
|
4735
4817
|
it "should not cause an error" do
|
4736
|
-
expect
|
4818
|
+
expect do
|
4737
4819
|
Addressable::URI.parse("http://under_score.example.com/")
|
4738
|
-
end
|
4820
|
+
end.not_to raise_error
|
4739
4821
|
end
|
4740
4822
|
end
|
4741
4823
|
|
@@ -4807,9 +4889,9 @@ describe Addressable::URI, "when parsed from '?one=1&two=2&three=3'" do
|
|
4807
4889
|
end
|
4808
4890
|
|
4809
4891
|
it "should raise an error for invalid return type values" do
|
4810
|
-
expect
|
4811
|
-
@uri.query_values(
|
4812
|
-
end
|
4892
|
+
expect do
|
4893
|
+
@uri.query_values(Integer)
|
4894
|
+
end.to raise_error(ArgumentError)
|
4813
4895
|
end
|
4814
4896
|
|
4815
4897
|
it "should have the correct array query values" do
|
@@ -5410,9 +5492,9 @@ describe Addressable::URI, "with a base uri of 'http://a/b/c/d;p?q'" do
|
|
5410
5492
|
end
|
5411
5493
|
|
5412
5494
|
it "when joined with a bogus object a TypeError should be raised" do
|
5413
|
-
expect
|
5495
|
+
expect do
|
5414
5496
|
Addressable::URI.join(@uri, 42)
|
5415
|
-
end
|
5497
|
+
end.to raise_error(TypeError)
|
5416
5498
|
end
|
5417
5499
|
end
|
5418
5500
|
|
@@ -5439,9 +5521,9 @@ end
|
|
5439
5521
|
|
5440
5522
|
describe Addressable::URI, "when converting a bogus path" do
|
5441
5523
|
it "should raise a TypeError" do
|
5442
|
-
expect
|
5524
|
+
expect do
|
5443
5525
|
Addressable::URI.convert_path(42)
|
5444
|
-
end
|
5526
|
+
end.to raise_error(TypeError)
|
5445
5527
|
end
|
5446
5528
|
end
|
5447
5529
|
|
@@ -5494,6 +5576,31 @@ describe Addressable::URI, "when given the path '/one/two/'" do
|
|
5494
5576
|
end
|
5495
5577
|
end
|
5496
5578
|
|
5579
|
+
describe Addressable::URI, "when given the tld " do
|
5580
|
+
it "'uk' should have a tld of 'uk'" do
|
5581
|
+
uri = Addressable::URI.parse("http://example.com")
|
5582
|
+
uri.tld = "uk"
|
5583
|
+
|
5584
|
+
expect(uri.tld).to eq("uk")
|
5585
|
+
end
|
5586
|
+
|
5587
|
+
context "which " do
|
5588
|
+
let (:uri) { Addressable::URI.parse("http://www.comrade.net/path/to/source/") }
|
5589
|
+
|
5590
|
+
it "contains a subdomain" do
|
5591
|
+
uri.tld = "co.uk"
|
5592
|
+
|
5593
|
+
expect(uri.to_s).to eq("http://www.comrade.co.uk/path/to/source/")
|
5594
|
+
end
|
5595
|
+
|
5596
|
+
it "is part of the domain" do
|
5597
|
+
uri.tld = "com"
|
5598
|
+
|
5599
|
+
expect(uri.to_s).to eq("http://www.comrade.com/path/to/source/")
|
5600
|
+
end
|
5601
|
+
end
|
5602
|
+
end
|
5603
|
+
|
5497
5604
|
describe Addressable::URI, "when given the path " +
|
5498
5605
|
"'c:\\windows\\My Documents 100%20\\foo.txt'" do
|
5499
5606
|
before do
|
@@ -5611,9 +5718,9 @@ describe Addressable::URI, "when parsing a non-String object" do
|
|
5611
5718
|
end
|
5612
5719
|
|
5613
5720
|
it "should raise a TypeError for objects than cannot be converted" do
|
5614
|
-
expect
|
5721
|
+
expect do
|
5615
5722
|
Addressable::URI.parse(42)
|
5616
|
-
end
|
5723
|
+
end.to raise_error(TypeError)
|
5617
5724
|
end
|
5618
5725
|
|
5619
5726
|
it "should correctly parse heuristically anything with a 'to_str' method" do
|
@@ -5621,9 +5728,9 @@ describe Addressable::URI, "when parsing a non-String object" do
|
|
5621
5728
|
end
|
5622
5729
|
|
5623
5730
|
it "should raise a TypeError for objects than cannot be converted" do
|
5624
|
-
expect
|
5731
|
+
expect do
|
5625
5732
|
Addressable::URI.heuristic_parse(42)
|
5626
|
-
end
|
5733
|
+
end.to raise_error(TypeError)
|
5627
5734
|
end
|
5628
5735
|
end
|
5629
5736
|
|
@@ -5667,9 +5774,9 @@ end
|
|
5667
5774
|
|
5668
5775
|
describe Addressable::URI, "when form encoding a non-Array object" do
|
5669
5776
|
it "should raise a TypeError for objects than cannot be converted" do
|
5670
|
-
expect
|
5777
|
+
expect do
|
5671
5778
|
Addressable::URI.form_encode(42)
|
5672
|
-
end
|
5779
|
+
end.to raise_error(TypeError)
|
5673
5780
|
end
|
5674
5781
|
end
|
5675
5782
|
|
@@ -5735,9 +5842,9 @@ describe Addressable::URI, "when form unencoding a non-String object" do
|
|
5735
5842
|
end
|
5736
5843
|
|
5737
5844
|
it "should raise a TypeError for objects than cannot be converted" do
|
5738
|
-
expect
|
5845
|
+
expect do
|
5739
5846
|
Addressable::URI.form_unencode(42)
|
5740
|
-
end
|
5847
|
+
end.to raise_error(TypeError)
|
5741
5848
|
end
|
5742
5849
|
end
|
5743
5850
|
|
@@ -5747,15 +5854,15 @@ describe Addressable::URI, "when normalizing a non-String object" do
|
|
5747
5854
|
end
|
5748
5855
|
|
5749
5856
|
it "should raise a TypeError for objects than cannot be converted" do
|
5750
|
-
expect
|
5857
|
+
expect do
|
5751
5858
|
Addressable::URI.normalize_component(42)
|
5752
|
-
end
|
5859
|
+
end.to raise_error(TypeError)
|
5753
5860
|
end
|
5754
5861
|
|
5755
5862
|
it "should raise a TypeError for objects than cannot be converted" do
|
5756
|
-
expect
|
5863
|
+
expect do
|
5757
5864
|
Addressable::URI.normalize_component("component", 42)
|
5758
|
-
end
|
5865
|
+
end.to raise_error(TypeError)
|
5759
5866
|
end
|
5760
5867
|
end
|
5761
5868
|
|
@@ -5827,6 +5934,18 @@ describe Addressable::URI, "when normalizing a string but leaving some character
|
|
5827
5934
|
end
|
5828
5935
|
end
|
5829
5936
|
|
5937
|
+
describe Addressable::URI, "when encoding IP literals" do
|
5938
|
+
it "should work for IPv4" do
|
5939
|
+
input = "http://127.0.0.1/"
|
5940
|
+
expect(Addressable::URI.encode(input)).to eq(input)
|
5941
|
+
end
|
5942
|
+
|
5943
|
+
it "should work for IPv6" do
|
5944
|
+
input = "http://[fe80::200:f8ff:fe21:67cf]/"
|
5945
|
+
expect(Addressable::URI.encode(input)).to eq(input)
|
5946
|
+
end
|
5947
|
+
end
|
5948
|
+
|
5830
5949
|
describe Addressable::URI, "when encoding a string with existing encodings to upcase" do
|
5831
5950
|
it "should result in correct percent encoded sequence" do
|
5832
5951
|
expect(Addressable::URI.encode_component("JK%4c", "0-9A-IKM-Za-z%", "L")).to eq("%4AK%4C")
|
@@ -5899,41 +6018,41 @@ end
|
|
5899
6018
|
|
5900
6019
|
describe Addressable::URI, "when unencoding a bogus object" do
|
5901
6020
|
it "should raise a TypeError" do
|
5902
|
-
expect
|
6021
|
+
expect do
|
5903
6022
|
Addressable::URI.unencode_component(42)
|
5904
|
-
end
|
6023
|
+
end.to raise_error(TypeError)
|
5905
6024
|
end
|
5906
6025
|
|
5907
6026
|
it "should raise a TypeError" do
|
5908
|
-
expect
|
6027
|
+
expect do
|
5909
6028
|
Addressable::URI.unencode("/path?g%C3%BCnther", Integer)
|
5910
|
-
end
|
6029
|
+
end.to raise_error(TypeError)
|
5911
6030
|
end
|
5912
6031
|
end
|
5913
6032
|
|
5914
6033
|
describe Addressable::URI, "when encoding a bogus object" do
|
5915
6034
|
it "should raise a TypeError" do
|
5916
|
-
expect
|
6035
|
+
expect do
|
5917
6036
|
Addressable::URI.encode(Object.new)
|
5918
|
-
end
|
6037
|
+
end.to raise_error(TypeError)
|
5919
6038
|
end
|
5920
6039
|
|
5921
6040
|
it "should raise a TypeError" do
|
5922
|
-
expect
|
6041
|
+
expect do
|
5923
6042
|
Addressable::URI.normalized_encode(Object.new)
|
5924
|
-
end
|
6043
|
+
end.to raise_error(TypeError)
|
5925
6044
|
end
|
5926
6045
|
|
5927
6046
|
it "should raise a TypeError" do
|
5928
|
-
expect
|
6047
|
+
expect do
|
5929
6048
|
Addressable::URI.encode_component("günther", Object.new)
|
5930
|
-
end
|
6049
|
+
end.to raise_error(TypeError)
|
5931
6050
|
end
|
5932
6051
|
|
5933
6052
|
it "should raise a TypeError" do
|
5934
|
-
expect
|
6053
|
+
expect do
|
5935
6054
|
Addressable::URI.encode_component(Object.new)
|
5936
|
-
end
|
6055
|
+
end.to raise_error(TypeError)
|
5937
6056
|
end
|
5938
6057
|
end
|
5939
6058
|
|
@@ -5949,9 +6068,9 @@ describe Addressable::URI, "when given the input " +
|
|
5949
6068
|
end
|
5950
6069
|
|
5951
6070
|
it "should not raise error when frozen" do
|
5952
|
-
expect
|
6071
|
+
expect do
|
5953
6072
|
Addressable::URI.heuristic_parse(@input).freeze.to_s
|
5954
|
-
end
|
6073
|
+
end.not_to raise_error
|
5955
6074
|
end
|
5956
6075
|
end
|
5957
6076
|
|
@@ -6231,6 +6350,18 @@ describe Addressable::URI, "when given the input " +
|
|
6231
6350
|
end
|
6232
6351
|
end
|
6233
6352
|
|
6353
|
+
describe Addressable::URI, "when given the input which "\
|
6354
|
+
"start with digits and has specified port" do
|
6355
|
+
before do
|
6356
|
+
@input = "7777.example.org:8089"
|
6357
|
+
end
|
6358
|
+
|
6359
|
+
it "should heuristically parse to 'http://7777.example.org:8089'" do
|
6360
|
+
uri = Addressable::URI.heuristic_parse(@input)
|
6361
|
+
expect(uri.to_s).to eq("http://7777.example.org:8089")
|
6362
|
+
end
|
6363
|
+
end
|
6364
|
+
|
6234
6365
|
describe Addressable::URI, "when given the input " +
|
6235
6366
|
"'feed:///example.com'" do
|
6236
6367
|
before do
|
@@ -6243,6 +6374,18 @@ describe Addressable::URI, "when given the input " +
|
|
6243
6374
|
end
|
6244
6375
|
end
|
6245
6376
|
|
6377
|
+
describe Addressable::URI, "when given the input " +
|
6378
|
+
"'file://localhost/path/to/resource/'" do
|
6379
|
+
before do
|
6380
|
+
@input = "file://localhost/path/to/resource/"
|
6381
|
+
end
|
6382
|
+
|
6383
|
+
it "should heuristically parse to 'file:///path/to/resource/'" do
|
6384
|
+
@uri = Addressable::URI.heuristic_parse(@input)
|
6385
|
+
expect(@uri.to_s).to eq("file:///path/to/resource/")
|
6386
|
+
end
|
6387
|
+
end
|
6388
|
+
|
6246
6389
|
describe Addressable::URI, "when given the input " +
|
6247
6390
|
"'file://path/to/resource/'" do
|
6248
6391
|
before do
|
@@ -6255,6 +6398,18 @@ describe Addressable::URI, "when given the input " +
|
|
6255
6398
|
end
|
6256
6399
|
end
|
6257
6400
|
|
6401
|
+
describe Addressable::URI, "when given the input " +
|
6402
|
+
"'file://///path/to/resource/'" do
|
6403
|
+
before do
|
6404
|
+
@input = "file:///////path/to/resource/"
|
6405
|
+
end
|
6406
|
+
|
6407
|
+
it "should heuristically parse to 'file:////path/to/resource/'" do
|
6408
|
+
@uri = Addressable::URI.heuristic_parse(@input)
|
6409
|
+
expect(@uri.to_s).to eq("file:////path/to/resource/")
|
6410
|
+
end
|
6411
|
+
end
|
6412
|
+
|
6258
6413
|
describe Addressable::URI, "when given the input " +
|
6259
6414
|
"'feed://http://example.com'" do
|
6260
6415
|
before do
|
@@ -6279,6 +6434,44 @@ describe Addressable::URI, "when given the input " +
|
|
6279
6434
|
end
|
6280
6435
|
end
|
6281
6436
|
|
6437
|
+
describe Addressable::URI, "when given the input: 'user@domain.com'" do
|
6438
|
+
before do
|
6439
|
+
@input = "user@domain.com"
|
6440
|
+
end
|
6441
|
+
|
6442
|
+
context "for heuristic parse" do
|
6443
|
+
it "should remain 'mailto:user@domain.com'" do
|
6444
|
+
uri = Addressable::URI.heuristic_parse("mailto:#{@input}")
|
6445
|
+
expect(uri.to_s).to eq("mailto:user@domain.com")
|
6446
|
+
end
|
6447
|
+
|
6448
|
+
it "should have a scheme of 'mailto'" do
|
6449
|
+
uri = Addressable::URI.heuristic_parse(@input)
|
6450
|
+
expect(uri.to_s).to eq("mailto:user@domain.com")
|
6451
|
+
expect(uri.scheme).to eq("mailto")
|
6452
|
+
end
|
6453
|
+
|
6454
|
+
it "should remain 'acct:user@domain.com'" do
|
6455
|
+
uri = Addressable::URI.heuristic_parse("acct:#{@input}")
|
6456
|
+
expect(uri.to_s).to eq("acct:user@domain.com")
|
6457
|
+
end
|
6458
|
+
|
6459
|
+
context "HTTP" do
|
6460
|
+
before do
|
6461
|
+
@uri = Addressable::URI.heuristic_parse("http://#{@input}/")
|
6462
|
+
end
|
6463
|
+
|
6464
|
+
it "should remain 'http://user@domain.com/'" do
|
6465
|
+
expect(@uri.to_s).to eq("http://user@domain.com/")
|
6466
|
+
end
|
6467
|
+
|
6468
|
+
it "should have the username 'user' for HTTP basic authentication" do
|
6469
|
+
expect(@uri.user).to eq("user")
|
6470
|
+
end
|
6471
|
+
end
|
6472
|
+
end
|
6473
|
+
end
|
6474
|
+
|
6282
6475
|
describe Addressable::URI, "when assigning query values" do
|
6283
6476
|
before do
|
6284
6477
|
@uri = Addressable::URI.new
|
@@ -6290,54 +6483,54 @@ describe Addressable::URI, "when assigning query values" do
|
|
6290
6483
|
end
|
6291
6484
|
|
6292
6485
|
it "should raise an error attempting to assign {'a' => {'b' => ['c']}}" do
|
6293
|
-
expect
|
6486
|
+
expect do
|
6294
6487
|
@uri.query_values = { 'a' => {'b' => ['c'] } }
|
6295
|
-
end
|
6488
|
+
end.to raise_error(TypeError)
|
6296
6489
|
end
|
6297
6490
|
|
6298
6491
|
it "should raise an error attempting to assign " +
|
6299
6492
|
"{:b => '2', :a => {:c => '1'}}" do
|
6300
|
-
expect
|
6493
|
+
expect do
|
6301
6494
|
@uri.query_values = {:b => '2', :a => {:c => '1'}}
|
6302
|
-
end
|
6495
|
+
end.to raise_error(TypeError)
|
6303
6496
|
end
|
6304
6497
|
|
6305
6498
|
it "should raise an error attempting to assign " +
|
6306
6499
|
"{:a => 'a', :b => [{:c => 'c', :d => 'd'}, " +
|
6307
6500
|
"{:e => 'e', :f => 'f'}]}" do
|
6308
|
-
expect
|
6501
|
+
expect do
|
6309
6502
|
@uri.query_values = {
|
6310
6503
|
:a => "a", :b => [{:c => "c", :d => "d"}, {:e => "e", :f => "f"}]
|
6311
6504
|
}
|
6312
|
-
end
|
6505
|
+
end.to raise_error(TypeError)
|
6313
6506
|
end
|
6314
6507
|
|
6315
6508
|
it "should raise an error attempting to assign " +
|
6316
6509
|
"{:a => 'a', :b => [{:c => true, :d => 'd'}, " +
|
6317
6510
|
"{:e => 'e', :f => 'f'}]}" do
|
6318
|
-
expect
|
6511
|
+
expect do
|
6319
6512
|
@uri.query_values = {
|
6320
6513
|
:a => 'a', :b => [{:c => true, :d => 'd'}, {:e => 'e', :f => 'f'}]
|
6321
6514
|
}
|
6322
|
-
end
|
6515
|
+
end.to raise_error(TypeError)
|
6323
6516
|
end
|
6324
6517
|
|
6325
6518
|
it "should raise an error attempting to assign " +
|
6326
6519
|
"{:a => 'a', :b => {:c => true, :d => 'd'}}" do
|
6327
|
-
expect
|
6520
|
+
expect do
|
6328
6521
|
@uri.query_values = {
|
6329
6522
|
:a => 'a', :b => {:c => true, :d => 'd'}
|
6330
6523
|
}
|
6331
|
-
end
|
6524
|
+
end.to raise_error(TypeError)
|
6332
6525
|
end
|
6333
6526
|
|
6334
6527
|
it "should raise an error attempting to assign " +
|
6335
6528
|
"{:a => 'a', :b => {:c => true, :d => 'd'}}" do
|
6336
|
-
expect
|
6529
|
+
expect do
|
6337
6530
|
@uri.query_values = {
|
6338
6531
|
:a => 'a', :b => {:c => true, :d => 'd'}
|
6339
6532
|
}
|
6340
|
-
end
|
6533
|
+
end.to raise_error(TypeError)
|
6341
6534
|
end
|
6342
6535
|
|
6343
6536
|
it "should correctly assign {:a => 1, :b => 1.5}" do
|
@@ -6348,13 +6541,13 @@ describe Addressable::URI, "when assigning query values" do
|
|
6348
6541
|
it "should raise an error attempting to assign " +
|
6349
6542
|
"{:z => 1, :f => [2, {999.1 => [3,'4']}, ['h', 'i']], " +
|
6350
6543
|
":a => {:b => ['c', 'd'], :e => true, :y => 0.5}}" do
|
6351
|
-
expect
|
6544
|
+
expect do
|
6352
6545
|
@uri.query_values = {
|
6353
6546
|
:z => 1,
|
6354
6547
|
:f => [ 2, {999.1 => [3,'4']}, ['h', 'i'] ],
|
6355
6548
|
:a => { :b => ['c', 'd'], :e => true, :y => 0.5 }
|
6356
6549
|
}
|
6357
|
-
end
|
6550
|
+
end.to raise_error(TypeError)
|
6358
6551
|
end
|
6359
6552
|
|
6360
6553
|
it "should correctly assign {}" do
|
@@ -6404,7 +6597,7 @@ describe Addressable::URI, "when assigning path values" do
|
|
6404
6597
|
@uri.path = "acct:bob@sporkmonger.com"
|
6405
6598
|
expect(@uri.path).to eq("acct:bob@sporkmonger.com")
|
6406
6599
|
expect(@uri.normalize.to_str).to eq("acct%2Fbob@sporkmonger.com")
|
6407
|
-
expect
|
6600
|
+
expect { @uri.to_s }.to raise_error(
|
6408
6601
|
Addressable::URI::InvalidURIError
|
6409
6602
|
)
|
6410
6603
|
end
|
@@ -6422,26 +6615,26 @@ describe Addressable::URI, "when assigning path values" do
|
|
6422
6615
|
end
|
6423
6616
|
|
6424
6617
|
it "should not allow relative paths to be assigned on absolute URIs" do
|
6425
|
-
expect
|
6618
|
+
expect do
|
6426
6619
|
@uri.scheme = "http"
|
6427
6620
|
@uri.host = "example.com"
|
6428
6621
|
@uri.path = "acct:bob@sporkmonger.com"
|
6429
|
-
end
|
6622
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
6430
6623
|
end
|
6431
6624
|
|
6432
6625
|
it "should not allow relative paths to be assigned on absolute URIs" do
|
6433
|
-
expect
|
6626
|
+
expect do
|
6434
6627
|
@uri.path = "acct:bob@sporkmonger.com"
|
6435
6628
|
@uri.scheme = "http"
|
6436
6629
|
@uri.host = "example.com"
|
6437
|
-
end
|
6630
|
+
end.to raise_error(Addressable::URI::InvalidURIError)
|
6438
6631
|
end
|
6439
6632
|
|
6440
6633
|
it "should not allow relative paths to be assigned on absolute URIs" do
|
6441
|
-
expect
|
6634
|
+
expect do
|
6442
6635
|
@uri.path = "uuid:0b3ecf60-3f93-11df-a9c3-001f5bfffe12"
|
6443
6636
|
@uri.scheme = "urn"
|
6444
|
-
end
|
6637
|
+
end.not_to raise_error
|
6445
6638
|
end
|
6446
6639
|
end
|
6447
6640
|
|