diff options
author | Alexey Izbyshev <izbyshev@ispras.ru> | 2022-05-06 07:01:15 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-05-05 21:01:15 -0700 |
commit | 85354ed78c0edb6d81a2bd53cabc85e547b8b26e (patch) | |
tree | 244e74e1f2aa63be2ffc02acf07f86268163fa68 /Lib/test/test_descr.py | |
parent | adcb6a6055c7fe6e02621f66945be237b42e945a (diff) | |
download | cpython-git-85354ed78c0edb6d81a2bd53cabc85e547b8b26e.tar.gz |
gh-92112: Fix crash triggered by an evil custom `mro()` (#92113)
Diffstat (limited to 'Lib/test/test_descr.py')
-rw-r--r-- | Lib/test/test_descr.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py index 48d43d7af8..afe0f7e9c7 100644 --- a/Lib/test/test_descr.py +++ b/Lib/test/test_descr.py @@ -5784,6 +5784,23 @@ class MroTest(unittest.TestCase): class A(metaclass=M): pass + def test_disappearing_custom_mro(self): + """ + gh-92112: A custom mro() returning a result conflicting with + __bases__ and deleting itself caused a double free. + """ + class B: + pass + + class M(DebugHelperMeta): + def mro(cls): + del M.mro + return (B,) + + with self.assertRaises(TypeError): + class A(metaclass=M): + pass + if __name__ == "__main__": unittest.main() |