ticket47313_test.py 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. # --- BEGIN COPYRIGHT BLOCK ---
  2. # Copyright (C) 2015 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 os
  10. import sys
  11. import time
  12. import ldap
  13. import logging
  14. import time
  15. import pytest
  16. from lib389 import DirSrv, Entry, tools
  17. from lib389.tools import DirSrvTools
  18. from lib389._constants import *
  19. from lib389.properties import *
  20. log = logging.getLogger(__name__)
  21. ENTRY_NAME = 'test_entry'
  22. class TopologyStandalone(object):
  23. def __init__(self, standalone):
  24. standalone.open()
  25. self.standalone = standalone
  26. @pytest.fixture(scope="module")
  27. def topology(request):
  28. '''
  29. This fixture is used to standalone topology for the 'module'.
  30. '''
  31. standalone = DirSrv(verbose=False)
  32. # Args for the standalone instance
  33. args_instance[SER_HOST] = HOST_STANDALONE
  34. args_instance[SER_PORT] = PORT_STANDALONE
  35. args_instance[SER_SERVERID_PROP] = SERVERID_STANDALONE
  36. args_standalone = args_instance.copy()
  37. standalone.allocate(args_standalone)
  38. # Get the status of the instance
  39. instance_standalone = standalone.exists()
  40. # Remove the instance
  41. if instance_standalone:
  42. standalone.delete()
  43. # Create the instance
  44. standalone.create()
  45. # Used to retrieve configuration information (dbdir, confdir...)
  46. standalone.open()
  47. def fin():
  48. standalone.delete()
  49. request.addfinalizer(fin)
  50. return TopologyStandalone(standalone)
  51. def test_ticket47313_run(topology):
  52. """
  53. It adds 2 test entries
  54. Search with filters including subtype and !
  55. It deletes the added entries
  56. """
  57. # bind as directory manager
  58. topology.standalone.log.info("Bind as %s" % DN_DM)
  59. topology.standalone.simple_bind_s(DN_DM, PASSWORD)
  60. # enable filter error logging
  61. #mod = [(ldap.MOD_REPLACE, 'nsslapd-errorlog-level', '32')]
  62. #topology.standalone.modify_s(DN_CONFIG, mod)
  63. topology.standalone.log.info("\n\n######################### ADD ######################\n")
  64. # Prepare the entry with cn;fr & cn;en
  65. entry_name_fr = '%s fr' % (ENTRY_NAME)
  66. entry_name_en = '%s en' % (ENTRY_NAME)
  67. entry_name_both = '%s both' % (ENTRY_NAME)
  68. entry_dn_both = 'cn=%s, %s' % (entry_name_both, SUFFIX)
  69. entry_both = Entry(entry_dn_both)
  70. entry_both.setValues('objectclass', 'top', 'person')
  71. entry_both.setValues('sn', entry_name_both)
  72. entry_both.setValues('cn', entry_name_both)
  73. entry_both.setValues('cn;fr', entry_name_fr)
  74. entry_both.setValues('cn;en', entry_name_en)
  75. # Prepare the entry with one member
  76. entry_name_en_only = '%s en only' % (ENTRY_NAME)
  77. entry_dn_en_only = 'cn=%s, %s' % (entry_name_en_only, SUFFIX)
  78. entry_en_only = Entry(entry_dn_en_only)
  79. entry_en_only.setValues('objectclass', 'top', 'person')
  80. entry_en_only.setValues('sn', entry_name_en_only)
  81. entry_en_only.setValues('cn', entry_name_en_only)
  82. entry_en_only.setValues('cn;en', entry_name_en)
  83. topology.standalone.log.info("Try to add Add %s: %r" % (entry_dn_both, entry_both))
  84. topology.standalone.add_s(entry_both)
  85. topology.standalone.log.info("Try to add Add %s: %r" % (entry_dn_en_only, entry_en_only))
  86. topology.standalone.add_s(entry_en_only)
  87. topology.standalone.log.info("\n\n######################### SEARCH ######################\n")
  88. # filter: (&(cn=test_entry en only)(!(cn=test_entry fr)))
  89. myfilter = '(&(sn=%s)(!(cn=%s)))' % (entry_name_en_only, entry_name_fr)
  90. topology.standalone.log.info("Try to search with filter %s" % myfilter)
  91. ents = topology.standalone.search_s(SUFFIX, ldap.SCOPE_SUBTREE, myfilter)
  92. assert len(ents) == 1
  93. assert ents[0].sn == entry_name_en_only
  94. topology.standalone.log.info("Found %s" % ents[0].dn)
  95. # filter: (&(cn=test_entry en only)(!(cn;fr=test_entry fr)))
  96. myfilter = '(&(sn=%s)(!(cn;fr=%s)))' % (entry_name_en_only, entry_name_fr)
  97. topology.standalone.log.info("Try to search with filter %s" % myfilter)
  98. ents = topology.standalone.search_s(SUFFIX, ldap.SCOPE_SUBTREE, myfilter)
  99. assert len(ents) == 1
  100. assert ents[0].sn == entry_name_en_only
  101. topology.standalone.log.info("Found %s" % ents[0].dn)
  102. # filter: (&(cn=test_entry en only)(!(cn;en=test_entry en)))
  103. myfilter = '(&(sn=%s)(!(cn;en=%s)))' % (entry_name_en_only, entry_name_en)
  104. topology.standalone.log.info("Try to search with filter %s" % myfilter)
  105. ents = topology.standalone.search_s(SUFFIX, ldap.SCOPE_SUBTREE, myfilter)
  106. assert len(ents) == 0
  107. topology.standalone.log.info("Found none")
  108. topology.standalone.log.info("\n\n######################### DELETE ######################\n")
  109. topology.standalone.log.info("Try to delete %s " % entry_dn_both)
  110. topology.standalone.delete_s(entry_dn_both)
  111. topology.standalone.log.info("Try to delete %s " % entry_dn_en_only)
  112. topology.standalone.delete_s(entry_dn_en_only)
  113. log.info('Testcase PASSED')
  114. if __name__ == '__main__':
  115. # Run isolated
  116. # -s for DEBUG mode
  117. CURRENT_FILE = os.path.realpath(__file__)
  118. pytest.main("-s %s" % CURRENT_FILE)