cpython/Lib/test/test_re.py

59 lines
1.6 KiB
Python
Raw Normal View History

1997-07-11 16:34:44 -03:00
from test_support import verbose
import re
1997-07-11 17:47:58 -03:00
import sys, traceback
1997-07-11 16:34:44 -03:00
from re_tests import *
1997-07-11 17:47:58 -03:00
if verbose: print 'Running re_tests test suite'
1997-07-11 16:34:44 -03:00
for t in tests:
print t
pattern=s=outcome=repl=expected=None
if len(t)==5:
pattern, s, outcome, repl, expected = t
elif len(t)==3:
pattern, s, outcome = t
else:
raise ValueError, ('Test tuples should have 3 or 5 fields',t)
try:
obj=re.compile(pattern)
except re.error:
if outcome==SYNTAX_ERROR: pass # Expected a syntax error
else:
print '=== Syntax error:', t
except:
print '*** Unexpected error ***'
1997-07-11 17:47:58 -03:00
traceback.print_exc(file=sys.stdout)
1997-07-11 16:34:44 -03:00
else:
try:
result=obj.search(s)
except regex.error, msg:
print '=== Unexpected exception', t, repr(msg)
if outcome==SYNTAX_ERROR:
# This should have been a syntax error; forget it.
pass
elif outcome==FAIL:
if result is None: pass # No match, as expected
else: print '=== Succeeded incorrectly', t
elif outcome==SUCCEED:
if result is not None:
# Matched, as expected, so now we compute the
# result string and compare it to our expected result.
start, end = result.span(0)
vardict={'found': result.group(0)}
for i in range(1, 100):
try:
gi = result.group(i)
1997-07-11 17:47:58 -03:00
# Special hack because else the string concat fails:
if gi is None: gi = "None"
1997-07-11 16:34:44 -03:00
except IndexError:
break
else:
vardict['g%d' % i] = gi
repl=eval(repl, vardict)
if repl!=expected:
print '=== grouping error', t,
print repr(repl)+' should be '+repr(expected)
else:
print '=== Failed incorrectly', t