]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-42199: Fix bytecode_helper assertNotInBytecode (#23031)
authorMax Bernstein <tekknolagi@users.noreply.github.com>
Fri, 18 Dec 2020 00:30:29 +0000 (16:30 -0800)
committerGitHub <noreply@github.com>
Fri, 18 Dec 2020 00:30:29 +0000 (16:30 -0800)
* bpo-42199: Fix bytecode_helper assertNotInBytecode

Add tests.

* ðŸ“œðŸ¤– Added by blurb_it.

Co-authored-by: Dino Viehland <dinoviehland@fb.com>
Co-authored-by: blurb-it[bot] <43283697+blurb-it[bot]@users.noreply.github.com>
Lib/test/support/bytecode_helper.py
Lib/test/test_dis.py
Misc/NEWS.d/next/Tests/2020-10-29-21-26-46.bpo-42199.KksGCV.rst [new file with mode: 0644]

index 348e277c1658823bb55ed94cbbdd716f6c200a1f..471d4a68f915aab082591921ebdc3fcfb0996426 100644 (file)
@@ -35,7 +35,8 @@ class BytecodeTestCase(unittest.TestCase):
                 disassembly = self.get_disassembly_as_string(x)
                 if argval is _UNSPECIFIED:
                     msg = '%s occurs in bytecode:\n%s' % (opname, disassembly)
+                    self.fail(msg)
                 elif instr.argval == argval:
                     msg = '(%s,%r) occurs in bytecode:\n%s'
                     msg = msg % (opname, argval, disassembly)
-                self.fail(msg)
+                    self.fail(msg)
index 786744923eb46106955b3896225d83dfaa18c042..d5d815dc5dc55a726ecb6c9e0397bf9c10ece4e3 100644 (file)
@@ -1212,5 +1212,24 @@ class BytecodeTests(unittest.TestCase):
         b = dis.Bytecode.from_traceback(tb)
         self.assertEqual(b.dis(), dis_traceback)
 
+
+class TestBytecodeTestCase(BytecodeTestCase):
+    def test_assert_not_in_with_op_not_in_bytecode(self):
+        code = compile("a = 1", "<string>", "exec")
+        self.assertInBytecode(code, "LOAD_CONST", 1)
+        self.assertNotInBytecode(code, "LOAD_NAME")
+        self.assertNotInBytecode(code, "LOAD_NAME", "a")
+
+    def test_assert_not_in_with_arg_not_in_bytecode(self):
+        code = compile("a = 1", "<string>", "exec")
+        self.assertInBytecode(code, "LOAD_CONST")
+        self.assertInBytecode(code, "LOAD_CONST", 1)
+        self.assertNotInBytecode(code, "LOAD_CONST", 2)
+
+    def test_assert_not_in_with_arg_in_bytecode(self):
+        code = compile("a = 1", "<string>", "exec")
+        with self.assertRaises(AssertionError):
+            self.assertNotInBytecode(code, "LOAD_CONST", 1)
+
 if __name__ == "__main__":
     unittest.main()
diff --git a/Misc/NEWS.d/next/Tests/2020-10-29-21-26-46.bpo-42199.KksGCV.rst b/Misc/NEWS.d/next/Tests/2020-10-29-21-26-46.bpo-42199.KksGCV.rst
new file mode 100644 (file)
index 0000000..4426f33
--- /dev/null
@@ -0,0 +1 @@
+Fix bytecode helper assertNotInBytecode.
\ No newline at end of file