Add retry support & redirect following
This commit is contained in:
parent
30881d7169
commit
1819e16f19
1
Gemfile
1
Gemfile
|
@ -10,6 +10,7 @@ gem 'faraday', '>= 0.9.0'
|
||||||
gem 'multi_json', '>= 1.0.0'
|
gem 'multi_json', '>= 1.0.0'
|
||||||
gem 'extlib', '>= 0.9.15'
|
gem 'extlib', '>= 0.9.15'
|
||||||
gem 'jwt', '~> 0.1.5'
|
gem 'jwt', '~> 0.1.5'
|
||||||
|
gem 'retriable', '>= 1.4'
|
||||||
gem 'jruby-openssl', :platforms => :jruby
|
gem 'jruby-openssl', :platforms => :jruby
|
||||||
|
|
||||||
group :development do
|
group :development do
|
||||||
|
|
|
@ -17,6 +17,7 @@ require 'faraday'
|
||||||
require 'multi_json'
|
require 'multi_json'
|
||||||
require 'compat/multi_json'
|
require 'compat/multi_json'
|
||||||
require 'stringio'
|
require 'stringio'
|
||||||
|
require 'retriable'
|
||||||
|
|
||||||
require 'google/api_client/version'
|
require 'google/api_client/version'
|
||||||
require 'google/api_client/logging'
|
require 'google/api_client/logging'
|
||||||
|
@ -107,6 +108,7 @@ module Google
|
||||||
self.auto_refresh_token = options.fetch(:auto_refresh_token) { true }
|
self.auto_refresh_token = options.fetch(:auto_refresh_token) { true }
|
||||||
self.key = options[:key]
|
self.key = options[:key]
|
||||||
self.user_ip = options[:user_ip]
|
self.user_ip = options[:user_ip]
|
||||||
|
self.retries = options.fetch(:retries) { 0 }
|
||||||
@discovery_uris = {}
|
@discovery_uris = {}
|
||||||
@discovery_documents = {}
|
@discovery_documents = {}
|
||||||
@discovered_apis = {}
|
@discovered_apis = {}
|
||||||
|
@ -230,6 +232,13 @@ module Google
|
||||||
# The base path. Should almost always be '/discovery/v1'.
|
# The base path. Should almost always be '/discovery/v1'.
|
||||||
attr_accessor :discovery_path
|
attr_accessor :discovery_path
|
||||||
|
|
||||||
|
##
|
||||||
|
# Number of times to retry on recoverable errors
|
||||||
|
#
|
||||||
|
# @return [FixNum]
|
||||||
|
# Number of retries
|
||||||
|
attr_accessor :retries
|
||||||
|
|
||||||
##
|
##
|
||||||
# Returns the URI for the directory document.
|
# Returns the URI for the directory document.
|
||||||
#
|
#
|
||||||
|
@ -424,6 +433,8 @@ module Google
|
||||||
# Verifies an ID token against a server certificate. Used to ensure that
|
# Verifies an ID token against a server certificate. Used to ensure that
|
||||||
# an ID token supplied by an untrusted client-side mechanism is valid.
|
# an ID token supplied by an untrusted client-side mechanism is valid.
|
||||||
# Raises an error if the token is invalid or missing.
|
# Raises an error if the token is invalid or missing.
|
||||||
|
#
|
||||||
|
# @deprecated Use the google-id-token gem for verifying JWTs
|
||||||
def verify_id_token!
|
def verify_id_token!
|
||||||
require 'jwt'
|
require 'jwt'
|
||||||
require 'openssl'
|
require 'openssl'
|
||||||
|
@ -533,6 +544,8 @@ module Google
|
||||||
# authenticated, `false` otherwise.
|
# authenticated, `false` otherwise.
|
||||||
# - (TrueClass, FalseClass) :gzip (default: true) -
|
# - (TrueClass, FalseClass) :gzip (default: true) -
|
||||||
# `true` if gzip enabled, `false` otherwise.
|
# `true` if gzip enabled, `false` otherwise.
|
||||||
|
# - (FixNum) :retries -
|
||||||
|
# # of times to retry on recoverable errors
|
||||||
#
|
#
|
||||||
# @return [Google::APIClient::Result] The result from the API, nil if batch.
|
# @return [Google::APIClient::Result] The result from the API, nil if batch.
|
||||||
#
|
#
|
||||||
|
@ -547,7 +560,7 @@ module Google
|
||||||
# )
|
# )
|
||||||
#
|
#
|
||||||
# @see Google::APIClient#generate_request
|
# @see Google::APIClient#generate_request
|
||||||
def execute(*params)
|
def execute!(*params)
|
||||||
if params.first.kind_of?(Google::APIClient::Request)
|
if params.first.kind_of?(Google::APIClient::Request)
|
||||||
request = params.shift
|
request = params.shift
|
||||||
options = params.shift || {}
|
options = params.shift || {}
|
||||||
|
@ -572,49 +585,56 @@ module Google
|
||||||
|
|
||||||
request.headers['User-Agent'] ||= '' + self.user_agent unless self.user_agent.nil?
|
request.headers['User-Agent'] ||= '' + self.user_agent unless self.user_agent.nil?
|
||||||
request.headers['Accept-Encoding'] ||= 'gzip' unless options[:gzip] == false
|
request.headers['Accept-Encoding'] ||= 'gzip' unless options[:gzip] == false
|
||||||
|
request.headers['Content-Type'] ||= ''
|
||||||
request.parameters['key'] ||= self.key unless self.key.nil?
|
request.parameters['key'] ||= self.key unless self.key.nil?
|
||||||
request.parameters['userIp'] ||= self.user_ip unless self.user_ip.nil?
|
request.parameters['userIp'] ||= self.user_ip unless self.user_ip.nil?
|
||||||
|
|
||||||
connection = options[:connection] || self.connection
|
connection = options[:connection] || self.connection
|
||||||
request.authorization = options[:authorization] || self.authorization unless options[:authenticated] == false
|
request.authorization = options[:authorization] || self.authorization unless options[:authenticated] == false
|
||||||
|
tries = 1 + (options[:retries] || self.retries)
|
||||||
|
Retriable.retriable :tries => tries,
|
||||||
|
:on => [TransmissionError],
|
||||||
|
:interval => lambda {|attempts| (2 ** attempts) + Random.rand} do
|
||||||
|
result = request.send(connection, true)
|
||||||
|
|
||||||
result = request.send(connection)
|
case result.status
|
||||||
|
when 200...300
|
||||||
|
result
|
||||||
|
when 301, 302, 303, 307
|
||||||
|
request = generate_request(request.to_hash.merge({
|
||||||
|
:uri => result.headers['location'],
|
||||||
|
:api_method => nil
|
||||||
|
}))
|
||||||
|
raise RedirectError.new(result.headers['location'], result)
|
||||||
|
when 400...500
|
||||||
if result.status == 401 && request.authorization.respond_to?(:refresh_token) && auto_refresh_token
|
if result.status == 401 && request.authorization.respond_to?(:refresh_token) && auto_refresh_token
|
||||||
begin
|
begin
|
||||||
logger.debug("Attempting refresh of access token & retry of request")
|
logger.debug("Attempting refresh of access token & retry of request")
|
||||||
request.authorization.fetch_access_token!
|
request.authorization.fetch_access_token!
|
||||||
result = request.send(connection, true)
|
|
||||||
rescue Signet::AuthorizationError
|
rescue Signet::AuthorizationError
|
||||||
# Ignore since we want the original error
|
# Ignore since we want the original error
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
raise ClientError.new(result.error_message || "A client error has occurred", result)
|
||||||
return result
|
when 500...600
|
||||||
|
raise ServerError.new(result.error_message || "A server error has occurred", result)
|
||||||
|
else
|
||||||
|
raise TransmissionError.new(result.error_message || "A transmission error has occurred", result)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
##
|
##
|
||||||
# Same as Google::APIClient#execute, but raises an exception if there was
|
# Same as Google::APIClient#execute!, but does not raise an exception for
|
||||||
# an error.
|
# normal API errros.
|
||||||
#
|
#
|
||||||
# @see Google::APIClient#execute
|
# @see Google::APIClient#execute
|
||||||
def execute!(*params)
|
def execute(*params)
|
||||||
result = self.execute(*params)
|
begin
|
||||||
if result.error?
|
return self.execute!(*params)
|
||||||
error_message = result.error_message
|
rescue TransmissionError => e
|
||||||
case result.response.status
|
return e.result
|
||||||
when 400...500
|
|
||||||
exception_type = ClientError
|
|
||||||
error_message ||= "A client error has occurred."
|
|
||||||
when 500...600
|
|
||||||
exception_type = ServerError
|
|
||||||
error_message ||= "A server error has occurred."
|
|
||||||
else
|
|
||||||
exception_type = TransmissionError
|
|
||||||
error_message ||= "A transmission error has occurred."
|
|
||||||
end
|
end
|
||||||
raise exception_type, error_message
|
|
||||||
end
|
|
||||||
return result
|
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
@ -646,6 +666,7 @@ module Google
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
require 'google/api_client/version'
|
require 'google/api_client/version'
|
||||||
|
|
|
@ -19,6 +19,17 @@ module Google
|
||||||
# An error which is raised when there is an unexpected response or other
|
# An error which is raised when there is an unexpected response or other
|
||||||
# transport error that prevents an operation from succeeding.
|
# transport error that prevents an operation from succeeding.
|
||||||
class TransmissionError < StandardError
|
class TransmissionError < StandardError
|
||||||
|
attr_reader :result
|
||||||
|
def initialize(message = nil, result = nil)
|
||||||
|
super(message)
|
||||||
|
@result = result
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# An exception that is raised if a redirect is required
|
||||||
|
#
|
||||||
|
class RedirectError < TransmissionError
|
||||||
end
|
end
|
||||||
|
|
||||||
##
|
##
|
||||||
|
|
|
@ -89,6 +89,7 @@ describe Google::APIClient do
|
||||||
|
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/discovery/v1/apis/prediction/v1.2/rest?userIp=127.0.0.1') do |env|
|
stub.get('/discovery/v1/apis/prediction/v1.2/rest?userIp=127.0.0.1') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
CLIENT.execute(
|
CLIENT.execute(
|
||||||
|
@ -104,6 +105,7 @@ describe Google::APIClient do
|
||||||
CLIENT.key = 'qwerty'
|
CLIENT.key = 'qwerty'
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/discovery/v1/apis/prediction/v1.2/rest?key=qwerty') do |env|
|
stub.get('/discovery/v1/apis/prediction/v1.2/rest?key=qwerty') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -120,6 +122,7 @@ describe Google::APIClient do
|
||||||
CLIENT.user_ip = '127.0.0.1'
|
CLIENT.user_ip = '127.0.0.1'
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/discovery/v1/apis/prediction/v1.2/rest?key=qwerty&userIp=127.0.0.1') do |env|
|
stub.get('/discovery/v1/apis/prediction/v1.2/rest?key=qwerty&userIp=127.0.0.1') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -187,6 +190,7 @@ describe Google::APIClient do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
||||||
env[:body].should == ''
|
env[:body].should == ''
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -204,6 +208,7 @@ describe Google::APIClient do
|
||||||
# to a CGI-escaped semicolon (%3B) instead.
|
# to a CGI-escaped semicolon (%3B) instead.
|
||||||
stub.post('/prediction/v1.2/training?data=12345%3B67890') do |env|
|
stub.post('/prediction/v1.2/training?data=12345%3B67890') do |env|
|
||||||
env[:body].should == ''
|
env[:body].should == ''
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -218,6 +223,7 @@ describe Google::APIClient do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.2/training?data=1&data=2') do |env|
|
stub.post('/prediction/v1.2/training?data=1&data=2') do |env|
|
||||||
env.params['data'].should include('1', '2')
|
env.params['data'].should include('1', '2')
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -231,6 +237,7 @@ describe Google::APIClient do
|
||||||
it 'should generate requests against the correct URIs' do
|
it 'should generate requests against the correct URIs' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -244,6 +251,7 @@ describe Google::APIClient do
|
||||||
it 'should generate requests against the correct URIs' do
|
it 'should generate requests against the correct URIs' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -264,6 +272,7 @@ describe Google::APIClient do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.2/training') do |env|
|
stub.post('/prediction/v1.2/training') do |env|
|
||||||
env[:url].host.should == 'testing-domain.example.com'
|
env[:url].host.should == 'testing-domain.example.com'
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -284,6 +293,7 @@ describe Google::APIClient do
|
||||||
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
||||||
env[:request_headers].should have_key('Authorization')
|
env[:request_headers].should have_key('Authorization')
|
||||||
env[:request_headers]['Authorization'].should =~ /^OAuth/
|
env[:request_headers]['Authorization'].should =~ /^OAuth/
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -303,6 +313,7 @@ describe Google::APIClient do
|
||||||
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
||||||
env[:request_headers].should have_key('Authorization')
|
env[:request_headers].should have_key('Authorization')
|
||||||
env[:request_headers]['Authorization'].should =~ /^Bearer/
|
env[:request_headers]['Authorization'].should =~ /^Bearer/
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -363,6 +374,7 @@ describe Google::APIClient do
|
||||||
stub.post('/prediction/v1.2/training') do |env|
|
stub.post('/prediction/v1.2/training') do |env|
|
||||||
env[:request_headers].should have_key('Content-Type')
|
env[:request_headers].should have_key('Content-Type')
|
||||||
env[:request_headers]['Content-Type'].should == 'application/json'
|
env[:request_headers]['Content-Type'].should == 'application/json'
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
CLIENT.authorization = :oauth_2
|
CLIENT.authorization = :oauth_2
|
||||||
|
@ -415,6 +427,7 @@ describe Google::APIClient do
|
||||||
it 'should generate requests against the correct URIs' do
|
it 'should generate requests against the correct URIs' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/plus/v1/people/107807692475771887386/activities/public') do |env|
|
stub.get('/plus/v1/people/107807692475771887386/activities/public') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -485,6 +498,7 @@ describe Google::APIClient do
|
||||||
it 'should generate requests against the correct URIs' do
|
it 'should generate requests against the correct URIs' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/adsense/v1.3/adclients') do |env|
|
stub.get('/adsense/v1.3/adclients') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
@ -515,6 +529,7 @@ describe Google::APIClient do
|
||||||
it 'should succeed when validating parameters in a correct call' do
|
it 'should succeed when validating parameters in a correct call' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/adsense/v1.3/reports?dimension=DATE&endDate=2010-01-01&metric=PAGE_VIEWS&startDate=2000-01-01') do |env|
|
stub.get('/adsense/v1.3/reports?dimension=DATE&endDate=2010-01-01&metric=PAGE_VIEWS&startDate=2000-01-01') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
(lambda do
|
(lambda do
|
||||||
|
@ -553,6 +568,7 @@ describe Google::APIClient do
|
||||||
stub.get('/adsense/v1.3/reports?dimension=DATE&dimension=PRODUCT_CODE'+
|
stub.get('/adsense/v1.3/reports?dimension=DATE&dimension=PRODUCT_CODE'+
|
||||||
'&endDate=2010-01-01&metric=CLICKS&metric=PAGE_VIEWS&'+
|
'&endDate=2010-01-01&metric=CLICKS&metric=PAGE_VIEWS&'+
|
||||||
'startDate=2000-01-01') do |env|
|
'startDate=2000-01-01') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
(lambda do
|
(lambda do
|
||||||
|
@ -593,6 +609,7 @@ describe Google::APIClient do
|
||||||
'startDate=2000-01-01') do |env|
|
'startDate=2000-01-01') do |env|
|
||||||
env.params['dimension'].should include('DATE', 'PRODUCT_CODE')
|
env.params['dimension'].should include('DATE', 'PRODUCT_CODE')
|
||||||
env.params['metric'].should include('CLICKS', 'PAGE_VIEWS')
|
env.params['metric'].should include('CLICKS', 'PAGE_VIEWS')
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
request = CLIENT.execute(
|
request = CLIENT.execute(
|
||||||
|
|
|
@ -49,6 +49,7 @@ describe Google::APIClient::Service do
|
||||||
it 'should make a valid call for a method with no parameters' do
|
it 'should make a valid call for a method with no parameters' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/adsense/v1.3/adclients') do |env|
|
stub.get('/adsense/v1.3/adclients') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
adsense = Google::APIClient::Service.new(
|
adsense = Google::APIClient::Service.new(
|
||||||
|
@ -69,6 +70,7 @@ describe Google::APIClient::Service do
|
||||||
it 'should make a valid call for a method with parameters' do
|
it 'should make a valid call for a method with parameters' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/adsense/v1.3/adclients/1/adunits') do |env|
|
stub.get('/adsense/v1.3/adclients/1/adunits') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
adsense = Google::APIClient::Service.new(
|
adsense = Google::APIClient::Service.new(
|
||||||
|
@ -87,6 +89,7 @@ describe Google::APIClient::Service do
|
||||||
it 'should make a valid call for a deep method' do
|
it 'should make a valid call for a deep method' do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.get('/adsense/v1.3/accounts/1/adclients') do |env|
|
stub.get('/adsense/v1.3/accounts/1/adclients') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
adsense = Google::APIClient::Service.new(
|
adsense = Google::APIClient::Service.new(
|
||||||
|
@ -147,6 +150,7 @@ describe Google::APIClient::Service do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.5/trainedmodels?project=1') do |env|
|
stub.post('/prediction/v1.5/trainedmodels?project=1') do |env|
|
||||||
env.body.should == '{"id":"1"}'
|
env.body.should == '{"id":"1"}'
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
prediction = Google::APIClient::Service.new(
|
prediction = Google::APIClient::Service.new(
|
||||||
|
@ -167,6 +171,7 @@ describe Google::APIClient::Service do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.5/trainedmodels?project=1') do |env|
|
stub.post('/prediction/v1.5/trainedmodels?project=1') do |env|
|
||||||
env.body.should == '{"id":"1"}'
|
env.body.should == '{"id":"1"}'
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
prediction = Google::APIClient::Service.new(
|
prediction = Google::APIClient::Service.new(
|
||||||
|
@ -224,6 +229,7 @@ describe Google::APIClient::Service do
|
||||||
conn = stub_connection do |stub|
|
conn = stub_connection do |stub|
|
||||||
stub.post('/upload/drive/v1/files?uploadType=multipart') do |env|
|
stub.post('/upload/drive/v1/files?uploadType=multipart') do |env|
|
||||||
env.body.should be_a Faraday::CompositeReadIO
|
env.body.should be_a Faraday::CompositeReadIO
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
drive = Google::APIClient::Service.new(
|
drive = Google::APIClient::Service.new(
|
||||||
|
|
|
@ -114,6 +114,7 @@ describe Google::APIClient do
|
||||||
@connection = stub_connection do |stub|
|
@connection = stub_connection do |stub|
|
||||||
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
stub.post('/prediction/v1.2/training?data=12345') do |env|
|
||||||
env[:request_headers]['Authorization'].should == 'Bearer 12345'
|
env[:request_headers]['Authorization'].should == 'Bearer 12345'
|
||||||
|
[200, {}, '{}']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -166,4 +167,87 @@ describe Google::APIClient do
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe 'when retiries enabled' do
|
||||||
|
before do
|
||||||
|
client.retries = 2
|
||||||
|
end
|
||||||
|
|
||||||
|
after do
|
||||||
|
@connection.verify
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'should follow redirects' do
|
||||||
|
client.authorization = nil
|
||||||
|
@connection = stub_connection do |stub|
|
||||||
|
stub.get('/foo') do |env|
|
||||||
|
[302, {'location' => 'https://www.google.com/bar'}, '{}']
|
||||||
|
end
|
||||||
|
stub.get('/bar') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
client.execute(
|
||||||
|
:uri => 'https://www.gogole.com/foo',
|
||||||
|
:connection => @connection
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'should refresh tokens on 401 tokens' do
|
||||||
|
client.authorization.access_token = '12345'
|
||||||
|
expect(client.authorization).to receive(:fetch_access_token!)
|
||||||
|
|
||||||
|
@connection = stub_connection do |stub|
|
||||||
|
stub.get('/foo') do |env|
|
||||||
|
[401, {}, '{}']
|
||||||
|
end
|
||||||
|
stub.get('/foo') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
client.execute(
|
||||||
|
:uri => 'https://www.gogole.com/foo',
|
||||||
|
:connection => @connection
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'should retry on 500 errors' do
|
||||||
|
client.authorization = nil
|
||||||
|
|
||||||
|
@connection = stub_connection do |stub|
|
||||||
|
stub.get('/foo') do |env|
|
||||||
|
[500, {}, '{}']
|
||||||
|
end
|
||||||
|
stub.get('/foo') do |env|
|
||||||
|
[200, {}, '{}']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
client.execute(
|
||||||
|
:uri => 'https://www.gogole.com/foo',
|
||||||
|
:connection => @connection
|
||||||
|
).status.should == 200
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'should fail after max retries' do
|
||||||
|
client.authorization = nil
|
||||||
|
count = 0
|
||||||
|
@connection = stub_connection do |stub|
|
||||||
|
stub.get('/foo') do |env|
|
||||||
|
count += 1
|
||||||
|
[500, {}, '{}']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
client.execute(
|
||||||
|
:uri => 'https://www.gogole.com/foo',
|
||||||
|
:connection => @connection
|
||||||
|
).status.should == 500
|
||||||
|
count.should == 3
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue