summaryrefslogtreecommitdiff
path: root/Lib/test/test_mmap.py
diff options
context:
space:
mode:
authorHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>2009-02-28 10:56:50 +0000
committerHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>2009-02-28 10:56:50 +0000
commit39c6dea4a24a1739971b0a68e0bdc49f68356b73 (patch)
treecfc3da838ab166cb1953967c359fd5a5adbb73dd /Lib/test/test_mmap.py
parentf072122c79955e0e7695eb3f104bbd5d32132159 (diff)
downloadcpython-git-39c6dea4a24a1739971b0a68e0bdc49f68356b73.tar.gz
Merged revisions 70052 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r70052 | hirokazu.yamamoto | 2009-02-28 19:31:54 +0900 | 2 lines Issue #5386: mmap.write_byte didn't check map size, so it could cause buffer overrun. ........
Diffstat (limited to 'Lib/test/test_mmap.py')
-rw-r--r--Lib/test/test_mmap.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/Lib/test/test_mmap.py b/Lib/test/test_mmap.py
index 8b7e3e22d0..59b2374ac2 100644
--- a/Lib/test/test_mmap.py
+++ b/Lib/test/test_mmap.py
@@ -466,6 +466,44 @@ class MmapTests(unittest.TestCase):
self.assert_(issubclass(mmap.error, EnvironmentError))
self.assert_("mmap.error" in str(mmap.error))
+ def test_io_methods(self):
+ data = b"0123456789"
+ open(TESTFN, "wb").write(b"x"*len(data))
+ f = open(TESTFN, "r+b")
+ m = mmap.mmap(f.fileno(), len(data))
+ f.close()
+ # Test write_byte()
+ for i in range(len(data)):
+ self.assertEquals(m.tell(), i)
+ m.write_byte(data[i:i+1])
+ self.assertEquals(m.tell(), i+1)
+ self.assertRaises(ValueError, m.write_byte, b"x")
+ self.assertEquals(m[:], data)
+ # Test read_byte()
+ m.seek(0)
+ for i in range(len(data)):
+ self.assertEquals(m.tell(), i)
+ # XXX: Disable this test for now because it's not clear
+ # which type of object m.read_byte returns. Currently, it
+ # returns 1-length str (unicode).
+ if 0:
+ self.assertEquals(m.read_byte(), data[i:i+1])
+ else:
+ m.read_byte()
+ self.assertEquals(m.tell(), i+1)
+ self.assertRaises(ValueError, m.read_byte)
+ # Test read()
+ m.seek(3)
+ self.assertEquals(m.read(3), b"345")
+ self.assertEquals(m.tell(), 6)
+ # Test write()
+ m.seek(3)
+ m.write(b"bar")
+ self.assertEquals(m.tell(), 6)
+ self.assertEquals(m[:], b"012bar6789")
+ m.seek(8)
+ self.assertRaises(ValueError, m.write, b"bar")
+
def test_main():
run_unittest(MmapTests)