diff -r 5f003d725619 Lib/test/test_posix.py --- a/Lib/test/test_posix.py Wed Jul 27 19:42:05 2011 +0200 +++ b/Lib/test/test_posix.py Wed Jul 27 21:14:03 2011 +0200 @@ -16,6 +16,7 @@ import tempfile import unittest import warnings +import platform _DUMMY_SYMLINK = os.path.join(tempfile.gettempdir(), support.TESTFN + '-dummy-symlink') @@ -387,6 +388,9 @@ def _test_all_chown_common(self, chown_func, first_param): """Common code for chown, fchown and lchown tests.""" + # test a successful chown call + chown_func(first_param, os.getuid(), os.getgid()) + if os.getuid() == 0: try: # Many linux distros have a nfsnobody user as MAX_UID-2 @@ -398,12 +402,15 @@ chown_func(first_param, ent.pw_uid, ent.pw_gid) except KeyError: pass + elif platform.system() in ('HP-UX', 'SunOS'): + # HP-UX and Solaris allow a non-root user to chown to root (issue + # #5113) + raise unittest.SkipTest("Skipping because of non-standard chown() " + "behavior") else: # non-root cannot chown to root, raises OSError self.assertRaises(OSError, chown_func, first_param, 0, 0) - # test a successful chown call - chown_func(first_param, os.getuid(), os.getgid()) @unittest.skipUnless(hasattr(posix, 'chown'), "test needs os.chown()") def test_chown(self):