| 
									
										
										
										
											2010-03-18 00:23:44 +00:00
										 |  |  | import sys | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  | import unittest | 
					
						
							| 
									
										
										
										
											2020-06-25 18:38:51 +08:00
										 |  |  | from test.support import import_helper | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-25 18:38:51 +08:00
										 |  |  | pwd = import_helper.import_module('pwd') | 
					
						
							| 
									
										
										
										
											1996-12-11 16:53:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-25 17:32:27 +01:00
										 |  |  | @unittest.skipUnless(hasattr(pwd, 'getpwall'), 'Does not have getpwall()') | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  | class PwdTest(unittest.TestCase): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_values(self): | 
					
						
							| 
									
										
										
										
											2017-11-25 17:32:27 +01:00
										 |  |  |         entries = pwd.getpwall() | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         for e in entries: | 
					
						
							|  |  |  |             self.assertEqual(len(e), 7) | 
					
						
							|  |  |  |             self.assertEqual(e[0], e.pw_name) | 
					
						
							| 
									
										
										
										
											2010-01-24 19:26:24 +00:00
										 |  |  |             self.assertIsInstance(e.pw_name, str) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |             self.assertEqual(e[1], e.pw_passwd) | 
					
						
							| 
									
										
										
										
											2010-01-24 19:26:24 +00:00
										 |  |  |             self.assertIsInstance(e.pw_passwd, str) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |             self.assertEqual(e[2], e.pw_uid) | 
					
						
							| 
									
										
										
										
											2010-01-24 19:26:24 +00:00
										 |  |  |             self.assertIsInstance(e.pw_uid, int) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |             self.assertEqual(e[3], e.pw_gid) | 
					
						
							| 
									
										
										
										
											2010-01-24 19:26:24 +00:00
										 |  |  |             self.assertIsInstance(e.pw_gid, int) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |             self.assertEqual(e[4], e.pw_gecos) | 
					
						
							| 
									
										
										
										
											2020-04-14 12:11:46 -06:00
										 |  |  |             self.assertIn(type(e.pw_gecos), (str, type(None))) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |             self.assertEqual(e[5], e.pw_dir) | 
					
						
							| 
									
										
										
										
											2010-01-24 19:26:24 +00:00
										 |  |  |             self.assertIsInstance(e.pw_dir, str) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |             self.assertEqual(e[6], e.pw_shell) | 
					
						
							| 
									
										
										
										
											2010-01-24 19:26:24 +00:00
										 |  |  |             self.assertIsInstance(e.pw_shell, str) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-04-15 15:39:08 +00: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 00:20:35 -06:00
										 |  |  |             # and check afterwards (done in test_values_extended) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_values_extended(self): | 
					
						
							| 
									
										
										
										
											2017-11-25 17:32:27 +01:00
										 |  |  |         entries = pwd.getpwall() | 
					
						
							| 
									
										
										
										
											2013-12-08 00:20:35 -06: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 11:05:57 +00:00
										 |  |  |             entriesbyname.setdefault(e.pw_name, []).append(e) | 
					
						
							| 
									
										
										
										
											2003-04-15 15:39:08 +00: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 20:53:40 +00:00
										 |  |  |             if not e[0] or e[0] == '+': | 
					
						
							|  |  |  |                 continue # skip NIS entries etc. | 
					
						
							| 
									
										
										
										
											2010-01-19 00:09:57 +00: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 11:10:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_errors(self): | 
					
						
							|  |  |  |         self.assertRaises(TypeError, pwd.getpwuid) | 
					
						
							| 
									
										
										
										
											2013-02-11 20:32:47 +02:00
										 |  |  |         self.assertRaises(TypeError, pwd.getpwuid, 3.14) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |         self.assertRaises(TypeError, pwd.getpwnam) | 
					
						
							| 
									
										
										
										
											2013-02-11 20:32:47 +02:00
										 |  |  |         self.assertRaises(TypeError, pwd.getpwnam, 42) | 
					
						
							| 
									
										
										
										
											2017-11-25 17:32:27 +01:00
										 |  |  |         self.assertRaises(TypeError, pwd.getpwall, 42) | 
					
						
							| 
									
										
										
										
											2022-08-07 01:53:19 +09:00
										 |  |  |         # embedded null character | 
					
						
							|  |  |  |         self.assertRaisesRegex(ValueError, 'null', pwd.getpwnam, 'a\x00b') | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # try to get some errors | 
					
						
							|  |  |  |         bynames = {} | 
					
						
							|  |  |  |         byuids = {} | 
					
						
							| 
									
										
										
										
											2017-11-25 17:32:27 +01:00
										 |  |  |         for (n, p, u, g, gecos, d, s) in pwd.getpwall(): | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |             bynames[n] = u | 
					
						
							|  |  |  |             byuids[u] = n | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-11 18:54:18 +00:00
										 |  |  |         allnames = list(bynames.keys()) | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |         namei = 0 | 
					
						
							| 
									
										
										
										
											2022-02-05 21:52:01 +02:00
										 |  |  |         fakename = allnames[namei] if allnames else "invaliduser" | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |         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 08:25:58 +00:00
										 |  |  |             chars = list(fakename) | 
					
						
							| 
									
										
										
										
											2007-05-07 22:24:25 +00:00
										 |  |  |             for i in range(len(chars)): | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00: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 08:25:58 +00:00
										 |  |  |             fakename = ''.join(chars) | 
					
						
							| 
									
										
										
										
											1996-12-11 16:53:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-04-15 11:10:33 +00:00
										 |  |  |         self.assertRaises(KeyError, pwd.getpwnam, fakename) | 
					
						
							| 
									
										
										
										
											1996-12-11 16:53:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-18 00:23:44 +00: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 17:32:27 +01:00
										 |  |  |         self.assertRaises(KeyError, pwd.getpwuid, fakeuid) | 
					
						
							| 
									
										
										
										
											2000-10-23 17:22:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-11 20:32:47 +02:00
										 |  |  |         # -1 shouldn't be a valid uid because it has a special meaning in many | 
					
						
							|  |  |  |         # uid-related functions | 
					
						
							| 
									
										
										
										
											2017-11-25 17:32:27 +01:00
										 |  |  |         self.assertRaises(KeyError, pwd.getpwuid, -1) | 
					
						
							| 
									
										
										
										
											2013-02-11 20:32:47 +02: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 11:10:33 +00:00
										 |  |  | if __name__ == "__main__": | 
					
						
							| 
									
										
										
										
											2015-04-13 15:00:43 -05:00
										 |  |  |     unittest.main() |