]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-120782: Update internal type cache when reloading datetime (#120829)
authorneonene <53406459+neonene@users.noreply.github.com>
Fri, 21 Jun 2024 17:09:33 +0000 (02:09 +0900)
committerGitHub <noreply@github.com>
Fri, 21 Jun 2024 17:09:33 +0000 (22:39 +0530)
Lib/test/datetimetester.py
Misc/NEWS.d/next/Library/2024-06-21-12-00-16.gh-issue-120782.LOE8tj.rst [new file with mode: 0644]
Modules/_datetimemodule.c

index e55b738eb4a97518e8eacc26cbcf9516392593b5..b8f69e774f79909d775fb02f57ffef9769518a8e 100644 (file)
@@ -6870,6 +6870,23 @@ class ExtensionModuleTests(unittest.TestCase):
                 """)
             script_helper.assert_python_ok('-c', script)
 
+    def test_update_type_cache(self):
+        # gh-120782
+        script = textwrap.dedent("""
+            import sys
+            for i in range(5):
+                import _datetime
+                _datetime.date.max > _datetime.date.min
+                _datetime.time.max > _datetime.time.min
+                _datetime.datetime.max > _datetime.datetime.min
+                _datetime.timedelta.max > _datetime.timedelta.min
+                isinstance(_datetime.timezone.min, _datetime.tzinfo)
+                isinstance(_datetime.timezone.utc, _datetime.tzinfo)
+                isinstance(_datetime.timezone.max, _datetime.tzinfo)
+                del sys.modules['_datetime']
+            """)
+        script_helper.assert_python_ok('-c', script)
+
 
 def load_tests(loader, standard_tests, pattern):
     standard_tests.addTest(ZoneInfoCompleteTest())
diff --git a/Misc/NEWS.d/next/Library/2024-06-21-12-00-16.gh-issue-120782.LOE8tj.rst b/Misc/NEWS.d/next/Library/2024-06-21-12-00-16.gh-issue-120782.LOE8tj.rst
new file mode 100644 (file)
index 0000000..02acbd2
--- /dev/null
@@ -0,0 +1 @@
+Fix wrong references of the :mod:`datetime` types after reloading the module.
index 31bf641152d8036310afa4e0a7bb6c22d368ed58..85595dce0bad5c08b301cc7c1aa7aba66347e460 100644 (file)
@@ -7296,6 +7296,12 @@ _datetime_exec(PyObject *module)
     static_assert(DI100Y == 25 * DI4Y - 1, "DI100Y");
     assert(DI100Y == days_before_year(100+1));
 
+    if (reloading) {
+        for (size_t i = 0; i < Py_ARRAY_LENGTH(capi_types); i++) {
+            PyType_Modified(capi_types[i]);
+        }
+    }
+
     if (set_current_module(interp, module) < 0) {
         goto error;
     }