files.com 1.0.486 → 1.0.487
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/_VERSION +1 -1
- data/lib/files.com/api_client.rb +9 -6
- data/lib/files.com/version.rb +1 -1
- data/spec/lib/api_client_spec.rb +5 -6
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b7b26950c315d418ad5a98128863c5e09a92513a6b61c69c0f124355c50979fa
|
4
|
+
data.tar.gz: 35d0001958e3d7cd9c683ab85c13c7068284a281701f9848b3ab3a10f03c21ce
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 17f5f0610765f124fa5b9612169094e5523da4b5acadb80a4274bacf5ef4c65a35506dac1474a71c21366581453c1e56d8ac7ab5fb576ef20fd2ac20a3f7bdf9
|
7
|
+
data.tar.gz: 70990797609a9c7017fa96d260d358418bf30d0a11a4b503a26534df0cb66c64d11f801f0e7796c1dd8e7916a2b2e83e339bf2adce44d1c492704a9ccf392dc3
|
data/_VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
1.0.
|
1
|
+
1.0.487
|
data/lib/files.com/api_client.rb
CHANGED
@@ -235,10 +235,13 @@ module Files
|
|
235
235
|
end
|
236
236
|
|
237
237
|
case e
|
238
|
-
when Faraday::ClientError
|
239
|
-
|
240
|
-
|
241
|
-
|
238
|
+
when Faraday::ClientError, Faraday::ServerError
|
239
|
+
if e.response
|
240
|
+
handle_error_response(e.response, error_context)
|
241
|
+
else
|
242
|
+
handle_network_error(e, error_context, num_retries, base_url)
|
243
|
+
end
|
244
|
+
|
242
245
|
else
|
243
246
|
raise
|
244
247
|
end
|
@@ -299,10 +302,10 @@ module Files
|
|
299
302
|
end
|
300
303
|
end
|
301
304
|
|
302
|
-
private def handle_network_error(error,
|
305
|
+
private def handle_network_error(error, context, num_retries, base_url = nil)
|
303
306
|
base_url ||= Files.base_url
|
304
307
|
|
305
|
-
Util.log_error("Network error", error_message: error.message)
|
308
|
+
Util.log_error("Network error", error_message: error.message, request_id: context.request_id)
|
306
309
|
message = "Could not connect to Files.com at URL #{base_url}. Please check your internet connection and try again. If this problem persists, you should check Files.com's service status at https://status.files.com, or contact your primary account representative."
|
307
310
|
message += " Request was retried #{num_retries} times." if num_retries > 0
|
308
311
|
message += "\n\n(Network error: #{error.message})"
|
data/lib/files.com/version.rb
CHANGED
data/spec/lib/api_client_spec.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
require "spec_helper"
|
2
|
-
require "pry"
|
3
2
|
|
4
3
|
RSpec.describe Files::ApiClient do
|
5
4
|
let(:subject) { described_class.new }
|
@@ -9,22 +8,22 @@ RSpec.describe Files::ApiClient do
|
|
9
8
|
|
10
9
|
shared_examples 'a server error handler' do
|
11
10
|
before do
|
12
|
-
allow(subject).to receive(:log_request).and_raise(Faraday::ServerError.new('
|
11
|
+
allow(subject).to receive(:log_request).and_raise(Faraday::ServerError.new('', mock_response))
|
13
12
|
end
|
14
13
|
|
15
|
-
it 'retries with sleeps and raises general api
|
14
|
+
it 'retries with sleeps and raises general api error' do
|
16
15
|
expect(subject).to receive(:sleep).with(0.5).ordered
|
17
16
|
expect(subject).to receive(:sleep).with(be_between(0.5, 1)).ordered
|
18
17
|
expect(subject).to receive(:sleep).with(be_between(1, 2)).ordered
|
19
18
|
expect {
|
20
19
|
subject.execute_request_with_rescues(1, context) { 'empty block' }
|
21
|
-
}.to raise_error(Files::
|
20
|
+
}.to raise_error(Files::APIError, error_message)
|
22
21
|
end
|
23
22
|
end
|
24
23
|
|
25
24
|
context 'when response is a valid json' do
|
26
25
|
it_behaves_like 'a server error handler' do
|
27
|
-
let(:error_message) { "
|
26
|
+
let(:error_message) { "Server Error" }
|
28
27
|
let(:mock_response) { { status: 502, headers: {}, body: { error: error_message }.to_json } }
|
29
28
|
end
|
30
29
|
end
|
@@ -38,7 +37,7 @@ RSpec.describe Files::ApiClient do
|
|
38
37
|
body: "<html><head><title>502 Bad Gateway</title></head><body><center><h1>502 Bad Gateway</h1></center><hr><center>files.com</center></body></html>"
|
39
38
|
}
|
40
39
|
}
|
41
|
-
let(:error_message) { "
|
40
|
+
let(:error_message) { "Unexpected response object from API: \"#{mock_response[:body]}\" (HTTP response code was 502)" }
|
42
41
|
end
|
43
42
|
end
|
44
43
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: files.com
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.487
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- files.com
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-11-
|
11
|
+
date: 2023-11-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: addressable
|