diff options
| author | Alexander Belopolsky <alexander.belopolsky@gmail.com> | 2012-06-22 16:48:08 (GMT) |
|---|---|---|
| committer | Alexander Belopolsky <alexander.belopolsky@gmail.com> | 2012-06-22 16:48:08 (GMT) |
| commit | 67064bc1b6b4fb71e1698dc898b9f7d8065a4a70 (patch) | |
| tree | e3bf4ab1c64589dd2a2e29af029163993e363f0d /Lib/test/test_posix.py | |
| parent | a2637729f23dc993e820fd92f0d1759ad714c9b2 (diff) | |
| parent | 9436361e4cdd7d3dc5f42674b54995c4915afb59 (diff) | |
| download | cpython-67064bc1b6b4fb71e1698dc898b9f7d8065a4a70.zip cpython-67064bc1b6b4fb71e1698dc898b9f7d8065a4a70.tar.gz cpython-67064bc1b6b4fb71e1698dc898b9f7d8065a4a70.tar.bz2 | |
merge
Diffstat (limited to 'Lib/test/test_posix.py')
| -rw-r--r-- | Lib/test/test_posix.py | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/Lib/test/test_posix.py b/Lib/test/test_posix.py index 21473fc..ae46866 100644 --- a/Lib/test/test_posix.py +++ b/Lib/test/test_posix.py @@ -1015,6 +1015,26 @@ class PosixTester(unittest.TestCase): posix.RTLD_GLOBAL posix.RTLD_LOCAL + @unittest.skipUnless(hasattr(os, 'SEEK_HOLE'), + "test needs an OS that reports file holes") + def test_fs_holes(self) : + # Even if the filesystem doesn't report holes, + # if the OS supports it the SEEK_* constants + # will be defined and will have a consistent + # behaviour: + # os.SEEK_DATA = current position + # os.SEEK_HOLE = end of file position + with open(support.TESTFN, 'r+b') as fp : + fp.write(b"hello") + fp.flush() + size = fp.tell() + fno = fp.fileno() + for i in range(size) : + self.assertEqual(i, os.lseek(fno, i, os.SEEK_DATA)) + self.assertLessEqual(size, os.lseek(fno, i, os.SEEK_HOLE)) + self.assertRaises(OSError, os.lseek, fno, size, os.SEEK_DATA) + self.assertRaises(OSError, os.lseek, fno, size, os.SEEK_HOLE) + class PosixGroupsTester(unittest.TestCase): def setUp(self): |
