diff options
author | Georg Brandl <georg@python.org> | 2014-09-16 14:06:54 +0200 |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2014-09-16 14:06:54 +0200 |
commit | 4ebcf72d1a077c29d94a0cefce3f068ce41a37eb (patch) | |
tree | 887c6378b170a1fb00a252d929738cb227f99967 /tests | |
parent | 5e5586a698e82c7b596ab2e47f035d2aa941b400 (diff) | |
download | pygments-4ebcf72d1a077c29d94a0cefce3f068ce41a37eb.tar.gz |
Add module to optimize regexes that consist of a long |-separated list of literals.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_regexopt.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/tests/test_regexopt.py b/tests/test_regexopt.py new file mode 100644 index 00000000..5dc8f9af --- /dev/null +++ b/tests/test_regexopt.py @@ -0,0 +1,39 @@ +# -*- coding: utf-8 -*- +""" + Tests for pygments.regexopt + ~~~~~~~~~~~~~~~~~~~~~~~~~~~ + + :copyright: Copyright 2006-2014 by the Pygments team, see AUTHORS. + :license: BSD, see LICENSE for details. +""" + +import random +import unittest +import itertools + +from pygments.regexopt import regex_opt + +ALPHABET = ['a', 'b', 'c', 'd', 'e'] +N_TRIES = 15 + + +class RegexOptTestCase(unittest.TestCase): + + def generate_keywordlist(self, length): + return [''.join(p) for p in + itertools.combinations_with_replacement(ALPHABET, length)] + + def test_randomly(self): + # generate a list of all possible keywords of a certain length using + # a restricted alphabet, then choose some to match and make sure only + # those do + for n in range(3, N_TRIES): + kwlist = self.generate_keywordlist(n) + to_match = random.sample(kwlist, + random.randint(1, len(kwlist) - 1)) + no_match = set(kwlist) - set(to_match) + rex = regex_opt(to_match, True) + for w in to_match: + self.assertTrue(rex.match(w)) + for w in no_match: + self.assertFalse(rex.match(w)) |