fix bug #42 reported by Andrew Dalke

The Compare close contains a close method that checks to see if there
is any unconsumed data in the Compare instance; i.e. if the canonical
output file contains more data than was produced by the current test
run. This method was never called, allowing differences to go
undetected.

Fix is to call close after the test is run (after __import__)

output/test_long and output/test_popen2 needed trivial changes
output/test_select contained lots of text, but test_select.py produced
    no output
This commit is contained in:
Jeremy Hylton 2000-07-11 15:15:31 +00:00
parent b35de5b78a
commit fff9e20943
5 changed files with 2 additions and 27 deletions

View File

@ -3,4 +3,3 @@ long / * % divmod
long bit-operation identities
long str/hex/oct/atol
long miscellaneous operations

View File

@ -2,4 +2,3 @@ test_popen2
testing popen2...
testing popen3...
All OK

View File

@ -1,25 +1 @@
test_select
timeout = 0
timeout = 1
'testing...\012'
timeout = 2
'testing...\012'
timeout = 4
'testing...\012'
timeout = 8
'testing...\012'
timeout = 16
'testing...\012'
timeout = None
'testing...\012'
timeout = None
'testing...\012'
timeout = None
'testing...\012'
timeout = None
'testing...\012'
timeout = None
'testing...\012'
timeout = None
''
EOF

View File

@ -212,6 +212,8 @@ def runtest(test, generate, verbose, testdir = None):
sys.stdout = cfp
print test # Output file starts with test name
__import__(test, globals(), locals(), [])
if cfp and not (generate or verbose):
cfp.close()
finally:
sys.stdout = save_stdout
except ImportError, msg:

View File

@ -45,7 +45,6 @@ def test():
if verbose:
print 'timeout =', tout
rfd, wfd, xfd = select.select([p], [], [], tout)
## print rfd, wfd, xfd
if (rfd, wfd, xfd) == ([], [], []):
continue
if (rfd, wfd, xfd) == ([p], [], []):