Часть моего сценария:Как уловить тайм-аут сокета в Python 3?
def testConnection(self):
# This code doesn't work
try:
self.imap.login(self.user, self.password)
return True
except:
return False
Когда я пытаюсь соединиться с imaplib к почтовому серверу с неправильными настройками, сценарий всегда падает с этой ошибкой:
Traceback (most recent call last):
File "./mail-notifier.py", line 198, in <module>
mail_check()
File "./mail-notifier.py", line 161, in mail_check
if (SettingsExist() == True and Mail().testConnection() == True):
File "./mail-notifier.py", line 142, in __init__
self.imap = imaplib.IMAP4_SSL(settings.value("MailServer"), settings.value("Port"))
File "/usr/lib64/python3.4/imaplib.py", line 1221, in __init__
IMAP4.__init__(self, host, port)
File "/usr/lib64/python3.4/imaplib.py", line 181, in __init__
self.open(host, port)
File "/usr/lib64/python3.4/imaplib.py", line 1234, in open
IMAP4.open(self, host, port)
File "/usr/lib64/python3.4/imaplib.py", line 257, in open
self.sock = self._create_socket()
File "/usr/lib64/python3.4/imaplib.py", line 1224, in _create_socket
sock = IMAP4._create_socket(self)
File "/usr/lib64/python3.4/imaplib.py", line 247, in _create_socket
return socket.create_connection((self.host, self.port))
File "/usr/lib64/python3.4/socket.py", line 512, in create_connection
raise err
File "/usr/lib64/python3.4/socket.py", line 503, in create_connection
sock.connect(sa)
socket.timeout: timed out
Я не могу поймать исключение тайм-аута и напечатать сообщение об ошибке и продолжить работу. Я думал, что «кроме:» ловит все ошибки, которые происходят. Я попытался установить «except socket.timeout:», но безуспешно. Что я не так?
Проблема заключается в установлении соединения, но не в тайм-ауте соединения. – hrust
Как поймать эту ошибку? – Rinaldus
Попробуйте поймать ошибку там, где вы звоните: 'mail_check()' – hrust