summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_posix.py
diff options
context:
space:
mode:
authorpxinwr <peixing.xin@windriver.com>2020-12-15 21:21:53 (GMT)
committerGitHub <noreply@github.com>2020-12-15 21:21:53 (GMT)
commit9a0dea6137a9fe295c8b03aaa08a74c8572ecc4e (patch)
treef20bb665411d639b26bb486c82e57f8f8fbbd56f /Lib/test/test_posix.py
parente1e3c2dac3da8a179f57bd3e3309ab65385bcc8a (diff)
downloadcpython-9a0dea6137a9fe295c8b03aaa08a74c8572ecc4e.zip
cpython-9a0dea6137a9fe295c8b03aaa08a74c8572ecc4e.tar.gz
cpython-9a0dea6137a9fe295c8b03aaa08a74c8572ecc4e.tar.bz2
bpo-31904: Skip some tests of changing owner in _test_all_chown_common() on VxWorks (GH-23716)
Diffstat (limited to 'Lib/test/test_posix.py')
-rw-r--r--Lib/test/test_posix.py13
1 files changed, 11 insertions, 2 deletions
diff --git a/Lib/test/test_posix.py b/Lib/test/test_posix.py
index cd18a49..588c869 100644
--- a/Lib/test/test_posix.py
+++ b/Lib/test/test_posix.py
@@ -724,11 +724,20 @@ class PosixTester(unittest.TestCase):
chown_func(first_param, uid, -1)
check_stat(uid, gid)
- if uid == 0:
+ if sys.platform == "vxworks":
+ # On VxWorks, root user id is 1 and 0 means no login user:
+ # both are super users.
+ is_root = (uid in (0, 1))
+ else:
+ is_root = (uid == 0)
+ if is_root:
# Try an amusingly large uid/gid to make sure we handle
# large unsigned values. (chown lets you use any
# uid/gid you like, even if they aren't defined.)
#
+ # On VxWorks uid_t is defined as unsigned short. A big
+ # value greater than 65535 will result in underflow error.
+ #
# This problem keeps coming up:
# http://bugs.python.org/issue1747858
# http://bugs.python.org/issue4591
@@ -738,7 +747,7 @@ class PosixTester(unittest.TestCase):
# This part of the test only runs when run as root.
# Only scary people run their tests as root.
- big_value = 2**31
+ big_value = (2**31 if sys.platform != "vxworks" else 2**15)
chown_func(first_param, big_value, big_value)
check_stat(big_value, big_value)
chown_func(first_param, -1, -1)