Skip to content

Commit

Permalink
gh-117061: Fix test_posix.test_sched_setaffinity() on RHEL9 (#117126)
Browse files Browse the repository at this point in the history
On RHEL9, sched_setaffinity(0, []) does not fail.
  • Loading branch information
vstinner committed Mar 21, 2024
1 parent 0907871 commit 50f9b0b
Showing 1 changed file with 10 additions and 1 deletion.
11 changes: 10 additions & 1 deletion Lib/test/test_posix.py
Expand Up @@ -1335,12 +1335,21 @@ def test_sched_getaffinity(self):
def test_sched_setaffinity(self):
mask = posix.sched_getaffinity(0)
self.addCleanup(posix.sched_setaffinity, 0, list(mask))

if len(mask) > 1:
# Empty masks are forbidden
mask.pop()
posix.sched_setaffinity(0, mask)
self.assertEqual(posix.sched_getaffinity(0), mask)
self.assertRaises(OSError, posix.sched_setaffinity, 0, [])

try:
posix.sched_setaffinity(0, [])
# gh-117061: On RHEL9, sched_setaffinity(0, []) does not fail
except OSError:
# sched_setaffinity() manual page documents EINVAL error
# when the mask is empty.
pass

self.assertRaises(ValueError, posix.sched_setaffinity, 0, [-10])
self.assertRaises(ValueError, posix.sched_setaffinity, 0, map(int, "0X"))
self.assertRaises(OverflowError, posix.sched_setaffinity, 0, [1<<128])
Expand Down

0 comments on commit 50f9b0b

Please sign in to comment.