diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2013-10-25 19:36:10 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2013-10-25 19:36:10 (GMT) |
commit | 79aa68dfc1ab4936107f9528d939e865f94da4b6 (patch) | |
tree | 8cfe598860de5ebc6c9490a365884bff634fcd39 /Lib/test/test_re.py | |
parent | e38b0544c4f89fe3e665721e52c027e006922032 (diff) | |
download | cpython-79aa68dfc1ab4936107f9528d939e865f94da4b6.zip cpython-79aa68dfc1ab4936107f9528d939e865f94da4b6.tar.gz cpython-79aa68dfc1ab4936107f9528d939e865f94da4b6.tar.bz2 |
Issue #19387: explain and test the sre overlap table
Diffstat (limited to 'Lib/test/test_re.py')
-rw-r--r-- | Lib/test/test_re.py | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/Lib/test/test_re.py b/Lib/test/test_re.py index 5e68585..9ee077d 100644 --- a/Lib/test/test_re.py +++ b/Lib/test/test_re.py @@ -3,10 +3,12 @@ from test.support import verbose, run_unittest, gc_collect, bigmemtest, _2G, \ import io import re from re import Scanner +import sre_compile import sre_constants import sys import string import traceback +import unittest from weakref import proxy # Misc tests from Tim Peters' re.doc @@ -15,8 +17,6 @@ from weakref import proxy # what you're doing. Some of these tests were carefully modeled to # cover most of the code. -import unittest - class S(str): def __getitem__(self, index): return S(super().__getitem__(index)) @@ -1140,6 +1140,22 @@ class ReTests(unittest.TestCase): self.assertEqual(m.group(1), "") self.assertEqual(m.group(2), "y") + +class ImplementationTest(unittest.TestCase): + """ + Test implementation details of the re module. + """ + + def test_overlap_table(self): + f = sre_compile._generate_overlap_table + self.assertEqual(f(""), []) + self.assertEqual(f("a"), [0]) + self.assertEqual(f("abcd"), [0, 0, 0, 0]) + self.assertEqual(f("aaaa"), [0, 1, 2, 3]) + self.assertEqual(f("ababba"), [0, 0, 1, 2, 0, 1]) + self.assertEqual(f("abcabdac"), [0, 0, 0, 1, 2, 0, 1, 0]) + + def run_re_tests(): from test.re_tests import tests, SUCCEED, FAIL, SYNTAX_ERROR if verbose: @@ -1269,7 +1285,7 @@ def run_re_tests(): def test_main(): - run_unittest(ReTests) + run_unittest(__name__) run_re_tests() if __name__ == "__main__": |