[Python-Dev] off-by-one on ftell on wine, but no regression test to catch it
Luke Kenneth Casson Leighton
lkcl at lkcl.net
Sat Jan 17 21:46:40 CET 2009
folks, hi,
http://bugs.winehq.org/show_bug.cgi?id=16982 related to this:
from array import array
TESTFN = "testfile.txt"
def fail(x):
print x
testlines = [
"spam, spam and eggs\n",
"eggs, spam, ham and spam\n",
"saussages, spam, spam and eggs\n",
"spam, ham, spam and eggs\n",
"spam, spam, spam, spam, spam, ham, spam\n",
"wonderful spaaaaaam.\n"
]
try:
# Prepare the testfile
bag = open(TESTFN, "w")
bag.writelines(testlines)
bag.close()
f = open(TESTFN)
testline = testlines.pop(0)
line = f.readline()
testline = testlines.pop(0)
buf = array("c", "\x00" * len(testline))
f.readinto(buf)
testline = testlines.pop(0)
print "length of testline:", len(testline)
line = f.read(len(testline))
if line != testline:
fail("read() after next() with empty buffer "
"failed. Got %r, expected %r" % (line, testline))
lines = f.readlines()
if lines != testlines:
fail("readlines() after next() with empty buffer "
"failed. Got %r, expected %r" % (line, testline))
f.close()
finally:
os.unlink(TESTFN)
which is a reduced version of Lib/test/test_file.py
running under wine, ftell() has an off-by-one bug, where the file
position accidentally doesn't include the fact that the CR of the CRLF
has been skipped. but, now with the fgets() bug fixed, the regression
tests pass, but there's still the off-by-one bug which _isn't_ caught.
this really should be added as a windows test. actually, it should be
added as a test for everything: it's not always reasonable to assume
that OSes get their file positions right :)
l.
More information about the Python-Dev
mailing list