blob: 2c3ab296a8b765d053d69498f80e170331da9b5c [file] [log] [blame]
Fred Drake5b811be2001-05-18 21:38:52 +00001"""Test script for the grp module."""
2
Roger E. Masse749cc6b1996-12-18 19:36:34 +00003import grp
Fred Drake5b811be2001-05-18 21:38:52 +00004import unittest
Barry Warsaw04f357c2002-07-23 19:04:11 +00005from test import test_support
Roger E. Masse749cc6b1996-12-18 19:36:34 +00006
Fred Drake5b811be2001-05-18 21:38:52 +00007class GroupDatabaseTestCase(unittest.TestCase):
Roger E. Masse749cc6b1996-12-18 19:36:34 +00008
Walter Dörwaldce07c8a2003-04-23 19:50:24 +00009 def check_value(self, value):
10 # check that a grp tuple has the entries and
11 # attributes promised by the docs
12 self.assertEqual(len(value), 4)
13 self.assertEqual(value[0], value.gr_name)
14 self.assert_(isinstance(value.gr_name, basestring))
15 self.assertEqual(value[1], value.gr_passwd)
16 self.assert_(isinstance(value.gr_passwd, basestring))
17 self.assertEqual(value[2], value.gr_gid)
18 self.assert_(isinstance(value.gr_gid, int))
19 self.assertEqual(value[3], value.gr_mem)
20 self.assert_(isinstance(value.gr_mem, list))
21
Walter Dörwaldb1ded1e2003-04-15 11:10:33 +000022 def test_values(self):
23 entries = grp.getgrall()
Fred Drake5b811be2001-05-18 21:38:52 +000024
Walter Dörwaldb1ded1e2003-04-15 11:10:33 +000025 for e in entries:
Walter Dörwaldce07c8a2003-04-23 19:50:24 +000026 self.check_value(e)
Walter Dörwald43bc1f12003-04-15 15:59:36 +000027
Walter Dörwald43bc1f12003-04-15 15:59:36 +000028 for e in entries:
Walter Dörwaldce07c8a2003-04-23 19:50:24 +000029 e2 = grp.getgrgid(e.gr_gid)
30 self.check_value(e2)
Walter Dörwaldce6829a2003-05-05 20:37:33 +000031 self.assertEqual(e2.gr_gid, e.gr_gid)
Walter Dörwaldce07c8a2003-04-23 19:50:24 +000032 e2 = grp.getgrnam(e.gr_name)
33 self.check_value(e2)
Walter Dörwaldce6829a2003-05-05 20:37:33 +000034 self.assertEqual(e2.gr_name, e.gr_name)
Fred Drake5b811be2001-05-18 21:38:52 +000035
Walter Dörwaldb1ded1e2003-04-15 11:10:33 +000036 def test_errors(self):
37 self.assertRaises(TypeError, grp.getgrgid)
38 self.assertRaises(TypeError, grp.getgrnam)
39 self.assertRaises(TypeError, grp.getgrall, 42)
40
41 # try to get some errors
42 bynames = {}
43 bygids = {}
44 for (n, p, g, mem) in grp.getgrall():
Fredrik Lundh0e664e12005-12-12 20:53:40 +000045 if not n or n == '+':
46 continue # skip NIS entries etc.
Walter Dörwaldb1ded1e2003-04-15 11:10:33 +000047 bynames[n] = g
48 bygids[g] = n
49
50 allnames = bynames.keys()
51 namei = 0
52 fakename = allnames[namei]
53 while fakename in bynames:
54 chars = map(None, fakename)
55 for i in xrange(len(chars)):
56 if chars[i] == 'z':
57 chars[i] = 'A'
58 break
59 elif chars[i] == 'Z':
60 continue
61 else:
62 chars[i] = chr(ord(chars[i]) + 1)
63 break
64 else:
65 namei = namei + 1
66 try:
67 fakename = allnames[namei]
68 except IndexError:
69 # should never happen... if so, just forget it
70 break
71 fakename = ''.join(map(None, chars))
72
73 self.assertRaises(KeyError, grp.getgrnam, fakename)
74
75 # Choose a non-existent gid.
76 fakegid = 4127
77 while fakegid in bygids:
78 fakegid = (fakegid * 3) % 0x10000
79
80 self.assertRaises(KeyError, grp.getgrgid, fakegid)
Fred Drake5b811be2001-05-18 21:38:52 +000081
Fred Drake2e2be372001-09-20 21:33:42 +000082def test_main():
Walter Dörwald21d3a322003-05-01 17:45:56 +000083 test_support.run_unittest(GroupDatabaseTestCase)
Fred Drake2e2be372001-09-20 21:33:42 +000084
85if __name__ == "__main__":
86 test_main()