summaryrefslogtreecommitdiffstatshomepage
path: root/tests/basics
diff options
context:
space:
mode:
Diffstat (limited to 'tests/basics')
-rw-r--r--tests/basics/fun_code_colines.py81
-rw-r--r--tests/basics/fun_code_colines.py.exp20
-rw-r--r--tests/basics/fun_code_full.py47
3 files changed, 148 insertions, 0 deletions
diff --git a/tests/basics/fun_code_colines.py b/tests/basics/fun_code_colines.py
new file mode 100644
index 0000000000..a8867770ed
--- /dev/null
+++ b/tests/basics/fun_code_colines.py
@@ -0,0 +1,81 @@
+# Check that we have sensical bytecode offsets in function.__code__.co_lines
+
+def f1(x, y, obj, obj2, obj3):
+ a = x + y # line 4: bc+4 line+4
+ b = x - y # line 5: bc+4 line+1
+ # line 6
+ # line 7
+ # line 8
+ # line 9
+ # line 10
+ # line 11
+ # line 12
+ # line 13
+ # line 14
+ # line 15
+ # line 16
+ # line 17
+ # line 18
+ # line 19
+ c = a * b # line 20: bc+4 line+15
+ obj.a.b.c.d.e.f.g.h.i.j.k.l.m.n.o.p.q.r.s.t.u.v.w.x.y.z.fun() # line 21: bc+31 line+1; bc+27 line+0
+ # line 22
+ # line 23
+ # line 24: bc+0 line+3
+ # line 25
+ # line 26
+ # line 27: bc+0 line+3
+ # line 28
+ # line 29
+ obj2.a.b.c.d.e.f.g.h.i.j.k.l.m.n.o.p.q.r.s.t.u.v.w.x.y.z.fun() # line 30: bc+31 line+3; bc+27 line+0
+ # line 31
+ # line 32
+ # line 33: bc+0 line+3
+ # line 34
+ # line 35
+ # line 36
+ # line 37
+ # line 38
+ # line 39
+ # line 40
+ # line 41
+ # line 42
+ # line 43
+ # line 44
+ # line 45
+ # line 46
+ # line 47
+ # line 48
+ # line 49
+ # line 50
+ # line 51
+ # line 52
+ # line 53
+ # line 54
+ # line 55
+ # line 56
+ # line 57
+ # line 58
+ # line 59
+ return obj3.a.b.c.d.e.f.g.h.i.j.k.l.m.n.o.p.q.r.s.t.u.v.w.x.y.z.fun() # line 60: bc+31 line+27; bc+27 line+0
+
+def f2(x, y):
+ a = x + y # line 63
+ b = x - y # line 64
+ return a * b # line 65
+
+try:
+ f1.__code__.co_lines
+except AttributeError:
+ print("SKIP")
+ raise SystemExit
+
+print("f1")
+for start, end, line_no in f1.__code__.co_lines():
+ print("line {} start: {}".format(line_no, start))
+ print("line {} end: {}".format(line_no, end))
+
+print("f2")
+for start, end, line_no in f2.__code__.co_lines():
+ print("line {} start: {}".format(line_no, start))
+ print("line {} end: {}".format(line_no, end))
diff --git a/tests/basics/fun_code_colines.py.exp b/tests/basics/fun_code_colines.py.exp
new file mode 100644
index 0000000000..19bd4ef6e2
--- /dev/null
+++ b/tests/basics/fun_code_colines.py.exp
@@ -0,0 +1,20 @@
+f1
+line 4 start: 0
+line 4 end: 4
+line 5 start: 4
+line 5 end: 8
+line 20 start: 8
+line 20 end: 12
+line 21 start: 12
+line 21 end: 70
+line 30 start: 70
+line 30 end: 128
+line 60 start: 128
+line 60 end: 186
+f2
+line 63 start: 0
+line 63 end: 4
+line 64 start: 4
+line 64 end: 8
+line 65 start: 8
+line 65 end: 12
diff --git a/tests/basics/fun_code_full.py b/tests/basics/fun_code_full.py
new file mode 100644
index 0000000000..5eb23150df
--- /dev/null
+++ b/tests/basics/fun_code_full.py
@@ -0,0 +1,47 @@
+# Test function.__code__ attributes not available with MICROPY_PY_BUILTINS_CODE <= MICROPY_PY_BUILTINS_CODE_BASIC
+
+try:
+ (lambda: 0).__code__.co_code
+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
+ return a * b
+
+code = f.__code__
+
+print(type(code.co_code)) # both bytes (but mpy and cpy have different instruction sets)
+print(code.co_consts) # (not necessarily the same set, but in this function they are)
+print(code.co_filename.rsplit('/')[-1]) # same terminal filename but might be different paths on other ports
+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()
+
+l = list(co_lines)
+first_start = l[0][0]
+last_end = l[-1][1]
+print(first_start) # co_lines should start at the start of the bytecode
+print(len(code.co_code) - last_end) # and end at the end of the bytecode
+
+prev_end = 0
+for start, end, line_no in l:
+ if end != prev_end:
+ print("non-contiguous")
+ break # the offset ranges should be contiguous
+ prev_end = end
+else:
+ print("contiguous")
+
+