2010-03-17 21:23:44 -03:00
|
|
|
import sys
|
2003-04-15 08:10:33 -03:00
|
|
|
import unittest
|
2008-05-20 18:35:26 -03:00
|
|
|
from test import support
|
2003-04-15 08:10:33 -03:00
|
|
|
|
Merged revisions 70734,70775,70856,70874,70876-70877 via svnmerge
........
r70734 | r.david.murray | 2009-03-30 15:04:00 -0400 (Mon, 30 Mar 2009) | 7 lines
Add import_function method to test.test_support, and modify a number of
tests that expect to be skipped if imports fail or functions don't
exist to use import_function and import_module. The ultimate goal is
to change regrtest to not skip automatically on ImportError. Checking
in now to make sure the buldbots don't show any errors on platforms
I can't direct test on.
........
r70775 | r.david.murray | 2009-03-30 19:05:48 -0400 (Mon, 30 Mar 2009) | 4 lines
Change more tests to use import_module for the modules that
should cause tests to be skipped. Also rename import_function
to the more descriptive get_attribute and add a docstring.
........
r70856 | r.david.murray | 2009-03-31 14:32:17 -0400 (Tue, 31 Mar 2009) | 7 lines
A few more test skips via import_module, and change import_module to
return the error message produced by importlib, so that if an import
in the package whose import is being wrapped is what failed the skip
message will contain the name of that module instead of the name of the
wrapped module. Also fixed formatting of some previous comments.
........
r70874 | r.david.murray | 2009-03-31 15:33:15 -0400 (Tue, 31 Mar 2009) | 5 lines
Improve test_support.import_module docstring, remove
deprecated flag from get_attribute since it isn't likely
to do anything useful.
........
r70876 | r.david.murray | 2009-03-31 15:49:15 -0400 (Tue, 31 Mar 2009) | 4 lines
Remove the regrtest check that turns any ImportError into a skipped test.
Hopefully all modules whose imports legitimately result in a skipped
test have been properly wrapped by the previous commits.
........
r70877 | r.david.murray | 2009-03-31 15:57:24 -0400 (Tue, 31 Mar 2009) | 2 lines
Add NEWS entry for regrtest change.
........
2009-03-31 20:16:50 -03:00
|
|
|
pwd = support.import_module('pwd')
|
1996-12-11 12:53:51 -04:00
|
|
|
|
2017-11-25 12:32:27 -04:00
|
|
|
@unittest.skipUnless(hasattr(pwd, 'getpwall'), 'Does not have getpwall()')
|
2003-04-15 08:10:33 -03:00
|
|
|
class PwdTest(unittest.TestCase):
|
|
|
|
|
|
|
|
def test_values(self):
|
2017-11-25 12:32:27 -04:00
|
|
|
entries = pwd.getpwall()
|
2003-04-15 08:10:33 -03:00
|
|
|
|
|
|
|
for e in entries:
|
|
|
|
self.assertEqual(len(e), 7)
|
|
|
|
self.assertEqual(e[0], e.pw_name)
|
2010-01-24 15:26:24 -04:00
|
|
|
self.assertIsInstance(e.pw_name, str)
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertEqual(e[1], e.pw_passwd)
|
2010-01-24 15:26:24 -04:00
|
|
|
self.assertIsInstance(e.pw_passwd, str)
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertEqual(e[2], e.pw_uid)
|
2010-01-24 15:26:24 -04:00
|
|
|
self.assertIsInstance(e.pw_uid, int)
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertEqual(e[3], e.pw_gid)
|
2010-01-24 15:26:24 -04:00
|
|
|
self.assertIsInstance(e.pw_gid, int)
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertEqual(e[4], e.pw_gecos)
|
2020-04-14 15:11:46 -03:00
|
|
|
self.assertIn(type(e.pw_gecos), (str, type(None)))
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertEqual(e[5], e.pw_dir)
|
2010-01-24 15:26:24 -04:00
|
|
|
self.assertIsInstance(e.pw_dir, str)
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertEqual(e[6], e.pw_shell)
|
2010-01-24 15:26:24 -04:00
|
|
|
self.assertIsInstance(e.pw_shell, str)
|
2003-04-15 08:10:33 -03:00
|
|
|
|
2003-04-15 12:39:08 -03:00
|
|
|
# The following won't work, because of duplicate entries
|
|
|
|
# for one uid
|
|
|
|
# self.assertEqual(pwd.getpwuid(e.pw_uid), e)
|
|
|
|
# instead of this collect all entries for one uid
|
2013-12-08 02:20:35 -04:00
|
|
|
# and check afterwards (done in test_values_extended)
|
|
|
|
|
|
|
|
def test_values_extended(self):
|
2017-11-25 12:32:27 -04:00
|
|
|
entries = pwd.getpwall()
|
2013-12-08 02:20:35 -04:00
|
|
|
entriesbyname = {}
|
|
|
|
entriesbyuid = {}
|
|
|
|
|
|
|
|
if len(entries) > 1000: # Huge passwd file (NIS?) -- skip this test
|
|
|
|
self.skipTest('passwd file is huge; extended test skipped')
|
|
|
|
|
|
|
|
for e in entries:
|
2003-04-22 08:05:57 -03:00
|
|
|
entriesbyname.setdefault(e.pw_name, []).append(e)
|
2003-04-15 12:39:08 -03:00
|
|
|
entriesbyuid.setdefault(e.pw_uid, []).append(e)
|
|
|
|
|
|
|
|
# check whether the entry returned by getpwuid()
|
|
|
|
# for each uid is among those from getpwall() for this uid
|
|
|
|
for e in entries:
|
2005-12-12 16:53:40 -04:00
|
|
|
if not e[0] or e[0] == '+':
|
|
|
|
continue # skip NIS entries etc.
|
2010-01-18 20:09:57 -04:00
|
|
|
self.assertIn(pwd.getpwnam(e.pw_name), entriesbyname[e.pw_name])
|
|
|
|
self.assertIn(pwd.getpwuid(e.pw_uid), entriesbyuid[e.pw_uid])
|
2003-04-15 08:10:33 -03:00
|
|
|
|
|
|
|
def test_errors(self):
|
|
|
|
self.assertRaises(TypeError, pwd.getpwuid)
|
2013-02-11 14:32:47 -04:00
|
|
|
self.assertRaises(TypeError, pwd.getpwuid, 3.14)
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertRaises(TypeError, pwd.getpwnam)
|
2013-02-11 14:32:47 -04:00
|
|
|
self.assertRaises(TypeError, pwd.getpwnam, 42)
|
2017-11-25 12:32:27 -04:00
|
|
|
self.assertRaises(TypeError, pwd.getpwall, 42)
|
2003-04-15 08:10:33 -03:00
|
|
|
|
|
|
|
# try to get some errors
|
|
|
|
bynames = {}
|
|
|
|
byuids = {}
|
2017-11-25 12:32:27 -04:00
|
|
|
for (n, p, u, g, gecos, d, s) in pwd.getpwall():
|
2003-04-15 08:10:33 -03:00
|
|
|
bynames[n] = u
|
|
|
|
byuids[u] = n
|
|
|
|
|
2007-02-11 14:54:18 -04:00
|
|
|
allnames = list(bynames.keys())
|
2003-04-15 08:10:33 -03:00
|
|
|
namei = 0
|
|
|
|
fakename = allnames[namei]
|
|
|
|
while fakename in bynames:
|
Merged revisions 56125-56153 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
........
r56127 | georg.brandl | 2007-06-30 09:32:49 +0200 (Sat, 30 Jun 2007) | 2 lines
Fix a place where floor division would be in order.
........
r56135 | guido.van.rossum | 2007-07-01 06:13:54 +0200 (Sun, 01 Jul 2007) | 28 lines
Make map() and filter() identical to itertools.imap() and .ifilter(),
respectively.
I fixed two bootstrap issues, due to the dynamic import of itertools:
1. Starting python requires that map() and filter() are not used until
site.py has added build/lib.<arch> to sys.path.
2. Building python requires that setup.py and distutils and everything
they use is free of map() and filter() calls.
Beyond this, I only fixed the tests in test_builtin.py.
Others, please help fixing the remaining tests that are now broken!
The fixes are usually simple:
a. map(None, X) -> list(X)
b. map(F, X) -> list(map(F, X))
c. map(lambda x: F(x), X) -> [F(x) for x in X]
d. filter(F, X) -> list(filter(F, X))
e. filter(lambda x: P(x), X) -> [x for x in X if P(x)]
Someone, please also contribute a fixer for 2to3 to do this.
It can leave map()/filter() calls alone that are already
inside a list() or sorted() call or for-loop.
Only in rare cases have I seen code that depends on map() of lists
of different lengths going to the end of the longest, or on filter()
of a string or tuple returning an object of the same type; these
will need more thought to fix.
........
r56136 | guido.van.rossum | 2007-07-01 06:22:01 +0200 (Sun, 01 Jul 2007) | 3 lines
Make it so that test_decimal fails instead of hangs, to help automated
test runners.
........
r56139 | georg.brandl | 2007-07-01 18:20:58 +0200 (Sun, 01 Jul 2007) | 2 lines
Fix a few test cases after the map->imap change.
........
r56142 | neal.norwitz | 2007-07-02 06:38:12 +0200 (Mon, 02 Jul 2007) | 1 line
Get a bunch more tests passing after converting map/filter to return iterators.
........
r56147 | guido.van.rossum | 2007-07-02 15:32:02 +0200 (Mon, 02 Jul 2007) | 4 lines
Fix the remaining failing unit tests (at least on OSX).
Also tweaked urllib2 so it doesn't raise socket.gaierror when
all network interfaces are turned off.
........
2007-07-03 05:25:58 -03:00
|
|
|
chars = list(fakename)
|
2007-05-07 19:24:25 -03:00
|
|
|
for i in range(len(chars)):
|
2003-04-15 08:10:33 -03:00
|
|
|
if chars[i] == 'z':
|
|
|
|
chars[i] = 'A'
|
|
|
|
break
|
|
|
|
elif chars[i] == 'Z':
|
|
|
|
continue
|
|
|
|
else:
|
|
|
|
chars[i] = chr(ord(chars[i]) + 1)
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
namei = namei + 1
|
|
|
|
try:
|
|
|
|
fakename = allnames[namei]
|
|
|
|
except IndexError:
|
|
|
|
# should never happen... if so, just forget it
|
|
|
|
break
|
Merged revisions 56125-56153 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
........
r56127 | georg.brandl | 2007-06-30 09:32:49 +0200 (Sat, 30 Jun 2007) | 2 lines
Fix a place where floor division would be in order.
........
r56135 | guido.van.rossum | 2007-07-01 06:13:54 +0200 (Sun, 01 Jul 2007) | 28 lines
Make map() and filter() identical to itertools.imap() and .ifilter(),
respectively.
I fixed two bootstrap issues, due to the dynamic import of itertools:
1. Starting python requires that map() and filter() are not used until
site.py has added build/lib.<arch> to sys.path.
2. Building python requires that setup.py and distutils and everything
they use is free of map() and filter() calls.
Beyond this, I only fixed the tests in test_builtin.py.
Others, please help fixing the remaining tests that are now broken!
The fixes are usually simple:
a. map(None, X) -> list(X)
b. map(F, X) -> list(map(F, X))
c. map(lambda x: F(x), X) -> [F(x) for x in X]
d. filter(F, X) -> list(filter(F, X))
e. filter(lambda x: P(x), X) -> [x for x in X if P(x)]
Someone, please also contribute a fixer for 2to3 to do this.
It can leave map()/filter() calls alone that are already
inside a list() or sorted() call or for-loop.
Only in rare cases have I seen code that depends on map() of lists
of different lengths going to the end of the longest, or on filter()
of a string or tuple returning an object of the same type; these
will need more thought to fix.
........
r56136 | guido.van.rossum | 2007-07-01 06:22:01 +0200 (Sun, 01 Jul 2007) | 3 lines
Make it so that test_decimal fails instead of hangs, to help automated
test runners.
........
r56139 | georg.brandl | 2007-07-01 18:20:58 +0200 (Sun, 01 Jul 2007) | 2 lines
Fix a few test cases after the map->imap change.
........
r56142 | neal.norwitz | 2007-07-02 06:38:12 +0200 (Mon, 02 Jul 2007) | 1 line
Get a bunch more tests passing after converting map/filter to return iterators.
........
r56147 | guido.van.rossum | 2007-07-02 15:32:02 +0200 (Mon, 02 Jul 2007) | 4 lines
Fix the remaining failing unit tests (at least on OSX).
Also tweaked urllib2 so it doesn't raise socket.gaierror when
all network interfaces are turned off.
........
2007-07-03 05:25:58 -03:00
|
|
|
fakename = ''.join(chars)
|
1996-12-11 12:53:51 -04:00
|
|
|
|
2003-04-15 08:10:33 -03:00
|
|
|
self.assertRaises(KeyError, pwd.getpwnam, fakename)
|
1996-12-11 12:53:51 -04:00
|
|
|
|
2010-03-17 21:23:44 -03:00
|
|
|
# In some cases, byuids isn't a complete list of all users in the
|
|
|
|
# system, so if we try to pick a value not in byuids (via a perturbing
|
|
|
|
# loop, say), pwd.getpwuid() might still be able to find data for that
|
|
|
|
# uid. Using sys.maxint may provoke the same problems, but hopefully
|
|
|
|
# it will be a more repeatable failure.
|
|
|
|
fakeuid = sys.maxsize
|
|
|
|
self.assertNotIn(fakeuid, byuids)
|
2017-11-25 12:32:27 -04:00
|
|
|
self.assertRaises(KeyError, pwd.getpwuid, fakeuid)
|
2000-10-23 14:22:08 -03:00
|
|
|
|
2013-02-11 14:32:47 -04:00
|
|
|
# -1 shouldn't be a valid uid because it has a special meaning in many
|
|
|
|
# uid-related functions
|
2017-11-25 12:32:27 -04:00
|
|
|
self.assertRaises(KeyError, pwd.getpwuid, -1)
|
2013-02-11 14:32:47 -04:00
|
|
|
# should be out of uid_t range
|
|
|
|
self.assertRaises(KeyError, pwd.getpwuid, 2**128)
|
|
|
|
self.assertRaises(KeyError, pwd.getpwuid, -2**128)
|
|
|
|
|
2003-04-15 08:10:33 -03:00
|
|
|
if __name__ == "__main__":
|
2015-04-13 17:00:43 -03:00
|
|
|
unittest.main()
|