[Python-checkins] r61665 - python/trunk/Lib/test/test_fcntl.py python/trunk/Lib/test/test_ioctl.py

gregory.p.smith python-checkins at python.org
Thu Mar 20 06:41:53 CET 2008


Author: gregory.p.smith
Date: Thu Mar 20 06:41:53 2008
New Revision: 61665

Modified:
   python/trunk/Lib/test/test_fcntl.py
   python/trunk/Lib/test/test_ioctl.py
Log:
Attempt to fix the Solaris Sparc 10 buildbot.  It was failing with an invalid
argument error on ioctl.  This was caused by the added test_fcntl ioctl test
that hard coded 0 as the fd to use.  Without a terminal, this fails on solaris.
(it passed from the command line on sol 10, both 32 and 64 bit)

Also, test_ioctl exists so I moved the test into there where it belongs.


Modified: python/trunk/Lib/test/test_fcntl.py
==============================================================================
--- python/trunk/Lib/test/test_fcntl.py	(original)
+++ python/trunk/Lib/test/test_fcntl.py	Thu Mar 20 06:41:53 2008
@@ -3,7 +3,6 @@
 OS/2+EMX doesn't support the file locking operations.
 
 """
-import struct
 import fcntl
 import os
 import struct
@@ -11,12 +10,7 @@
 import unittest
 from test.test_support import verbose, TESTFN, unlink, run_unittest
 
-# TODO - Write tests for ioctl(), flock() and lockf().
-
-try:
-    import termios
-except ImportError:
-    termios = None
+# TODO - Write tests for flock() and lockf().
 
 def get_lockdata():
     if sys.platform.startswith('atheos'):
@@ -88,29 +82,8 @@
         self.f.close()
 
 
-class TestIoctl(unittest.TestCase):
-    if termios:
-        def test_ioctl_signed_unsigned_code_param(self):
-            if termios.TIOCSWINSZ < 0:
-                set_winsz_opcode_maybe_neg = termios.TIOCSWINSZ
-                set_winsz_opcode_pos = termios.TIOCSWINSZ & 0xffffffffL
-            else:
-                set_winsz_opcode_pos = termios.TIOCSWINSZ
-                set_winsz_opcode_maybe_neg, = struct.unpack("i",
-                        struct.pack("I", termios.TIOCSWINSZ))
-
-            # We're just testing that these calls do not raise exceptions.
-            saved_winsz = fcntl.ioctl(0, termios.TIOCGWINSZ, "\0"*8)
-            our_winsz = struct.pack("HHHH",80,25,0,0)
-            # test both with a positive and potentially negative ioctl code
-            new_winsz = fcntl.ioctl(0, set_winsz_opcode_pos, our_winsz)
-            new_winsz = fcntl.ioctl(0, set_winsz_opcode_maybe_neg, our_winsz)
-            fcntl.ioctl(0, set_winsz_opcode_maybe_neg, saved_winsz)
-
-
 def test_main():
     run_unittest(TestFcntl)
-    run_unittest(TestIoctl)
 
 if __name__ == '__main__':
     test_main()

Modified: python/trunk/Lib/test/test_ioctl.py
==============================================================================
--- python/trunk/Lib/test/test_ioctl.py	(original)
+++ python/trunk/Lib/test/test_ioctl.py	Thu Mar 20 06:41:53 2008
@@ -14,6 +14,11 @@
 except IOError:
     raise TestSkipped("Unable to open /dev/tty")
 
+try:
+    import pty
+except ImportError:
+    pty = None
+
 class IoctlTests(unittest.TestCase):
     def test_ioctl(self):
         # If this process has been put into the background, TIOCGPGRP returns
@@ -34,6 +39,30 @@
         self.assertEquals(r, 0)
         self.assert_(rpgrp in ids, "%s not in %s" % (rpgrp, ids))
 
+    def test_ioctl_signed_unsigned_code_param(self):
+        if not pty:
+            raise TestSkipped('pty module required')
+        mfd, sfd = pty.openpty()
+        try:
+            if termios.TIOCSWINSZ < 0:
+                set_winsz_opcode_maybe_neg = termios.TIOCSWINSZ
+                set_winsz_opcode_pos = termios.TIOCSWINSZ & 0xffffffffL
+            else:
+                set_winsz_opcode_pos = termios.TIOCSWINSZ
+                set_winsz_opcode_maybe_neg, = struct.unpack("i",
+                        struct.pack("I", termios.TIOCSWINSZ))
+
+            # We're just testing that these calls do not raise exceptions.
+            saved_winsz = fcntl.ioctl(mfd, termios.TIOCGWINSZ, "\0"*8)
+            our_winsz = struct.pack("HHHH",80,25,0,0)
+            # test both with a positive and potentially negative ioctl code
+            new_winsz = fcntl.ioctl(mfd, set_winsz_opcode_pos, our_winsz)
+            new_winsz = fcntl.ioctl(mfd, set_winsz_opcode_maybe_neg, our_winsz)
+            fcntl.ioctl(mfd, set_winsz_opcode_maybe_neg, saved_winsz)
+        finally:
+            os.close(mfd)
+            os.close(sfd)
+
 def test_main():
     run_unittest(IoctlTests)
 


More information about the Python-checkins mailing list