diff options
author | pxinwr <peixing.xin@windriver.com> | 2020-12-15 21:21:53 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-15 21:21:53 (GMT) |
commit | 9a0dea6137a9fe295c8b03aaa08a74c8572ecc4e (patch) | |
tree | f20bb665411d639b26bb486c82e57f8f8fbbd56f /Lib/test/test_posix.py | |
parent | e1e3c2dac3da8a179f57bd3e3309ab65385bcc8a (diff) | |
download | cpython-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.py | 13 |
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) |