Commit fc5db95e authored by Antoine Pitrou's avatar Antoine Pitrou Committed by GitHub

Test atexit shutdown mechanism in a subprocess (#4828)

* Test atexit shutdown mechanism in a subprocess
parent 317def9f
...@@ -3,6 +3,7 @@ import unittest ...@@ -3,6 +3,7 @@ import unittest
import io import io
import atexit import atexit
from test import support from test import support
from test.support import script_helper
### helpers ### helpers
def h1(): def h1():
...@@ -152,6 +153,21 @@ class GeneralTest(unittest.TestCase): ...@@ -152,6 +153,21 @@ class GeneralTest(unittest.TestCase):
atexit._run_exitfuncs() atexit._run_exitfuncs()
self.assertEqual(l, [5]) self.assertEqual(l, [5])
def test_shutdown(self):
# Actually test the shutdown mechanism in a subprocess
code = """if 1:
import atexit
def f(msg):
print(msg)
atexit.register(f, "one")
atexit.register(f, "two")
"""
res = script_helper.assert_python_ok("-c", code)
self.assertEqual(res.out.decode().splitlines(), ["two", "one"])
self.assertFalse(res.err)
@support.cpython_only @support.cpython_only
class SubinterpreterTest(unittest.TestCase): class SubinterpreterTest(unittest.TestCase):
......
...@@ -2086,6 +2086,8 @@ _Py_FatalInitError(_PyInitError err) ...@@ -2086,6 +2086,8 @@ _Py_FatalInitError(_PyInitError err)
/* For the atexit module. */ /* For the atexit module. */
void _Py_PyAtExit(void (*func)(void)) void _Py_PyAtExit(void (*func)(void))
{ {
/* Guard against API misuse (see bpo-17852) */
assert(_PyRuntime.pyexitfunc == NULL || _PyRuntime.pyexitfunc == func);
_PyRuntime.pyexitfunc = func; _PyRuntime.pyexitfunc = func;
} }
......
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