summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorR David Murray <rdmurray@bitdance.com>2012-04-23 17:23:57 (GMT)
committerR David Murray <rdmurray@bitdance.com>2012-04-23 17:23:57 (GMT)
commitc43125a05cc2f942ae8ba372b1dbe2e2e75d446a (patch)
treef93bb56c150958e958682b48c6aabdf66e22359b /Lib
parent88ec6209cfd0c691df596f681144e1e7c5206dd9 (diff)
downloadcpython-c43125a05cc2f942ae8ba372b1dbe2e2e75d446a.zip
cpython-c43125a05cc2f942ae8ba372b1dbe2e2e75d446a.tar.gz
cpython-c43125a05cc2f942ae8ba372b1dbe2e2e75d446a.tar.bz2
#14638: pydoc now treats non-str __name__ as None instead of raising
Original patch by Peter Otten.
Diffstat (limited to 'Lib')
-rwxr-xr-xLib/pydoc.py3
-rw-r--r--Lib/test/test_pydoc.py11
2 files changed, 13 insertions, 1 deletions
diff --git a/Lib/pydoc.py b/Lib/pydoc.py
index 89fd09b..37616fb 100755
--- a/Lib/pydoc.py
+++ b/Lib/pydoc.py
@@ -1525,7 +1525,8 @@ def resolve(thing, forceload=0):
raise ImportError('no Python documentation found for %r' % thing)
return object, thing
else:
- return thing, getattr(thing, '__name__', None)
+ name = getattr(thing, '__name__', None)
+ return thing, name if isinstance(name, str) else None
def render_doc(thing, title='Python Library Documentation: %s', forceload=0,
renderer=None):
diff --git a/Lib/test/test_pydoc.py b/Lib/test/test_pydoc.py
index 65b0ab5..c5a8e98 100644
--- a/Lib/test/test_pydoc.py
+++ b/Lib/test/test_pydoc.py
@@ -282,6 +282,17 @@ class PydocDocTest(unittest.TestCase):
result, doc_loc = get_pydoc_text(xml.etree)
self.assertEqual(doc_loc, "", "MODULE DOCS incorrectly includes a link")
+ def test_non_str_name(self):
+ # issue14638
+ # Treat illegal (non-str) name like no name
+ class A:
+ __name__ = 42
+ class B:
+ pass
+ adoc = pydoc.render_doc(A())
+ bdoc = pydoc.render_doc(B())
+ self.assertEqual(adoc.replace("A", "B"), bdoc)
+
def test_not_here(self):
missing_module = "test.i_am_not_here"
result = str(run_pydoc(missing_module), 'ascii')