diff --git a/Lib/_pyio.py b/Lib/_pyio.py index d7119742b9d22b..8f20c5ed2abd5c 100644 --- a/Lib/_pyio.py +++ b/Lib/_pyio.py @@ -312,7 +312,7 @@ def __getattr__(name): global OpenWrapper OpenWrapper = open return OpenWrapper - raise AttributeError(name) + raise AttributeError(f"module {__name__!r} has no attribute {name!r}") # In normal operation, both `UnsupportedOperation`s should be bound to the diff --git a/Lib/concurrent/futures/__init__.py b/Lib/concurrent/futures/__init__.py index d746aeac50a997..292e886d5a88ac 100644 --- a/Lib/concurrent/futures/__init__.py +++ b/Lib/concurrent/futures/__init__.py @@ -50,4 +50,4 @@ def __getattr__(name): ThreadPoolExecutor = te return te - raise AttributeError(f"module {__name__} has no attribute {name}") + raise AttributeError(f"module {__name__!r} has no attribute {name!r}") diff --git a/Lib/io.py b/Lib/io.py index 2a6140c3dd5094..a205e00575f7e8 100644 --- a/Lib/io.py +++ b/Lib/io.py @@ -70,7 +70,7 @@ def __getattr__(name): global OpenWrapper OpenWrapper = open return OpenWrapper - raise AttributeError(name) + raise AttributeError("module {__name__!r} has no attribute {name!r}") # Pretend this exception was created here. diff --git a/Misc/NEWS.d/next/Library/2022-01-25-15-31-04.bpo-46522.tYAlX4.rst b/Misc/NEWS.d/next/Library/2022-01-25-15-31-04.bpo-46522.tYAlX4.rst new file mode 100644 index 00000000000000..999863adb9b314 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2022-01-25-15-31-04.bpo-46522.tYAlX4.rst @@ -0,0 +1 @@ +Make various module ``__getattr__`` AttributeErrors more closely match a typical AttributeError