]> granicus.if.org Git - python/commitdiff
[3.6] bpo-34136: Make test_do_not_recreate_annotations more reliable. (GH-8364) ...
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Tue, 24 Jul 2018 12:06:19 +0000 (05:06 -0700)
committerSerhiy Storchaka <storchaka@gmail.com>
Tue, 24 Jul 2018 12:06:19 +0000 (15:06 +0300)
(cherry picked from commit 06ca3f0c09d017b9d741553818459cca2d5da587)

Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
Lib/test/test_opcodes.py

index 6806c616cbef3888a2b9ba2b54eef369fb166a81..b2a22861880fa3f960ca9319b830e313cd67db64 100644 (file)
@@ -1,7 +1,7 @@
 # Python test set -- part 2, opcodes
 
 import unittest
-from test import ann_module
+from test import ann_module, support
 
 class OpcodeTest(unittest.TestCase):
 
@@ -42,10 +42,13 @@ class OpcodeTest(unittest.TestCase):
         self.assertEqual(ns['__annotations__'], {'x': int, 1: 2})
 
     def test_do_not_recreate_annotations(self):
-        class C:
-            del __annotations__
-            with self.assertRaises(NameError):
-                x: int
+        # Don't rely on the existence of the '__annotations__' global.
+        with support.swap_item(globals(), '__annotations__', {}):
+            del globals()['__annotations__']
+            class C:
+                del __annotations__
+                with self.assertRaises(NameError):
+                    x: int
 
     def test_raise_class_exceptions(self):