summaryrefslogtreecommitdiffstatshomepage
path: root/tests/basics
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-04-29 02:44:13 +0300
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-04-29 20:31:13 +0300
commit4f46c441efef3a88498c186fdace5614bbe26cd7 (patch)
tree93075eabb138b93c3e598c7fc8dd0f8660e6bb2d /tests/basics
parent6ead0d2fbc21795b0a8f0f69a80f3752c9b0d1de (diff)
downloadmicropython-4f46c441efef3a88498c186fdace5614bbe26cd7.tar.gz
micropython-4f46c441efef3a88498c186fdace5614bbe26cd7.zip
tests: Add basic tests for subclassing native types and using special methods.
Even of these, some features do not yet work as expected.
Diffstat (limited to 'tests/basics')
-rw-r--r--tests/basics/subclass-native1.py31
-rw-r--r--tests/basics/subclass-native2.py37
2 files changed, 68 insertions, 0 deletions
diff --git a/tests/basics/subclass-native1.py b/tests/basics/subclass-native1.py
new file mode 100644
index 0000000000..a176893425
--- /dev/null
+++ b/tests/basics/subclass-native1.py
@@ -0,0 +1,31 @@
+class mylist(list):
+ pass
+
+a = mylist([1, 2, 5])
+# Test setting instance attr
+a.attr = "something"
+# Test base type __str__
+print(a)
+# Test getting instance attr
+print(a.attr)
+# Test base type ->subscr
+print(a[-1])
+a[0] = -1
+print(a)
+# Test another base type unary op
+print(len(a))
+
+# Test binary op of base type, with 2nd arg being raw base type
+print(a + [20, 30, 40])
+# Test binary op of base type, with 2nd arg being same class as 1st arg
+# TODO: Faults
+#print(a + a)
+
+def foo():
+ print("hello from foo")
+
+try:
+ class myfunc(type(foo)):
+ pass
+except TypeError:
+ print("TypeError")
diff --git a/tests/basics/subclass-native2.py b/tests/basics/subclass-native2.py
new file mode 100644
index 0000000000..749bf969cf
--- /dev/null
+++ b/tests/basics/subclass-native2.py
@@ -0,0 +1,37 @@
+class Base1:
+ def __init__(self, *args):
+ print("Base1.__init__",args)
+
+class Clist1(Base1, list):
+ pass
+
+class Ctuple1(Base1, tuple):
+ pass
+
+a = Clist1()
+print(len(a))
+a = Clist1([1, 2, 3])
+print(len(a))
+
+a = Ctuple1()
+print(len(a))
+a = Ctuple1([1, 2, 3])
+# TODO: Faults
+#print(len(a))
+
+print("---")
+
+class Clist2(list, Base1):
+ pass
+
+class Ctuple2(tuple, Base1):
+ pass
+a = Clist2()
+print(len(a))
+a = Clist2([1, 2, 3])
+print(len(a))
+
+#a = Ctuple2()
+#print(len(a))
+#a = Ctuple2([1, 2, 3])
+#print(len(a))