ticket47921_test.py 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. # --- BEGIN COPYRIGHT BLOCK ---
  2. # Copyright (C) 2016 Red Hat, Inc.
  3. # All rights reserved.
  4. #
  5. # License: GPL (version 3 or any later version).
  6. # See LICENSE for details.
  7. # --- END COPYRIGHT BLOCK ---
  8. #
  9. import pytest
  10. from lib389.tasks import *
  11. from lib389.utils import *
  12. from lib389.topologies import topology_st
  13. logging.getLogger(__name__).setLevel(logging.DEBUG)
  14. log = logging.getLogger(__name__)
  15. def test_ticket47921(topology_st):
  16. '''
  17. Test that indirect cos reflects the current value of the indirect entry
  18. '''
  19. INDIRECT_COS_DN = 'cn=cos definition,' + DEFAULT_SUFFIX
  20. MANAGER_DN = 'uid=my manager,ou=people,' + DEFAULT_SUFFIX
  21. USER_DN = 'uid=user,ou=people,' + DEFAULT_SUFFIX
  22. # Add COS definition
  23. try:
  24. topology_st.standalone.add_s(Entry((INDIRECT_COS_DN,
  25. {
  26. 'objectclass': 'top cosSuperDefinition cosIndirectDefinition ldapSubEntry'.split(),
  27. 'cosIndirectSpecifier': 'manager',
  28. 'cosAttribute': 'roomnumber'
  29. })))
  30. except ldap.LDAPError as e:
  31. log.fatal('Failed to add cos defintion, error: ' + e.message['desc'])
  32. assert False
  33. # Add manager entry
  34. try:
  35. topology_st.standalone.add_s(Entry((MANAGER_DN,
  36. {'objectclass': 'top extensibleObject'.split(),
  37. 'uid': 'my manager',
  38. 'roomnumber': '1'
  39. })))
  40. except ldap.LDAPError as e:
  41. log.fatal('Failed to add manager entry, error: ' + e.message['desc'])
  42. assert False
  43. # Add user entry
  44. try:
  45. topology_st.standalone.add_s(Entry((USER_DN,
  46. {'objectclass': 'top person organizationalPerson inetorgperson'.split(),
  47. 'sn': 'last',
  48. 'cn': 'full',
  49. 'givenname': 'mark',
  50. 'uid': 'user',
  51. 'manager': MANAGER_DN
  52. })))
  53. except ldap.LDAPError as e:
  54. log.fatal('Failed to add manager entry, error: ' + e.message['desc'])
  55. assert False
  56. # Test COS is working
  57. try:
  58. entry = topology_st.standalone.search_s(DEFAULT_SUFFIX, ldap.SCOPE_SUBTREE,
  59. "uid=user",
  60. ['roomnumber'])
  61. if entry:
  62. if entry[0].getValue('roomnumber') != '1':
  63. log.fatal('COS is not working.')
  64. assert False
  65. else:
  66. log.fatal('Failed to find user entry')
  67. assert False
  68. except ldap.LDAPError as e:
  69. log.error('Failed to search for user entry: ' + e.message['desc'])
  70. assert False
  71. # Modify manager entry
  72. try:
  73. topology_st.standalone.modify_s(MANAGER_DN, [(ldap.MOD_REPLACE, 'roomnumber', '2')])
  74. except ldap.LDAPError as e:
  75. log.error('Failed to modify manager entry: ' + e.message['desc'])
  76. assert False
  77. # Confirm COS is returning the new value
  78. try:
  79. entry = topology_st.standalone.search_s(DEFAULT_SUFFIX, ldap.SCOPE_SUBTREE,
  80. "uid=user",
  81. ['roomnumber'])
  82. if entry:
  83. if entry[0].getValue('roomnumber') != '2':
  84. log.fatal('COS is not working after manager update.')
  85. assert False
  86. else:
  87. log.fatal('Failed to find user entry')
  88. assert False
  89. except ldap.LDAPError as e:
  90. log.error('Failed to search for user entry: ' + e.message['desc'])
  91. assert False
  92. log.info('Test complete')
  93. if __name__ == '__main__':
  94. # Run isolated
  95. # -s for DEBUG mode
  96. CURRENT_FILE = os.path.realpath(__file__)
  97. pytest.main("-s %s" % CURRENT_FILE)