2015-02-07 09:27:50 -04:00
|
|
|
import os
|
|
|
|
import signal
|
2018-12-05 19:18:30 -04:00
|
|
|
import subprocess
|
|
|
|
import sys
|
2015-02-07 09:27:50 -04:00
|
|
|
import unittest
|
|
|
|
|
2015-05-06 00:33:17 -03:00
|
|
|
from test import support
|
|
|
|
from test.support import script_helper
|
2015-02-07 09:27:50 -04:00
|
|
|
|
|
|
|
|
|
|
|
@unittest.skipUnless(os.name == "posix", "only supported on Unix")
|
|
|
|
class EINTRTests(unittest.TestCase):
|
|
|
|
|
|
|
|
@unittest.skipUnless(hasattr(signal, "setitimer"), "requires setitimer()")
|
|
|
|
def test_all(self):
|
|
|
|
# Run the tester in a sub-process, to make sure there is only one
|
|
|
|
# thread (for reliable signal delivery).
|
|
|
|
tester = support.findfile("eintr_tester.py", subdir="eintrdata")
|
2015-10-01 08:16:43 -03:00
|
|
|
# use -u to try to get the full output if the test hangs or crash
|
2018-12-05 19:18:30 -04:00
|
|
|
args = ["-u", tester, "-v"]
|
|
|
|
if support.verbose:
|
|
|
|
print()
|
|
|
|
print("--- run eintr_tester.py ---")
|
|
|
|
# In verbose mode, the child process inherit stdout and stdout,
|
|
|
|
# to see output in realtime and reduce the risk of loosing output.
|
|
|
|
args = [sys.executable, "-E", "-X", "faulthandler", *args]
|
|
|
|
proc = subprocess.run(args)
|
|
|
|
print(f"--- eintr_tester.py completed: exit code {proc.returncode} ---")
|
|
|
|
if proc.returncode:
|
|
|
|
self.fail("eintr_tester.py failed")
|
|
|
|
else:
|
|
|
|
script_helper.assert_python_ok("-u", tester, "-v")
|
2015-02-07 09:27:50 -04:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
unittest.main()
|