mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-08-10 11:50:29 +00:00
disable python ioctl test for gh-actions
This commit is contained in:
parent
2b54f1bcf6
commit
026f01b50b
1 changed files with 20 additions and 14 deletions
34
third_party/python/Lib/test/test_ioctl.py
vendored
34
third_party/python/Lib/test/test_ioctl.py
vendored
|
@ -3,17 +3,20 @@ import unittest
|
||||||
from test.support import import_module, get_attribute
|
from test.support import import_module, get_attribute
|
||||||
import os, struct
|
import os, struct
|
||||||
|
|
||||||
fcntl = import_module('fcntl')
|
fcntl = import_module("fcntl")
|
||||||
termios = import_module('termios')
|
termios = import_module("termios")
|
||||||
get_attribute(termios, 'TIOCGPGRP') #Can't run tests without this feature
|
get_attribute(termios, "TIOCGPGRP") # Can't run tests without this feature
|
||||||
|
|
||||||
if __name__ == 'PYOBJ.COM':
|
if __name__ == "PYOBJ.COM":
|
||||||
import fcntl
|
import fcntl
|
||||||
import termios
|
import termios
|
||||||
|
|
||||||
try:
|
try:
|
||||||
tty = open("/dev/tty", "rb")
|
tty = open("/dev/tty", "rb")
|
||||||
except OSError:
|
except OSError:
|
||||||
|
# todo: gh-runners fail on skiptest cosmo issue #431
|
||||||
|
import sys
|
||||||
|
sys.exit()
|
||||||
raise unittest.SkipTest("Unable to open /dev/tty")
|
raise unittest.SkipTest("Unable to open /dev/tty")
|
||||||
else:
|
else:
|
||||||
# Skip if another process is in foreground
|
# Skip if another process is in foreground
|
||||||
|
@ -21,8 +24,9 @@ else:
|
||||||
tty.close()
|
tty.close()
|
||||||
rpgrp = struct.unpack("i", r)[0]
|
rpgrp = struct.unpack("i", r)[0]
|
||||||
if rpgrp not in (os.getpgrp(), os.getsid(0)):
|
if rpgrp not in (os.getpgrp(), os.getsid(0)):
|
||||||
raise unittest.SkipTest("Neither the process group nor the session "
|
raise unittest.SkipTest(
|
||||||
"are attached to /dev/tty")
|
"Neither the process group nor the session " "are attached to /dev/tty"
|
||||||
|
)
|
||||||
del tty, r, rpgrp
|
del tty, r, rpgrp
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -30,6 +34,7 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
pty = None
|
pty = None
|
||||||
|
|
||||||
|
|
||||||
class IoctlTests(unittest.TestCase):
|
class IoctlTests(unittest.TestCase):
|
||||||
def test_ioctl(self):
|
def test_ioctl(self):
|
||||||
# If this process has been put into the background, TIOCGPGRP returns
|
# If this process has been put into the background, TIOCGPGRP returns
|
||||||
|
@ -41,7 +46,7 @@ class IoctlTests(unittest.TestCase):
|
||||||
self.assertIn(rpgrp, ids)
|
self.assertIn(rpgrp, ids)
|
||||||
|
|
||||||
def _check_ioctl_mutate_len(self, nbytes=None):
|
def _check_ioctl_mutate_len(self, nbytes=None):
|
||||||
buf = array.array('i')
|
buf = array.array("i")
|
||||||
intsize = buf.itemsize
|
intsize = buf.itemsize
|
||||||
ids = (os.getpgrp(), os.getsid(0))
|
ids = (os.getpgrp(), os.getsid(0))
|
||||||
# A fill value unlikely to be in `ids`
|
# A fill value unlikely to be in `ids`
|
||||||
|
@ -49,7 +54,7 @@ class IoctlTests(unittest.TestCase):
|
||||||
if nbytes is not None:
|
if nbytes is not None:
|
||||||
# Extend the buffer so that it is exactly `nbytes` bytes long
|
# Extend the buffer so that it is exactly `nbytes` bytes long
|
||||||
buf.extend([fill] * (nbytes // intsize))
|
buf.extend([fill] * (nbytes // intsize))
|
||||||
self.assertEqual(len(buf) * intsize, nbytes) # sanity check
|
self.assertEqual(len(buf) * intsize, nbytes) # sanity check
|
||||||
else:
|
else:
|
||||||
buf.append(fill)
|
buf.append(fill)
|
||||||
with open("/dev/tty", "rb") as tty:
|
with open("/dev/tty", "rb") as tty:
|
||||||
|
@ -71,18 +76,19 @@ class IoctlTests(unittest.TestCase):
|
||||||
self._check_ioctl_mutate_len(2048)
|
self._check_ioctl_mutate_len(2048)
|
||||||
|
|
||||||
def test_ioctl_signed_unsigned_code_param(self):
|
def test_ioctl_signed_unsigned_code_param(self):
|
||||||
if not pty or not hasattr(os, 'openpty'):
|
if not pty or not hasattr(os, "openpty"):
|
||||||
raise unittest.SkipTest('pty module required')
|
raise unittest.SkipTest("pty module required")
|
||||||
mfd, sfd = pty.openpty()
|
mfd, sfd = pty.openpty()
|
||||||
try:
|
try:
|
||||||
if termios.TIOCSWINSZ < 0:
|
if termios.TIOCSWINSZ < 0:
|
||||||
set_winsz_opcode_maybe_neg = termios.TIOCSWINSZ
|
set_winsz_opcode_maybe_neg = termios.TIOCSWINSZ
|
||||||
set_winsz_opcode_pos = termios.TIOCSWINSZ & 0xffffffff
|
set_winsz_opcode_pos = termios.TIOCSWINSZ & 0xFFFFFFFF
|
||||||
else:
|
else:
|
||||||
set_winsz_opcode_pos = termios.TIOCSWINSZ
|
set_winsz_opcode_pos = termios.TIOCSWINSZ
|
||||||
set_winsz_opcode_maybe_neg, = struct.unpack("i",
|
(set_winsz_opcode_maybe_neg,) = struct.unpack(
|
||||||
struct.pack("I", termios.TIOCSWINSZ))
|
"i", struct.pack("I", termios.TIOCSWINSZ)
|
||||||
our_winsz = struct.pack("HHHH",80,25,0,0)
|
)
|
||||||
|
our_winsz = struct.pack("HHHH", 80, 25, 0, 0)
|
||||||
# test both with a positive and potentially negative ioctl code
|
# 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_pos, our_winsz)
|
||||||
new_winsz = fcntl.ioctl(mfd, set_winsz_opcode_maybe_neg, our_winsz)
|
new_winsz = fcntl.ioctl(mfd, set_winsz_opcode_maybe_neg, our_winsz)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue