Commit 9a3ffaf2 authored by Xiaowu Zhang's avatar Xiaowu Zhang

OoDocument: retry for socket related error

for example: SSLError: ('The read operation timed out',)

/reviewed-on !703
parent 10ef148f
......@@ -52,6 +52,7 @@ from Products.ERP5.mixin.extensible_traversable import OOoDocumentExtensibleTrav
# connection plugins
from Products.ERP5Type.ConnectionPlugin.TimeoutTransport import TimeoutTransport
from socket import error as SocketError
enc=base64.encodestring
dec=base64.decodestring
......@@ -98,6 +99,7 @@ class OOoServerProxy():
def _proxy_function(self, func_name, *args, **kw):
result_error_set_list = []
protocol_error_list = []
socket_error_list = []
fault_error_list = []
count = 0
serverproxy_list = self._serverproxy_list
......@@ -109,6 +111,11 @@ class OOoServerProxy():
# Cloudooo return result in (200 or 402, dict(), '') format or just based type
# 402 for error and 200 for ok
result_set = func(*args, **kw)
except SocketError, e:
message = 'Socket Error: %s' % (repr(e) or 'undefined.')
socket_error_list.append(message)
retry_server_list.append(server_proxy)
continue
except ProtocolError, e:
# Network issue
message = "%s: %s %s" % (e.url, e.errcode, e.errmsg)
......@@ -148,6 +155,8 @@ class OOoServerProxy():
if len(protocol_error_list):
raise ConversionError("Protocol error while contacting OOo conversion: "
"%s" % (','.join(protocol_error_list)))
if len(socket_error_list):
raise SocketError("%s" % (','.join(socket_error_list)))
if len(fault_error_list):
raise fault_error_list[0]
......
......@@ -103,3 +103,16 @@ class TestOOoConversionServerRetry(ERP5TypeTestCase):
system_pref.setPreferredDocumentConversionServerUrlList(saved_server_list)
self.commit()
def test_03_retry_for_socket_issue(self):
system_pref = self.getDefaultSystemPreference()
server_list = system_pref.getPreferredDocumentConversionServerUrlList()
system_pref.setPreferredDocumentConversionServerRetry(self.retry_count)
system_pref.setPreferredOoodocServerTimeout(1)
self.tic()
filename = 'TEST-en-002.doc'
file = makeFileUpload(filename)
document = self.portal.portal_contributions.newContent(file=file)
message = document.Document_tryToConvertToBaseFormat()
if 'Socket Error: SSLError' in message:
self.assertEqual(message.count('Socket Error: SSLError'), (self.retry_count + 1) * len(server_list))
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment