Commit 46f40be8 authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-33937: Catch ENOMEM error in test_socket (#9557)

Fix test_socket.SendmsgSCTPStreamTest: catch ENOMEM error.
testSendmsgTimeout() and testSendmsgDontWait() randomly fail on
Travis CI with: "OSError: [Errno 12] Cannot allocate memory".
parent 6ea29c5e
...@@ -2616,9 +2616,18 @@ class SendmsgStreamTests(SendmsgTests): ...@@ -2616,9 +2616,18 @@ class SendmsgStreamTests(SendmsgTests):
def _testSendmsgTimeout(self): def _testSendmsgTimeout(self):
try: try:
self.cli_sock.settimeout(0.03) self.cli_sock.settimeout(0.03)
with self.assertRaises(socket.timeout): try:
while True: while True:
self.sendmsgToServer([b"a"*512]) self.sendmsgToServer([b"a"*512])
except socket.timeout:
pass
except OSError as exc:
if exc.errno != errno.ENOMEM:
raise
# bpo-33937 the test randomly fails on Travis CI with
# "OSError: [Errno 12] Cannot allocate memory"
else:
self.fail("socket.timeout not raised")
finally: finally:
self.misc_event.set() self.misc_event.set()
...@@ -2641,8 +2650,10 @@ class SendmsgStreamTests(SendmsgTests): ...@@ -2641,8 +2650,10 @@ class SendmsgStreamTests(SendmsgTests):
with self.assertRaises(OSError) as cm: with self.assertRaises(OSError) as cm:
while True: while True:
self.sendmsgToServer([b"a"*512], [], socket.MSG_DONTWAIT) self.sendmsgToServer([b"a"*512], [], socket.MSG_DONTWAIT)
# bpo-33937: catch also ENOMEM, the test randomly fails on Travis CI
# with "OSError: [Errno 12] Cannot allocate memory"
self.assertIn(cm.exception.errno, self.assertIn(cm.exception.errno,
(errno.EAGAIN, errno.EWOULDBLOCK)) (errno.EAGAIN, errno.EWOULDBLOCK, errno.ENOMEM))
finally: finally:
self.misc_event.set() self.misc_event.set()
......
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