Convert test_fcntl to unittest.
Closes issue #2055. Thanks Giampaolo Rodola.
This commit is contained in:
parent
4a6e8d669a
commit
1f5182b572
|
@ -1,26 +1,29 @@
|
|||
#! /usr/bin/env python
|
||||
"""Test program for the fcntl C module.
|
||||
OS/2+EMX doesn't support the file locking operations.
|
||||
Roger E. Masse
|
||||
|
||||
OS/2+EMX doesn't support the file locking operations.
|
||||
|
||||
"""
|
||||
import struct
|
||||
import fcntl
|
||||
import os, sys
|
||||
from test.test_support import verbose, TESTFN
|
||||
import unittest
|
||||
from test.test_support import verbose, TESTFN, unlink, run_unittest
|
||||
|
||||
filename = TESTFN
|
||||
# TODO - Write tests for ioctl(), flock() and lockf().
|
||||
|
||||
try:
|
||||
|
||||
def get_lockdata():
|
||||
if sys.platform.startswith('atheos'):
|
||||
start_len = "qq"
|
||||
else:
|
||||
try:
|
||||
os.O_LARGEFILE
|
||||
except AttributeError:
|
||||
except AttributeError:
|
||||
start_len = "ll"
|
||||
else:
|
||||
else:
|
||||
start_len = "qq"
|
||||
|
||||
if sys.platform.startswith('atheos'):
|
||||
start_len = "qq"
|
||||
|
||||
if sys.platform in ('netbsd1', 'netbsd2', 'netbsd3',
|
||||
if sys.platform in ('netbsd1', 'netbsd2', 'netbsd3',
|
||||
'Darwin1.2', 'darwin',
|
||||
'freebsd2', 'freebsd3', 'freebsd4', 'freebsd5',
|
||||
'freebsd6', 'freebsd7', 'freebsd8',
|
||||
|
@ -32,38 +35,55 @@ if sys.platform in ('netbsd1', 'netbsd2', 'netbsd3',
|
|||
else:
|
||||
off_t = 'lxxxx'
|
||||
pid_t = 'l'
|
||||
lockdata = struct.pack(off_t+off_t+pid_t+'hh', 0, 0, 0, fcntl.F_WRLCK, 0)
|
||||
elif sys.platform in ['aix3', 'aix4', 'hp-uxB', 'unixware7']:
|
||||
lockdata = struct.pack(off_t + off_t + pid_t + 'hh', 0, 0, 0,
|
||||
fcntl.F_WRLCK, 0)
|
||||
elif sys.platform in ['aix3', 'aix4', 'hp-uxB', 'unixware7']:
|
||||
lockdata = struct.pack('hhlllii', fcntl.F_WRLCK, 0, 0, 0, 0, 0, 0)
|
||||
elif sys.platform in ['os2emx']:
|
||||
elif sys.platform in ['os2emx']:
|
||||
lockdata = None
|
||||
else:
|
||||
else:
|
||||
lockdata = struct.pack('hh'+start_len+'hh', fcntl.F_WRLCK, 0, 0, 0, 0, 0)
|
||||
if lockdata:
|
||||
if lockdata:
|
||||
if verbose:
|
||||
print 'struct.pack: ', repr(lockdata)
|
||||
return lockdata
|
||||
|
||||
# the example from the library docs
|
||||
f = open(filename, 'w')
|
||||
rv = fcntl.fcntl(f.fileno(), fcntl.F_SETFL, os.O_NONBLOCK)
|
||||
if verbose:
|
||||
lockdata = get_lockdata()
|
||||
|
||||
|
||||
class TestFcntl(unittest.TestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.f = None
|
||||
|
||||
def tearDown(self):
|
||||
if not self.f.closed:
|
||||
self.f.close()
|
||||
unlink(TESTFN)
|
||||
|
||||
def test_fcntl_fileno(self):
|
||||
# the example from the library docs
|
||||
self.f = open(TESTFN, 'w')
|
||||
rv = fcntl.fcntl(self.f.fileno(), fcntl.F_SETFL, os.O_NONBLOCK)
|
||||
if verbose:
|
||||
print 'Status from fcntl with O_NONBLOCK: ', rv
|
||||
|
||||
if sys.platform not in ['os2emx']:
|
||||
rv = fcntl.fcntl(f.fileno(), fcntl.F_SETLKW, lockdata)
|
||||
if sys.platform not in ['os2emx']:
|
||||
rv = fcntl.fcntl(self.f.fileno(), fcntl.F_SETLKW, lockdata)
|
||||
if verbose:
|
||||
print 'String from fcntl with F_SETLKW: ', repr(rv)
|
||||
self.f.close()
|
||||
|
||||
f.close()
|
||||
os.unlink(filename)
|
||||
def test_fcntl_file_descriptor(self):
|
||||
# again, but pass the file rather than numeric descriptor
|
||||
self.f = open(TESTFN, 'w')
|
||||
rv = fcntl.fcntl(self.f, fcntl.F_SETFL, os.O_NONBLOCK)
|
||||
if sys.platform not in ['os2emx']:
|
||||
rv = fcntl.fcntl(self.f, fcntl.F_SETLKW, lockdata)
|
||||
self.f.close()
|
||||
|
||||
|
||||
# Again, but pass the file rather than numeric descriptor:
|
||||
f = open(filename, 'w')
|
||||
rv = fcntl.fcntl(f, fcntl.F_SETFL, os.O_NONBLOCK)
|
||||
def test_main():
|
||||
run_unittest(TestFcntl)
|
||||
|
||||
if sys.platform not in ['os2emx']:
|
||||
rv = fcntl.fcntl(f, fcntl.F_SETLKW, lockdata)
|
||||
|
||||
f.close()
|
||||
os.unlink(filename)
|
||||
if __name__ == '__main__':
|
||||
test_main()
|
||||
|
|
Loading…
Reference in New Issue