test_grp.py 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. """Test script for the grp module."""
  2. import unittest
  3. from test import test_support
  4. grp = test_support.import_module('grp')
  5. class GroupDatabaseTestCase(unittest.TestCase):
  6. def check_value(self, value):
  7. # check that a grp tuple has the entries and
  8. # attributes promised by the docs
  9. self.assertEqual(len(value), 4)
  10. self.assertEqual(value[0], value.gr_name)
  11. self.assertIsInstance(value.gr_name, basestring)
  12. self.assertEqual(value[1], value.gr_passwd)
  13. self.assertIsInstance(value.gr_passwd, basestring)
  14. self.assertEqual(value[2], value.gr_gid)
  15. self.assertIsInstance(value.gr_gid, (long, int))
  16. self.assertEqual(value[3], value.gr_mem)
  17. self.assertIsInstance(value.gr_mem, list)
  18. def test_values(self):
  19. entries = grp.getgrall()
  20. for e in entries:
  21. self.check_value(e)
  22. def test_values_extended(self):
  23. entries = grp.getgrall()
  24. if len(entries) > 1000: # Huge group file (NIS?) -- skip the rest
  25. self.skipTest('huge group file, extended test skipped')
  26. for e in entries:
  27. e2 = grp.getgrgid(e.gr_gid)
  28. self.check_value(e2)
  29. self.assertEqual(e2.gr_gid, e.gr_gid)
  30. name = e.gr_name
  31. if name.startswith('+') or name.startswith('-'):
  32. # NIS-related entry
  33. continue
  34. e2 = grp.getgrnam(name)
  35. self.check_value(e2)
  36. # There are instances where getgrall() returns group names in
  37. # lowercase while getgrgid() returns proper casing.
  38. # Discovered on Ubuntu 5.04 (custom).
  39. self.assertEqual(e2.gr_name.lower(), name.lower())
  40. def test_errors(self):
  41. self.assertRaises(TypeError, grp.getgrgid)
  42. self.assertRaises(TypeError, grp.getgrnam)
  43. self.assertRaises(TypeError, grp.getgrall, 42)
  44. # try to get some errors
  45. bynames = {}
  46. bygids = {}
  47. for (n, p, g, mem) in grp.getgrall():
  48. if not n or n == '+':
  49. continue # skip NIS entries etc.
  50. bynames[n] = g
  51. bygids[g] = n
  52. allnames = bynames.keys()
  53. namei = 0
  54. fakename = allnames[namei]
  55. while fakename in bynames:
  56. chars = list(fakename)
  57. for i in xrange(len(chars)):
  58. if chars[i] == 'z':
  59. chars[i] = 'A'
  60. break
  61. elif chars[i] == 'Z':
  62. continue
  63. else:
  64. chars[i] = chr(ord(chars[i]) + 1)
  65. break
  66. else:
  67. namei = namei + 1
  68. try:
  69. fakename = allnames[namei]
  70. except IndexError:
  71. # should never happen... if so, just forget it
  72. break
  73. fakename = ''.join(chars)
  74. self.assertRaises(KeyError, grp.getgrnam, fakename)
  75. # Choose a non-existent gid.
  76. fakegid = 4127
  77. while fakegid in bygids:
  78. fakegid = (fakegid * 3) % 0x10000
  79. self.assertRaises(KeyError, grp.getgrgid, fakegid)
  80. def test_main():
  81. test_support.run_unittest(GroupDatabaseTestCase)
  82. if __name__ == "__main__":
  83. test_main()