faraday 0.17.3 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +52 -8
- data/LICENSE.md +1 -1
- data/README.md +18 -358
- data/Rakefile +1 -7
- data/examples/client_spec.rb +65 -0
- data/examples/client_test.rb +79 -0
- data/lib/faraday.rb +94 -175
- data/lib/faraday/adapter.rb +82 -22
- data/lib/faraday/adapter/em_http.rb +142 -99
- data/lib/faraday/adapter/em_http_ssl_patch.rb +24 -18
- data/lib/faraday/adapter/em_synchrony.rb +104 -60
- data/lib/faraday/adapter/em_synchrony/parallel_manager.rb +18 -15
- data/lib/faraday/adapter/excon.rb +98 -56
- data/lib/faraday/adapter/httpclient.rb +83 -59
- data/lib/faraday/adapter/net_http.rb +130 -63
- data/lib/faraday/adapter/net_http_persistent.rb +50 -27
- data/lib/faraday/adapter/patron.rb +80 -43
- data/lib/faraday/adapter/rack.rb +30 -13
- data/lib/faraday/adapter/test.rb +86 -53
- data/lib/faraday/adapter/typhoeus.rb +4 -1
- data/lib/faraday/adapter_registry.rb +30 -0
- data/lib/faraday/autoload.rb +47 -36
- data/lib/faraday/connection.rb +312 -182
- data/lib/faraday/dependency_loader.rb +37 -0
- data/lib/faraday/encoders/flat_params_encoder.rb +98 -0
- data/lib/faraday/encoders/nested_params_encoder.rb +171 -0
- data/lib/faraday/error.rb +9 -35
- data/lib/faraday/file_part.rb +128 -0
- data/lib/faraday/logging/formatter.rb +105 -0
- data/lib/faraday/middleware.rb +12 -28
- data/lib/faraday/middleware_registry.rb +129 -0
- data/lib/faraday/options.rb +32 -183
- data/lib/faraday/options/connection_options.rb +22 -0
- data/lib/faraday/options/env.rb +181 -0
- data/lib/faraday/options/proxy_options.rb +28 -0
- data/lib/faraday/options/request_options.rb +22 -0
- data/lib/faraday/options/ssl_options.rb +59 -0
- data/lib/faraday/param_part.rb +53 -0
- data/lib/faraday/parameters.rb +4 -197
- data/lib/faraday/rack_builder.rb +66 -55
- data/lib/faraday/request.rb +68 -36
- data/lib/faraday/request/authorization.rb +44 -30
- data/lib/faraday/request/basic_authentication.rb +14 -7
- data/lib/faraday/request/instrumentation.rb +45 -27
- data/lib/faraday/request/multipart.rb +79 -48
- data/lib/faraday/request/retry.rb +197 -171
- data/lib/faraday/request/token_authentication.rb +15 -10
- data/lib/faraday/request/url_encoded.rb +43 -23
- data/lib/faraday/response.rb +24 -14
- data/lib/faraday/response/logger.rb +22 -69
- data/lib/faraday/response/raise_error.rb +38 -18
- data/lib/faraday/utils.rb +36 -245
- data/lib/faraday/utils/headers.rb +139 -0
- data/lib/faraday/utils/params_hash.rb +61 -0
- data/spec/external_adapters/faraday_specs_setup.rb +14 -0
- data/spec/faraday/adapter/em_http_spec.rb +47 -0
- data/spec/faraday/adapter/em_synchrony_spec.rb +16 -0
- data/spec/faraday/adapter/excon_spec.rb +49 -0
- data/spec/faraday/adapter/httpclient_spec.rb +73 -0
- data/spec/faraday/adapter/net_http_persistent_spec.rb +57 -0
- data/spec/faraday/adapter/net_http_spec.rb +64 -0
- data/spec/faraday/adapter/patron_spec.rb +18 -0
- data/spec/faraday/adapter/rack_spec.rb +8 -0
- data/spec/faraday/adapter/typhoeus_spec.rb +7 -0
- data/spec/faraday/adapter_registry_spec.rb +28 -0
- data/spec/faraday/adapter_spec.rb +55 -0
- data/spec/faraday/composite_read_io_spec.rb +80 -0
- data/spec/faraday/connection_spec.rb +691 -0
- data/spec/faraday/error_spec.rb +0 -57
- data/spec/faraday/middleware_spec.rb +26 -0
- data/spec/faraday/options/env_spec.rb +70 -0
- data/spec/faraday/options/options_spec.rb +297 -0
- data/spec/faraday/options/proxy_options_spec.rb +37 -0
- data/spec/faraday/options/request_options_spec.rb +19 -0
- data/spec/faraday/params_encoders/flat_spec.rb +34 -0
- data/spec/faraday/params_encoders/nested_spec.rb +134 -0
- data/spec/faraday/rack_builder_spec.rb +196 -0
- data/spec/faraday/request/authorization_spec.rb +88 -0
- data/spec/faraday/request/instrumentation_spec.rb +76 -0
- data/spec/faraday/request/multipart_spec.rb +274 -0
- data/spec/faraday/request/retry_spec.rb +242 -0
- data/spec/faraday/request/url_encoded_spec.rb +83 -0
- data/spec/faraday/request_spec.rb +109 -0
- data/spec/faraday/response/logger_spec.rb +220 -0
- data/spec/faraday/response/middleware_spec.rb +68 -0
- data/spec/faraday/response/raise_error_spec.rb +15 -15
- data/spec/faraday/response_spec.rb +75 -0
- data/spec/faraday/utils/headers_spec.rb +82 -0
- data/spec/faraday/utils_spec.rb +56 -0
- data/spec/faraday_spec.rb +37 -0
- data/spec/spec_helper.rb +63 -36
- data/spec/support/disabling_stub.rb +14 -0
- data/spec/support/fake_safe_buffer.rb +15 -0
- data/spec/support/helper_methods.rb +133 -0
- data/spec/support/shared_examples/adapter.rb +104 -0
- data/spec/support/shared_examples/params_encoder.rb +18 -0
- data/spec/support/shared_examples/request_method.rb +234 -0
- data/spec/support/streaming_response_checker.rb +35 -0
- data/spec/support/webmock_rack_app.rb +68 -0
- metadata +66 -38
- data/lib/faraday/deprecate.rb +0 -107
- data/lib/faraday/upload_io.rb +0 -67
- data/spec/faraday/deprecate_spec.rb +0 -69
- data/test/adapters/default_test.rb +0 -14
- data/test/adapters/em_http_test.rb +0 -30
- data/test/adapters/em_synchrony_test.rb +0 -32
- data/test/adapters/excon_test.rb +0 -30
- data/test/adapters/httpclient_test.rb +0 -34
- data/test/adapters/integration.rb +0 -263
- data/test/adapters/logger_test.rb +0 -136
- data/test/adapters/net_http_persistent_test.rb +0 -114
- data/test/adapters/net_http_test.rb +0 -79
- data/test/adapters/patron_test.rb +0 -40
- data/test/adapters/rack_test.rb +0 -38
- data/test/adapters/test_middleware_test.rb +0 -157
- data/test/adapters/typhoeus_test.rb +0 -38
- data/test/authentication_middleware_test.rb +0 -65
- data/test/composite_read_io_test.rb +0 -109
- data/test/connection_test.rb +0 -738
- data/test/env_test.rb +0 -268
- data/test/helper.rb +0 -75
- data/test/live_server.rb +0 -67
- data/test/middleware/instrumentation_test.rb +0 -88
- data/test/middleware/retry_test.rb +0 -282
- data/test/middleware_stack_test.rb +0 -260
- data/test/multibyte.txt +0 -1
- data/test/options_test.rb +0 -333
- data/test/parameters_test.rb +0 -157
- data/test/request_middleware_test.rb +0 -126
- data/test/response_middleware_test.rb +0 -72
- data/test/strawberry.rb +0 -2
- data/test/utils_test.rb +0 -98
@@ -0,0 +1,37 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.describe Faraday::ProxyOptions do
|
4
|
+
describe '#from' do
|
5
|
+
it 'works with string' do
|
6
|
+
options = Faraday::ProxyOptions.from 'http://user:pass@example.org'
|
7
|
+
expect(options.user).to eq('user')
|
8
|
+
expect(options.password).to eq('pass')
|
9
|
+
expect(options.uri).to be_a_kind_of(URI)
|
10
|
+
expect(options.path).to eq('')
|
11
|
+
expect(options.port).to eq(80)
|
12
|
+
expect(options.host).to eq('example.org')
|
13
|
+
expect(options.scheme).to eq('http')
|
14
|
+
expect(options.inspect).to match('#<Faraday::ProxyOptions uri=')
|
15
|
+
end
|
16
|
+
|
17
|
+
it 'works with nil' do
|
18
|
+
options = Faraday::ProxyOptions.from nil
|
19
|
+
expect(options).to be_a_kind_of(Faraday::ProxyOptions)
|
20
|
+
expect(options.inspect).to eq('#<Faraday::ProxyOptions (empty)>')
|
21
|
+
end
|
22
|
+
|
23
|
+
it 'works with no auth' do
|
24
|
+
proxy = Faraday::ProxyOptions.from 'http://example.org'
|
25
|
+
expect(proxy.user).to be_nil
|
26
|
+
expect(proxy.password).to be_nil
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
it 'allows hash access' do
|
31
|
+
proxy = Faraday::ProxyOptions.from 'http://a%40b:pw%20d@example.org'
|
32
|
+
expect(proxy.user).to eq('a@b')
|
33
|
+
expect(proxy[:user]).to eq('a@b')
|
34
|
+
expect(proxy.password).to eq('pw d')
|
35
|
+
expect(proxy[:password]).to eq('pw d')
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.describe Faraday::RequestOptions do
|
4
|
+
subject(:options) { Faraday::RequestOptions.new }
|
5
|
+
|
6
|
+
it 'allows to set the request proxy' do
|
7
|
+
expect(options.proxy).to be_nil
|
8
|
+
|
9
|
+
expect { options[:proxy] = { booya: 1 } }.to raise_error(NoMethodError)
|
10
|
+
|
11
|
+
options[:proxy] = { user: 'user' }
|
12
|
+
expect(options.proxy).to be_a_kind_of(Faraday::ProxyOptions)
|
13
|
+
expect(options.proxy.user).to eq('user')
|
14
|
+
|
15
|
+
options.proxy = nil
|
16
|
+
expect(options.proxy).to be_nil
|
17
|
+
expect(options.inspect).to eq('#<Faraday::RequestOptions (empty)>')
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'rack/utils'
|
4
|
+
|
5
|
+
RSpec.describe Faraday::FlatParamsEncoder do
|
6
|
+
it_behaves_like 'a params encoder'
|
7
|
+
|
8
|
+
it 'decodes arrays' do
|
9
|
+
query = 'a=one&a=two&a=three'
|
10
|
+
expected = { 'a' => %w[one two three] }
|
11
|
+
expect(subject.decode(query)).to eq(expected)
|
12
|
+
end
|
13
|
+
|
14
|
+
it 'decodes boolean values' do
|
15
|
+
query = 'a=true&b=false'
|
16
|
+
expected = { 'a' => 'true', 'b' => 'false' }
|
17
|
+
expect(subject.decode(query)).to eq(expected)
|
18
|
+
end
|
19
|
+
|
20
|
+
it 'encodes boolean values' do
|
21
|
+
params = { a: true, b: false }
|
22
|
+
expect(subject.encode(params)).to eq('a=true&b=false')
|
23
|
+
end
|
24
|
+
|
25
|
+
it 'encodes boolean values in array' do
|
26
|
+
params = { a: [true, false] }
|
27
|
+
expect(subject.encode(params)).to eq('a=true&a=false')
|
28
|
+
end
|
29
|
+
|
30
|
+
it 'encodes empty array in hash' do
|
31
|
+
params = { a: [] }
|
32
|
+
expect(subject.encode(params)).to eq('a=')
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,134 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'rack/utils'
|
4
|
+
|
5
|
+
RSpec.describe Faraday::NestedParamsEncoder do
|
6
|
+
it_behaves_like 'a params encoder'
|
7
|
+
|
8
|
+
it 'decodes arrays' do
|
9
|
+
query = 'a[1]=one&a[2]=two&a[3]=three'
|
10
|
+
expected = { 'a' => %w[one two three] }
|
11
|
+
expect(subject.decode(query)).to eq(expected)
|
12
|
+
end
|
13
|
+
|
14
|
+
it 'decodes hashes' do
|
15
|
+
query = 'a[b1]=one&a[b2]=two&a[b][c]=foo'
|
16
|
+
expected = { 'a' => { 'b1' => 'one', 'b2' => 'two', 'b' => { 'c' => 'foo' } } }
|
17
|
+
expect(subject.decode(query)).to eq(expected)
|
18
|
+
end
|
19
|
+
|
20
|
+
it 'decodes nested arrays rack compat' do
|
21
|
+
query = 'a[][one]=1&a[][two]=2&a[][one]=3&a[][two]=4'
|
22
|
+
expected = Rack::Utils.parse_nested_query(query)
|
23
|
+
expect(subject.decode(query)).to eq(expected)
|
24
|
+
end
|
25
|
+
|
26
|
+
it 'decodes nested array mixed types' do
|
27
|
+
query = 'a[][one]=1&a[]=2&a[]=&a[]'
|
28
|
+
expected = Rack::Utils.parse_nested_query(query)
|
29
|
+
expect(subject.decode(query)).to eq(expected)
|
30
|
+
end
|
31
|
+
|
32
|
+
it 'decodes nested ignores invalid array' do
|
33
|
+
query = '[][a]=1&b=2'
|
34
|
+
expected = { 'a' => '1', 'b' => '2' }
|
35
|
+
expect(subject.decode(query)).to eq(expected)
|
36
|
+
end
|
37
|
+
|
38
|
+
it 'decodes nested ignores repeated array notation' do
|
39
|
+
query = 'a[][][]=1'
|
40
|
+
expected = { 'a' => ['1'] }
|
41
|
+
expect(subject.decode(query)).to eq(expected)
|
42
|
+
end
|
43
|
+
|
44
|
+
it 'decodes nested ignores malformed keys' do
|
45
|
+
query = '=1&[]=2'
|
46
|
+
expected = {}
|
47
|
+
expect(subject.decode(query)).to eq(expected)
|
48
|
+
end
|
49
|
+
|
50
|
+
it 'decodes nested subkeys dont have to be in brackets' do
|
51
|
+
query = 'a[b]c[d]e=1'
|
52
|
+
expected = { 'a' => { 'b' => { 'c' => { 'd' => { 'e' => '1' } } } } }
|
53
|
+
expect(subject.decode(query)).to eq(expected)
|
54
|
+
end
|
55
|
+
|
56
|
+
it 'decodes nested final value overrides any type' do
|
57
|
+
query = 'a[b][c]=1&a[b]=2'
|
58
|
+
expected = { 'a' => { 'b' => '2' } }
|
59
|
+
expect(subject.decode(query)).to eq(expected)
|
60
|
+
end
|
61
|
+
|
62
|
+
it 'encodes rack compat' do
|
63
|
+
params = { a: [{ one: '1', two: '2' }, '3', ''] }
|
64
|
+
result = Faraday::Utils.unescape(Faraday::NestedParamsEncoder.encode(params)).split('&')
|
65
|
+
expected = Rack::Utils.build_nested_query(params).split('&')
|
66
|
+
expect(result).to match_array(expected)
|
67
|
+
end
|
68
|
+
|
69
|
+
it 'encodes empty string array value' do
|
70
|
+
expected = 'baz=&foo%5Bbar%5D='
|
71
|
+
result = Faraday::NestedParamsEncoder.encode(foo: { bar: '' }, baz: '')
|
72
|
+
expect(result).to eq(expected)
|
73
|
+
end
|
74
|
+
|
75
|
+
it 'encodes nil array value' do
|
76
|
+
expected = 'baz&foo%5Bbar%5D'
|
77
|
+
result = Faraday::NestedParamsEncoder.encode(foo: { bar: nil }, baz: nil)
|
78
|
+
expect(result).to eq(expected)
|
79
|
+
end
|
80
|
+
|
81
|
+
it 'encodes empty array value' do
|
82
|
+
expected = 'baz%5B%5D&foo%5Bbar%5D%5B%5D'
|
83
|
+
result = Faraday::NestedParamsEncoder.encode(foo: { bar: [] }, baz: [])
|
84
|
+
expect(result).to eq(expected)
|
85
|
+
end
|
86
|
+
|
87
|
+
it 'encodes boolean values' do
|
88
|
+
params = { a: true, b: false }
|
89
|
+
expect(subject.encode(params)).to eq('a=true&b=false')
|
90
|
+
end
|
91
|
+
|
92
|
+
it 'encodes boolean values in array' do
|
93
|
+
params = { a: [true, false] }
|
94
|
+
expect(subject.encode(params)).to eq('a%5B%5D=true&a%5B%5D=false')
|
95
|
+
end
|
96
|
+
|
97
|
+
shared_examples 'a wrong decoding' do
|
98
|
+
it do
|
99
|
+
expect { subject.decode(query) }.to raise_error(TypeError) do |e|
|
100
|
+
expect(e.message).to eq(error_message)
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
context 'when expecting hash but getting string' do
|
106
|
+
let(:query) { 'a=1&a[b]=2' }
|
107
|
+
let(:error_message) { "expected Hash (got String) for param `a'" }
|
108
|
+
it_behaves_like 'a wrong decoding'
|
109
|
+
end
|
110
|
+
|
111
|
+
context 'when expecting hash but getting array' do
|
112
|
+
let(:query) { 'a[]=1&a[b]=2' }
|
113
|
+
let(:error_message) { "expected Hash (got Array) for param `a'" }
|
114
|
+
it_behaves_like 'a wrong decoding'
|
115
|
+
end
|
116
|
+
|
117
|
+
context 'when expecting nested hash but getting non nested' do
|
118
|
+
let(:query) { 'a[b]=1&a[b][c]=2' }
|
119
|
+
let(:error_message) { "expected Hash (got String) for param `b'" }
|
120
|
+
it_behaves_like 'a wrong decoding'
|
121
|
+
end
|
122
|
+
|
123
|
+
context 'when expecting array but getting hash' do
|
124
|
+
let(:query) { 'a[b]=1&a[]=2' }
|
125
|
+
let(:error_message) { "expected Array (got Hash) for param `a'" }
|
126
|
+
it_behaves_like 'a wrong decoding'
|
127
|
+
end
|
128
|
+
|
129
|
+
context 'when expecting array but getting string' do
|
130
|
+
let(:query) { 'a=1&a[]=2' }
|
131
|
+
let(:error_message) { "expected Array (got String) for param `a'" }
|
132
|
+
it_behaves_like 'a wrong decoding'
|
133
|
+
end
|
134
|
+
end
|
@@ -0,0 +1,196 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.describe Faraday::RackBuilder do
|
4
|
+
# mock handler classes
|
5
|
+
(Handler = Struct.new(:app)).class_eval do
|
6
|
+
def call(env)
|
7
|
+
env[:request_headers]['X-Middleware'] ||= ''
|
8
|
+
env[:request_headers]['X-Middleware'] += ":#{self.class.name.split('::').last}"
|
9
|
+
app.call(env)
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
class Apple < Handler
|
14
|
+
end
|
15
|
+
class Orange < Handler
|
16
|
+
end
|
17
|
+
class Banana < Handler
|
18
|
+
end
|
19
|
+
|
20
|
+
class Broken < Faraday::Middleware
|
21
|
+
dependency 'zomg/i_dont/exist'
|
22
|
+
end
|
23
|
+
|
24
|
+
subject { conn.builder }
|
25
|
+
|
26
|
+
context 'with default stack' do
|
27
|
+
let(:conn) { Faraday::Connection.new }
|
28
|
+
|
29
|
+
it { expect(subject[0]).to eq(Faraday::Request.lookup_middleware(:url_encoded)) }
|
30
|
+
it { expect(subject.adapter).to eq(Faraday::Adapter.lookup_middleware(Faraday.default_adapter)) }
|
31
|
+
end
|
32
|
+
|
33
|
+
context 'with custom empty block' do
|
34
|
+
let(:conn) { Faraday::Connection.new {} }
|
35
|
+
|
36
|
+
it { expect(subject[0]).to be_nil }
|
37
|
+
it { expect(subject.adapter).to eq(Faraday::Adapter.lookup_middleware(Faraday.default_adapter)) }
|
38
|
+
end
|
39
|
+
|
40
|
+
context 'with custom adapter only' do
|
41
|
+
let(:conn) do
|
42
|
+
Faraday::Connection.new do |builder|
|
43
|
+
builder.adapter :test do |stub|
|
44
|
+
stub.get('/') { |_| [200, {}, ''] }
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
it { expect(subject[0]).to be_nil }
|
50
|
+
it { expect(subject.adapter).to eq(Faraday::Adapter.lookup_middleware(:test)) }
|
51
|
+
end
|
52
|
+
|
53
|
+
context 'with custom handler and adapter' do
|
54
|
+
let(:conn) do
|
55
|
+
Faraday::Connection.new do |builder|
|
56
|
+
builder.use Apple
|
57
|
+
builder.adapter :test do |stub|
|
58
|
+
stub.get('/') { |_| [200, {}, ''] }
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
it 'locks the stack after making a request' do
|
64
|
+
expect(subject.locked?).to be_falsey
|
65
|
+
conn.get('/')
|
66
|
+
expect(subject.locked?).to be_truthy
|
67
|
+
expect { subject.use(Orange) }.to raise_error(Faraday::RackBuilder::StackLocked)
|
68
|
+
end
|
69
|
+
|
70
|
+
it 'dup stack is unlocked' do
|
71
|
+
expect(subject.locked?).to be_falsey
|
72
|
+
subject.lock!
|
73
|
+
expect(subject.locked?).to be_truthy
|
74
|
+
dup = subject.dup
|
75
|
+
expect(dup).to eq(subject)
|
76
|
+
expect(dup.locked?).to be_falsey
|
77
|
+
end
|
78
|
+
|
79
|
+
it 'allows to compare handlers' do
|
80
|
+
expect(subject.handlers.first).to eq(Faraday::RackBuilder::Handler.new(Apple))
|
81
|
+
end
|
82
|
+
end
|
83
|
+
|
84
|
+
context 'when having a single handler' do
|
85
|
+
let(:conn) { Faraday::Connection.new {} }
|
86
|
+
|
87
|
+
before { subject.use(Apple) }
|
88
|
+
|
89
|
+
it { expect(subject.handlers).to eq([Apple]) }
|
90
|
+
|
91
|
+
it 'allows rebuilding' do
|
92
|
+
subject.build do |builder|
|
93
|
+
builder.use(Orange)
|
94
|
+
end
|
95
|
+
expect(subject.handlers).to eq([Orange])
|
96
|
+
end
|
97
|
+
|
98
|
+
it 'allows use' do
|
99
|
+
subject.use(Orange)
|
100
|
+
expect(subject.handlers).to eq([Apple, Orange])
|
101
|
+
end
|
102
|
+
|
103
|
+
it 'allows insert_before' do
|
104
|
+
subject.insert_before(Apple, Orange)
|
105
|
+
expect(subject.handlers).to eq([Orange, Apple])
|
106
|
+
end
|
107
|
+
|
108
|
+
it 'allows insert_after' do
|
109
|
+
subject.insert_after(Apple, Orange)
|
110
|
+
expect(subject.handlers).to eq([Apple, Orange])
|
111
|
+
end
|
112
|
+
|
113
|
+
it 'raises an error trying to use an unregistered symbol' do
|
114
|
+
expect { subject.use(:apple) }.to raise_error(Faraday::Error) do |err|
|
115
|
+
expect(err.message).to eq(':apple is not registered on Faraday::Middleware')
|
116
|
+
end
|
117
|
+
end
|
118
|
+
end
|
119
|
+
|
120
|
+
context 'with custom registered middleware' do
|
121
|
+
let(:conn) { Faraday::Connection.new {} }
|
122
|
+
|
123
|
+
after { Faraday::Middleware.unregister_middleware(:apple) }
|
124
|
+
|
125
|
+
it 'allows to register with constant' do
|
126
|
+
Faraday::Middleware.register_middleware(apple: Apple)
|
127
|
+
subject.use(:apple)
|
128
|
+
expect(subject.handlers).to eq([Apple])
|
129
|
+
end
|
130
|
+
|
131
|
+
it 'allows to register with symbol' do
|
132
|
+
Faraday::Middleware.register_middleware(apple: :Apple)
|
133
|
+
subject.use(:apple)
|
134
|
+
expect(subject.handlers).to eq([Apple])
|
135
|
+
end
|
136
|
+
|
137
|
+
it 'allows to register with string' do
|
138
|
+
Faraday::Middleware.register_middleware(apple: 'Apple')
|
139
|
+
subject.use(:apple)
|
140
|
+
expect(subject.handlers).to eq([Apple])
|
141
|
+
end
|
142
|
+
|
143
|
+
it 'allows to register with Proc' do
|
144
|
+
Faraday::Middleware.register_middleware(apple: -> { Apple })
|
145
|
+
subject.use(:apple)
|
146
|
+
expect(subject.handlers).to eq([Apple])
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
context 'when having two handlers' do
|
151
|
+
let(:conn) { Faraday::Connection.new {} }
|
152
|
+
|
153
|
+
before do
|
154
|
+
subject.use(Apple)
|
155
|
+
subject.use(Orange)
|
156
|
+
end
|
157
|
+
|
158
|
+
it 'allows insert_before' do
|
159
|
+
subject.insert_before(Orange, Banana)
|
160
|
+
expect(subject.handlers).to eq([Apple, Banana, Orange])
|
161
|
+
end
|
162
|
+
|
163
|
+
it 'allows insert_after' do
|
164
|
+
subject.insert_after(Apple, Banana)
|
165
|
+
expect(subject.handlers).to eq([Apple, Banana, Orange])
|
166
|
+
end
|
167
|
+
|
168
|
+
it 'allows to swap handlers' do
|
169
|
+
subject.swap(Apple, Banana)
|
170
|
+
expect(subject.handlers).to eq([Banana, Orange])
|
171
|
+
end
|
172
|
+
|
173
|
+
it 'allows to delete a handler' do
|
174
|
+
subject.delete(Apple)
|
175
|
+
expect(subject.handlers).to eq([Orange])
|
176
|
+
end
|
177
|
+
end
|
178
|
+
|
179
|
+
context 'when having a handler with broken dependency' do
|
180
|
+
let(:conn) do
|
181
|
+
Faraday::Connection.new do |builder|
|
182
|
+
builder.adapter :test do |stub|
|
183
|
+
stub.get('/') { |_| [200, {}, ''] }
|
184
|
+
end
|
185
|
+
end
|
186
|
+
end
|
187
|
+
|
188
|
+
before { subject.use(Broken) }
|
189
|
+
|
190
|
+
it 'raises an error while making a request' do
|
191
|
+
expect { conn.get('/') }.to raise_error(RuntimeError) do |err|
|
192
|
+
expect(err.message).to match(%r{missing dependency for Broken: .+ -- zomg/i_dont/exist})
|
193
|
+
end
|
194
|
+
end
|
195
|
+
end
|
196
|
+
end
|
@@ -0,0 +1,88 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.describe Faraday::Request::Authorization do
|
4
|
+
let(:conn) do
|
5
|
+
Faraday.new do |b|
|
6
|
+
b.request auth_type, *auth_config
|
7
|
+
b.adapter :test do |stub|
|
8
|
+
stub.get('/auth-echo') do |env|
|
9
|
+
[200, {}, env[:request_headers]['Authorization']]
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
shared_examples 'does not interfere with existing authentication' do
|
16
|
+
context 'and request already has an authentication header' do
|
17
|
+
let(:response) { conn.get('/auth-echo', nil, authorization: 'Token token="bar"') }
|
18
|
+
|
19
|
+
it 'does not interfere with existing authorization' do
|
20
|
+
expect(response.body).to eq('Token token="bar"')
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
let(:response) { conn.get('/auth-echo') }
|
26
|
+
|
27
|
+
describe 'basic_auth' do
|
28
|
+
let(:auth_type) { :basic_auth }
|
29
|
+
|
30
|
+
context 'when passed correct params' do
|
31
|
+
let(:auth_config) { %w[aladdin opensesame] }
|
32
|
+
|
33
|
+
it { expect(response.body).to eq('Basic YWxhZGRpbjpvcGVuc2VzYW1l') }
|
34
|
+
|
35
|
+
include_examples 'does not interfere with existing authentication'
|
36
|
+
end
|
37
|
+
|
38
|
+
context 'when passed very long values' do
|
39
|
+
let(:auth_config) { ['A' * 255, ''] }
|
40
|
+
|
41
|
+
it { expect(response.body).to eq("Basic #{'QUFB' * 85}Og==") }
|
42
|
+
|
43
|
+
include_examples 'does not interfere with existing authentication'
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
describe 'token_auth' do
|
48
|
+
let(:auth_type) { :token_auth }
|
49
|
+
|
50
|
+
context 'when passed correct params' do
|
51
|
+
let(:auth_config) { 'quux' }
|
52
|
+
|
53
|
+
it { expect(response.body).to eq('Token token="quux"') }
|
54
|
+
|
55
|
+
include_examples 'does not interfere with existing authentication'
|
56
|
+
end
|
57
|
+
|
58
|
+
context 'when other values are provided' do
|
59
|
+
let(:auth_config) { ['baz', foo: 42] }
|
60
|
+
|
61
|
+
it { expect(response.body).to match(/^Token /) }
|
62
|
+
it { expect(response.body).to match(/token="baz"/) }
|
63
|
+
it { expect(response.body).to match(/foo="42"/) }
|
64
|
+
|
65
|
+
include_examples 'does not interfere with existing authentication'
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
describe 'authorization' do
|
70
|
+
let(:auth_type) { :authorization }
|
71
|
+
|
72
|
+
context 'when passed two strings' do
|
73
|
+
let(:auth_config) { ['custom', 'abc def'] }
|
74
|
+
|
75
|
+
it { expect(response.body).to eq('custom abc def') }
|
76
|
+
|
77
|
+
include_examples 'does not interfere with existing authentication'
|
78
|
+
end
|
79
|
+
|
80
|
+
context 'when passed a string and a hash' do
|
81
|
+
let(:auth_config) { ['baz', foo: 42] }
|
82
|
+
|
83
|
+
it { expect(response.body).to eq('baz foo="42"') }
|
84
|
+
|
85
|
+
include_examples 'does not interfere with existing authentication'
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|