summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael W. Hudson <mwh@python.net>2002-03-08 13:39:25 (GMT)
committerMichael W. Hudson <mwh@python.net>2002-03-08 13:39:25 (GMT)
commitdb1752660157323a7c88a507a754726898eb1b97 (patch)
tree995e96e5c5e5ddd3cfeedb9acc9dfa61f7514128
parentb74a9623efa849417f66e3a856a24e766a809a59 (diff)
downloadcpython-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.py25
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()