[Python-checkins] bpo-32892: Support subclasses of base types in isinstance checks for AST constants. (GH-9934)

Serhiy Storchaka webhook-mailer at python.org
Sun Oct 28 07:43:06 EDT 2018


https://github.com/python/cpython/commit/6015cc50bc38b9e920ce4986ee10658eaa14f561
commit: 6015cc50bc38b9e920ce4986ee10658eaa14f561
branch: master
author: Serhiy Storchaka <storchaka at gmail.com>
committer: GitHub <noreply at github.com>
date: 2018-10-28T13:43:03+02:00
summary:

bpo-32892: Support subclasses of base types in isinstance checks for AST constants. (GH-9934)

Some projects (e.g. Chameleon) create ast.Str containing an instance
of the str subclass.

files:
M Lib/ast.py
M Lib/test/test_ast.py

diff --git a/Lib/ast.py b/Lib/ast.py
index de3df1473e5e..4c8c7795ff82 100644
--- a/Lib/ast.py
+++ b/Lib/ast.py
@@ -346,7 +346,7 @@ def __instancecheck__(cls, inst):
             except AttributeError:
                 return False
             else:
-                return type(value) in _const_types[cls]
+                return isinstance(value, _const_types[cls])
         return type.__instancecheck__(cls, inst)
 
 def _new(cls, *args, **kwargs):
diff --git a/Lib/test/test_ast.py b/Lib/test/test_ast.py
index 10be02eee0c0..4bbdc3b82daa 100644
--- a/Lib/test/test_ast.py
+++ b/Lib/test/test_ast.py
@@ -399,6 +399,10 @@ def test_isinstance(self):
         self.assertFalse(isinstance(ast.Constant(), ast.NameConstant))
         self.assertFalse(isinstance(ast.Constant(), ast.Ellipsis))
 
+        class S(str): pass
+        self.assertTrue(isinstance(ast.Constant(S('42')), ast.Str))
+        self.assertFalse(isinstance(ast.Constant(S('42')), ast.Num))
+
     def test_subclasses(self):
         class N(ast.Num):
             def __init__(self, *args, **kwargs):



More information about the Python-checkins mailing list