add a default timeout to 10s on connections
This commit is contained in:
parent
7cf5cb565c
commit
06599f48bc
1 changed files with 6 additions and 2 deletions
|
|
@ -165,6 +165,7 @@ class StandardBrowser(mechanize.Browser):
|
||||||
SAVE_RESPONSES = False
|
SAVE_RESPONSES = False
|
||||||
DEBUG_HTTP = False
|
DEBUG_HTTP = False
|
||||||
DEBUG_MECHANIZE = False
|
DEBUG_MECHANIZE = False
|
||||||
|
DEFAULT_TIMEOUT = 10
|
||||||
|
|
||||||
responses_dirname = None
|
responses_dirname = None
|
||||||
responses_count = 0
|
responses_count = 0
|
||||||
|
|
@ -236,19 +237,21 @@ class StandardBrowser(mechanize.Browser):
|
||||||
if_fail = kwargs.pop('if_fail', 'raise')
|
if_fail = kwargs.pop('if_fail', 'raise')
|
||||||
self.logger.debug('Opening URL "%s", %s' % (args, kwargs))
|
self.logger.debug('Opening URL "%s", %s' % (args, kwargs))
|
||||||
|
|
||||||
|
kwargs['timeout'] = kwargs.get('timeout', self.DEFAULT_TIMEOUT)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
return mechanize.Browser.open_novisit(self, *args, **kwargs)
|
return mechanize.Browser.open_novisit(self, *args, **kwargs)
|
||||||
except (mechanize.BrowserStateError, mechanize.response_seek_wrapper,
|
except (mechanize.BrowserStateError, mechanize.response_seek_wrapper,
|
||||||
urllib2.HTTPError, urllib2.URLError, BadStatusLine), e:
|
urllib2.HTTPError, urllib2.URLError, BadStatusLine), e:
|
||||||
if isinstance(e, mechanize.BrowserStateError) and hasattr(self, 'home'):
|
if isinstance(e, mechanize.BrowserStateError) and hasattr(self, 'home'):
|
||||||
self.home()
|
self.home()
|
||||||
return mechanize.Browser.open(self, *args, **kwargs)
|
return mechanize.Browser.open_novisit(self, *args, **kwargs)
|
||||||
elif if_fail == 'raise':
|
elif if_fail == 'raise':
|
||||||
raise self.get_exception(e)('%s (url="%s")' % (e, args and args[0] or 'None'))
|
raise self.get_exception(e)('%s (url="%s")' % (e, args and args[0] or 'None'))
|
||||||
else:
|
else:
|
||||||
return None
|
return None
|
||||||
except BrowserRetry, e:
|
except BrowserRetry, e:
|
||||||
return mechanize.Browser.open(self, *args, **kwargs)
|
return mechanize.Browser.open_novisit(self, *args, **kwargs)
|
||||||
|
|
||||||
def get_exception(self, e):
|
def get_exception(self, e):
|
||||||
if (isinstance(e, urllib2.HTTPError) and hasattr(e, 'getcode') and e.getcode() in (404, 403)) or \
|
if (isinstance(e, urllib2.HTTPError) and hasattr(e, 'getcode') and e.getcode() in (404, 403)) or \
|
||||||
|
|
@ -526,6 +529,7 @@ class BaseBrowser(StandardBrowser):
|
||||||
keep_kwargs = kwargs.copy()
|
keep_kwargs = kwargs.copy()
|
||||||
|
|
||||||
no_login = kwargs.pop('no_login', False)
|
no_login = kwargs.pop('no_login', False)
|
||||||
|
kwargs['timeout'] = kwargs.get('timeout', self.DEFAULT_TIMEOUT)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
self._change_location(mechanize.Browser.open(self, *args, **kwargs), no_login=no_login)
|
self._change_location(mechanize.Browser.open(self, *args, **kwargs), no_login=no_login)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue