diff options
author | Michael W. Hudson <mwh@python.net> | 2002-03-08 13:39:25 (GMT) |
---|---|---|
committer | Michael W. Hudson <mwh@python.net> | 2002-03-08 13:39:25 (GMT) |
commit | db1752660157323a7c88a507a754726898eb1b97 (patch) | |
tree | 995e96e5c5e5ddd3cfeedb9acc9dfa61f7514128 | |
parent | b74a9623efa849417f66e3a856a24e766a809a59 (diff) | |
download | cpython-db1752660157323a7c88a507a754726898eb1b97.zip cpython-db1752660157323a7c88a507a754726898eb1b97.tar.gz cpython-db1752660157323a7c88a507a754726898eb1b97.tar.bz2 |
backport tim_one's checkin of
revision 1.20 of test_mmap.py
SF bug 515943: searching for data with \0 in mmap.
mmap_find_method(): this obtained the string to find via s#, but it
ignored its length, acting as if it were \0-terminated instead.
Someone please run on Linux too (the extended test_mmap works on Windows).
Bugfix candidate.
-rw-r--r-- | Lib/test/test_mmap.py | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/Lib/test/test_mmap.py b/Lib/test/test_mmap.py index f3d1538..0f34758 100644 --- a/Lib/test/test_mmap.py +++ b/Lib/test/test_mmap.py @@ -244,6 +244,31 @@ def test_both(): except OSError: pass + # Do a tougher .find() test. SF bug 515943 pointed out that, in 2.2, + # searching for data with embedded \0 bytes didn't work. + f = open(TESTFN, 'w+') + + try: # unlink TESTFN no matter what + data = 'aabaac\x00deef\x00\x00aa\x00' + n = len(data) + f.write(data) + m = mmap.mmap(f.fileno(), n) + f.close() + + for start in range(n+1): + for finish in range(start, n+1): + slice = data[start : finish] + vereq(m.find(slice), data.find(slice)) + vereq(m.find(slice + 'x'), -1) + + finally: + try: + os.unlink(TESTFN) + except OSError: + pass + + + print ' Test passed' test_both() |