diff options
| -rw-r--r-- | tests/basics/fun_code_full.py | 7 | ||||
| -rw-r--r-- | tests/basics/fun_code_lnotab.py | 34 |
2 files changed, 34 insertions, 7 deletions
diff --git a/tests/basics/fun_code_full.py b/tests/basics/fun_code_full.py index 5eb23150d..e1c867939 100644 --- a/tests/basics/fun_code_full.py +++ b/tests/basics/fun_code_full.py @@ -6,12 +6,6 @@ except AttributeError: print("SKIP") raise SystemExit -try: - import warnings - warnings.simplefilter("ignore") # ignore deprecation warning about co_lnotab -except ImportError: - pass - def f(x, y): a = x + y b = x - y @@ -25,7 +19,6 @@ print(code.co_filename.rsplit('/')[-1]) # same terminal filename but might be di print(type(code.co_firstlineno)) # both ints (but mpy points to first line inside, cpy points to declaration) print(code.co_name) print(iter(code.co_names) is not None) # both iterable (but mpy returns dict with names as keys, cpy only the names; and not necessarily the same set) -print(type(code.co_lnotab)) # both bytes co_lines = code.co_lines() diff --git a/tests/basics/fun_code_lnotab.py b/tests/basics/fun_code_lnotab.py new file mode 100644 index 000000000..9223e5730 --- /dev/null +++ b/tests/basics/fun_code_lnotab.py @@ -0,0 +1,34 @@ +# Test deprecation of co_lnotab + +try: + (lambda: 0).__code__.co_code +except AttributeError: + print("SKIP") + raise SystemExit + + +import unittest +import sys + + +mpy_is_v2 = getattr(sys.implementation, '_v2', False) + + +def f(): + pass + + +class Test(unittest.TestCase): + + @unittest.skipIf(mpy_is_v2, "Removed in MicroPython v2 and later.") + def test_co_lnotab_exists(self): + self.assertIsInstance(f.__code__.co_lnotab, bytes) + + @unittest.skipUnless(mpy_is_v2, "Not removed before MicroPython v2.") + def test_co_lnotab_removed(self): + with self.assertRaises(AttributeError): + f.__code__.co_lnotab + + +if __name__ == "__main__": + unittest.main() |
