aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/deprecated/python/subprocess32/testdata
diff options
context:
space:
mode:
authornkozlovskiy <nmk@ydb.tech>2023-10-02 18:57:38 +0300
committernkozlovskiy <nmk@ydb.tech>2023-10-02 19:39:06 +0300
commit6295ef4d23465c11296e898b9dc4524ad9592b5d (patch)
treefc0c852877b2c52f365a1f6ed0710955844338c2 /contrib/deprecated/python/subprocess32/testdata
parentde63c80b75948ecc13894854514d147840ff8430 (diff)
downloadydb-6295ef4d23465c11296e898b9dc4524ad9592b5d.tar.gz
oss ydb: fix dstool building and test run
Diffstat (limited to 'contrib/deprecated/python/subprocess32/testdata')
-rw-r--r--contrib/deprecated/python/subprocess32/testdata/fd_status.py34
-rw-r--r--contrib/deprecated/python/subprocess32/testdata/input_reader.py7
-rw-r--r--contrib/deprecated/python/subprocess32/testdata/qcat.py7
-rw-r--r--contrib/deprecated/python/subprocess32/testdata/qgrep.py10
-rw-r--r--contrib/deprecated/python/subprocess32/testdata/sigchild_ignore.py18
-rw-r--r--contrib/deprecated/python/subprocess32/testdata/ya.make19
6 files changed, 95 insertions, 0 deletions
diff --git a/contrib/deprecated/python/subprocess32/testdata/fd_status.py b/contrib/deprecated/python/subprocess32/testdata/fd_status.py
new file mode 100644
index 0000000000..67fb41c0af
--- /dev/null
+++ b/contrib/deprecated/python/subprocess32/testdata/fd_status.py
@@ -0,0 +1,34 @@
+"""When called as a script, print a comma-separated list of the open
+file descriptors on stdout.
+
+Usage:
+fd_stats.py: check all file descriptors
+fd_status.py fd1 fd2 ...: check only specified file descriptors
+"""
+
+import errno
+import os
+import stat
+import sys
+
+if __name__ == "__main__":
+ fds = []
+ if len(sys.argv) == 1:
+ try:
+ _MAXFD = os.sysconf("SC_OPEN_MAX")
+ except:
+ _MAXFD = 256
+ test_fds = range(0, _MAXFD)
+ else:
+ test_fds = map(int, sys.argv[1:])
+ for fd in test_fds:
+ try:
+ st = os.fstat(fd)
+ except OSError, e:
+ if e.errno == errno.EBADF:
+ continue
+ raise
+ # Ignore Solaris door files
+ if not hasattr(stat, 'S_ISDOOR') or not stat.S_ISDOOR(st.st_mode):
+ fds.append(fd)
+ print ','.join(map(str, fds))
diff --git a/contrib/deprecated/python/subprocess32/testdata/input_reader.py b/contrib/deprecated/python/subprocess32/testdata/input_reader.py
new file mode 100644
index 0000000000..1dc3191ad1
--- /dev/null
+++ b/contrib/deprecated/python/subprocess32/testdata/input_reader.py
@@ -0,0 +1,7 @@
+"""When called as a script, consumes the input"""
+
+import sys
+
+if __name__ == "__main__":
+ for line in sys.stdin:
+ pass
diff --git a/contrib/deprecated/python/subprocess32/testdata/qcat.py b/contrib/deprecated/python/subprocess32/testdata/qcat.py
new file mode 100644
index 0000000000..fe6f9db25c
--- /dev/null
+++ b/contrib/deprecated/python/subprocess32/testdata/qcat.py
@@ -0,0 +1,7 @@
+"""When ran as a script, simulates cat with no arguments."""
+
+import sys
+
+if __name__ == "__main__":
+ for line in sys.stdin:
+ sys.stdout.write(line)
diff --git a/contrib/deprecated/python/subprocess32/testdata/qgrep.py b/contrib/deprecated/python/subprocess32/testdata/qgrep.py
new file mode 100644
index 0000000000..69906379a9
--- /dev/null
+++ b/contrib/deprecated/python/subprocess32/testdata/qgrep.py
@@ -0,0 +1,10 @@
+"""When called with a single argument, simulated fgrep with a single
+argument and no options."""
+
+import sys
+
+if __name__ == "__main__":
+ pattern = sys.argv[1]
+ for line in sys.stdin:
+ if pattern in line:
+ sys.stdout.write(line)
diff --git a/contrib/deprecated/python/subprocess32/testdata/sigchild_ignore.py b/contrib/deprecated/python/subprocess32/testdata/sigchild_ignore.py
new file mode 100644
index 0000000000..ba5ccf2cf0
--- /dev/null
+++ b/contrib/deprecated/python/subprocess32/testdata/sigchild_ignore.py
@@ -0,0 +1,18 @@
+import signal, subprocess32, sys, time
+# On Linux this causes os.waitpid to fail with OSError as the OS has already
+# reaped our child process. The wait() passing the OSError on to the caller
+# and causing us to exit with an error is what we are testing against.
+sig_child = getattr(signal, 'SIGCLD', None)
+if sig_child is None:
+ sig_child = getattr(signal, 'SIGCHLD')
+signal.signal(sig_child, signal.SIG_IGN)
+subprocess32.Popen([sys.executable, '-c', 'print("albatross")']).wait()
+# Also ensure poll() handles an errno.ECHILD appropriately.
+p = subprocess32.Popen([sys.executable, '-c', 'print("albatross")'])
+num_polls = 0
+while p.poll() is None:
+ # Waiting for the process to finish.
+ time.sleep(0.01) # Avoid being a CPU busy loop.
+ num_polls += 1
+ if num_polls > 3000:
+ raise RuntimeError('poll should have returned 0 within 30 seconds')
diff --git a/contrib/deprecated/python/subprocess32/testdata/ya.make b/contrib/deprecated/python/subprocess32/testdata/ya.make
new file mode 100644
index 0000000000..4611e078bb
--- /dev/null
+++ b/contrib/deprecated/python/subprocess32/testdata/ya.make
@@ -0,0 +1,19 @@
+PY2TEST()
+
+SIZE(MEDIUM)
+
+NO_LINT()
+
+SRCDIR(
+ contrib/deprecated/python/subprocess32
+)
+
+TEST_SRCS(
+ test_subprocess32.py
+)
+
+TEST_CWD(
+ contrib/deprecated/python/subprocess32
+)
+
+END()