summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2015-02-21 10:39:41 +0000
committerDamien George <damien.p.george@gmail.com>2015-02-21 10:39:41 +0000
commit4e3906d6b5d40a1c36a5b12bc27da7db4202bf63 (patch)
tree661460928f330e5787faf13a5cf75acdbeca06f5
parentd09a5b51c2c96e0315ec000589fdf81ca41c3fec (diff)
downloadmicropython-4e3906d6b5d40a1c36a5b12bc27da7db4202bf63.tar.gz
micropython-4e3906d6b5d40a1c36a5b12bc27da7db4202bf63.zip
tests: Add tests for ure groups and named char classes.
Issue #1122 should now be fixed.
-rw-r--r--tests/extmod/ure_group.py22
-rw-r--r--tests/extmod/ure_namedclass.py28
-rw-r--r--tests/extmod/ure_split.py3
3 files changed, 51 insertions, 2 deletions
diff --git a/tests/extmod/ure_group.py b/tests/extmod/ure_group.py
new file mode 100644
index 0000000000..e402ce5759
--- /dev/null
+++ b/tests/extmod/ure_group.py
@@ -0,0 +1,22 @@
+# test groups, and nested groups
+
+try:
+ import ure as re
+except:
+ import re
+
+def print_groups(match):
+ print('----')
+ try:
+ i = 0
+ while True:
+ print(m.group(i))
+ i += 1
+ except IndexError:
+ pass
+
+m = re.match(r'(([0-9]*)([a-z]*)[0-9]*)','1234hello567')
+print_groups(m)
+
+m = re.match(r'([0-9]*)(([a-z]*)([0-9]*))','1234hello567')
+print_groups(m)
diff --git a/tests/extmod/ure_namedclass.py b/tests/extmod/ure_namedclass.py
new file mode 100644
index 0000000000..25f425ce71
--- /dev/null
+++ b/tests/extmod/ure_namedclass.py
@@ -0,0 +1,28 @@
+# test named char classes
+
+try:
+ import ure as re
+except:
+ import re
+
+def print_groups(match):
+ print('----')
+ try:
+ i = 0
+ while True:
+ print(m.group(i))
+ i += 1
+ except IndexError:
+ pass
+
+m = re.match(r'\w+','1234hello567 abc')
+print_groups(m)
+
+m = re.match(r'(\w+)\s+(\w+)','ABC \t1234hello567 abc')
+print_groups(m)
+
+m = re.match(r'(\S+)\s+(\D+)','ABC \thello abc567 abc')
+print_groups(m)
+
+m = re.match(r'(([0-9]*)([a-z]*)\d*)','1234hello567')
+print_groups(m)
diff --git a/tests/extmod/ure_split.py b/tests/extmod/ure_split.py
index 0154f3abc2..3f7718813f 100644
--- a/tests/extmod/ure_split.py
+++ b/tests/extmod/ure_split.py
@@ -31,5 +31,4 @@ print(s)
r = re.compile("[a-f]+")
s = r.split("0a3b9")
-# TODO - char classes are not yet supported by re1.5
-#print(s)
+print(s)