summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Waygood <Alex.Waygood@Gmail.com>2024-10-21 06:53:21 (GMT)
committerGitHub <noreply@github.com>2024-10-21 06:53:21 (GMT)
commitc5c21fee7ae1ea689a351caa454c98e716a6e537 (patch)
tree19705a0cb736d7f972c816fdb40aeddbea7b9c42
parent9256be7ff0ab035cfd262127d893c9bc88b3c84c (diff)
downloadcpython-c5c21fee7ae1ea689a351caa454c98e716a6e537.zip
cpython-c5c21fee7ae1ea689a351caa454c98e716a6e537.tar.gz
cpython-c5c21fee7ae1ea689a351caa454c98e716a6e537.tar.bz2
gh-125519: Improve traceback if `importlib.reload()` is called with a non-module object (#125520)
-rw-r--r--Lib/importlib/__init__.py2
-rw-r--r--Lib/test/test_importlib/test_api.py15
-rw-r--r--Misc/NEWS.d/next/Library/2024-10-15-14-01-03.gh-issue-125519.TqGh6a.rst2
3 files changed, 18 insertions, 1 deletions
diff --git a/Lib/importlib/__init__.py b/Lib/importlib/__init__.py
index f38fe5c..a7d5756 100644
--- a/Lib/importlib/__init__.py
+++ b/Lib/importlib/__init__.py
@@ -103,7 +103,7 @@ def reload(module):
try:
name = module.__name__
except AttributeError:
- raise TypeError("reload() argument must be a module")
+ raise TypeError("reload() argument must be a module") from None
if sys.modules.get(name) is not module:
raise ImportError(f"module {name} not in sys.modules", name=name)
diff --git a/Lib/test/test_importlib/test_api.py b/Lib/test/test_importlib/test_api.py
index 973237c..51ea527 100644
--- a/Lib/test/test_importlib/test_api.py
+++ b/Lib/test/test_importlib/test_api.py
@@ -9,6 +9,7 @@ import sys
from test import support
from test.support import import_helper
from test.support import os_helper
+import traceback
import types
import unittest
@@ -354,6 +355,20 @@ class ReloadTests:
with self.assertRaises(ModuleNotFoundError):
self.init.reload(module)
+ def test_reload_traceback_with_non_str(self):
+ # gh-125519
+ with support.captured_stdout() as stdout:
+ try:
+ self.init.reload("typing")
+ except TypeError as exc:
+ traceback.print_exception(exc, file=stdout)
+ else:
+ self.fail("Expected TypeError to be raised")
+ printed_traceback = stdout.getvalue()
+ self.assertIn("TypeError", printed_traceback)
+ self.assertNotIn("AttributeError", printed_traceback)
+ self.assertNotIn("module.__spec__.name", printed_traceback)
+
(Frozen_ReloadTests,
Source_ReloadTests
diff --git a/Misc/NEWS.d/next/Library/2024-10-15-14-01-03.gh-issue-125519.TqGh6a.rst b/Misc/NEWS.d/next/Library/2024-10-15-14-01-03.gh-issue-125519.TqGh6a.rst
new file mode 100644
index 0000000..e606262
--- /dev/null
+++ b/Misc/NEWS.d/next/Library/2024-10-15-14-01-03.gh-issue-125519.TqGh6a.rst
@@ -0,0 +1,2 @@
+Improve traceback if :func:`importlib.reload` is called with an object that
+is not a module. Patch by Alex Waygood.