Kaydet (Commit) 1f5182b5 authored tarafından Brett Cannon's avatar Brett Cannon

Convert test_fcntl to unittest.

Closes issue #2055. Thanks Giampaolo Rodola.
üst 4a6e8d66
#! /usr/bin/env python
"""Test program for the fcntl C module. """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 struct
import fcntl import fcntl
import os, sys import os, sys
from test.test_support import verbose, TESTFN import unittest
from test.test_support import verbose, TESTFN, unlink, run_unittest
# TODO - Write tests for ioctl(), flock() and lockf().
filename = TESTFN
try: def get_lockdata():
if sys.platform.startswith('atheos'):
start_len = "qq"
else:
try:
os.O_LARGEFILE os.O_LARGEFILE
except AttributeError: except AttributeError:
start_len = "ll" start_len = "ll"
else: else:
start_len = "qq"
if sys.platform.startswith('atheos'):
start_len = "qq" start_len = "qq"
if sys.platform in ('netbsd1', 'netbsd2', 'netbsd3', if sys.platform in ('netbsd1', 'netbsd2', 'netbsd3',
'Darwin1.2', 'darwin', 'Darwin1.2', 'darwin',
'freebsd2', 'freebsd3', 'freebsd4', 'freebsd5', 'freebsd2', 'freebsd3', 'freebsd4', 'freebsd5',
'freebsd6', 'freebsd7', 'freebsd8', 'freebsd6', 'freebsd7', 'freebsd8',
...@@ -32,38 +35,55 @@ if sys.platform in ('netbsd1', 'netbsd2', 'netbsd3', ...@@ -32,38 +35,55 @@ if sys.platform in ('netbsd1', 'netbsd2', 'netbsd3',
else: else:
off_t = 'lxxxx' off_t = 'lxxxx'
pid_t = 'l' pid_t = 'l'
lockdata = struct.pack(off_t+off_t+pid_t+'hh', 0, 0, 0, fcntl.F_WRLCK, 0) lockdata = struct.pack(off_t + off_t + pid_t + 'hh', 0, 0, 0,
elif sys.platform in ['aix3', 'aix4', 'hp-uxB', 'unixware7']: 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) 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 lockdata = None
else: else:
lockdata = struct.pack('hh'+start_len+'hh', fcntl.F_WRLCK, 0, 0, 0, 0, 0) lockdata = struct.pack('hh'+start_len+'hh', fcntl.F_WRLCK, 0, 0, 0, 0, 0)
if lockdata: if lockdata:
if verbose: if verbose:
print 'struct.pack: ', repr(lockdata) print 'struct.pack: ', repr(lockdata)
return lockdata
# the example from the library docs lockdata = get_lockdata()
f = open(filename, 'w')
rv = fcntl.fcntl(f.fileno(), fcntl.F_SETFL, os.O_NONBLOCK)
if verbose: class TestFcntl(unittest.TestCase):
print 'Status from fcntl with O_NONBLOCK: ', rv
def setUp(self):
self.f = None
if sys.platform not in ['os2emx']: def tearDown(self):
rv = fcntl.fcntl(f.fileno(), fcntl.F_SETLKW, lockdata) 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(self.f.fileno(), fcntl.F_SETLKW, lockdata)
if verbose: if verbose:
print 'String from fcntl with F_SETLKW: ', repr(rv) print 'String from fcntl with F_SETLKW: ', repr(rv)
self.f.close()
f.close() def test_fcntl_file_descriptor(self):
os.unlink(filename) # 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)
if sys.platform not in ['os2emx']: def test_main():
rv = fcntl.fcntl(f, fcntl.F_SETLKW, lockdata) run_unittest(TestFcntl)
f.close() if __name__ == '__main__':
os.unlink(filename) test_main()
...@@ -50,6 +50,8 @@ Library ...@@ -50,6 +50,8 @@ Library
Tests Tests
----- -----
- Issue #2055: Convert test_fcntl to unittest.
- Issue 1960: Convert test_gdbm to unittest. - Issue 1960: Convert test_gdbm to unittest.
- GHOP 294: Convert test_contains, test_crypt, and test_select to unittest. - GHOP 294: Convert test_contains, test_crypt, and test_select to unittest.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment