Skip to content

Commit

Permalink
Tests: Add a test suite for edits
Browse files Browse the repository at this point in the history
  • Loading branch information
pyldap contributors authored and Petr Viktorin committed Nov 24, 2017
1 parent 4549352 commit 2949e78
Show file tree
Hide file tree
Showing 2 changed files with 90 additions and 0 deletions.
1 change: 1 addition & 0 deletions Tests/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,4 +18,5 @@
from . import t_ldapurl
from . import t_ldif
from . import t_ldapobject
from . import t_edit
from . import t_ldap_schema_subentry
89 changes: 89 additions & 0 deletions Tests/t_edit.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
from __future__ import unicode_literals

import sys

if sys.version_info[0] <= 2:
PY2 = True
text_type = unicode
else:
PY2 = False
text_type = str

import ldap, unittest
from slapdtest import SlapdObject

from ldap.ldapobject import LDAPObject

server = None


class EditionTests(unittest.TestCase):

def setUp(self):
global server
if server is None:
server = SlapdObject()
server.start()
base = server.suffix
suffix_dc = base.split(',')[0][3:]

# insert some Foo* objects via ldapadd
server.ldapadd("\n".join([
'dn: '+server.suffix,
'objectClass: dcObject',
'objectClass: organization',
'dc: '+suffix_dc,
'o: '+suffix_dc,
'',
'dn: '+server.root_dn,
'objectClass: applicationProcess',
'cn: '+server.root_cn,
'',
"dn: cn=Foo1,"+base,
"objectClass: organizationalRole",
"cn: Foo1",
"",
"dn: cn=Foo2,"+base,
"objectClass: organizationalRole",
"cn: Foo2",
"",
"dn: cn=Foo3,"+base,
"objectClass: organizationalRole",
"cn: Foo3",
"",
"dn: ou=Container,"+base,
"objectClass: organizationalUnit",
"ou: Container",
"",
"dn: cn=Foo4,ou=Container,"+base,
"objectClass: organizationalRole",
"cn: Foo4",
"",
])+"\n")

l = LDAPObject(server.ldap_uri, bytes_mode=False)
l.protocol_version = 3
l.set_option(ldap.OPT_REFERRALS,0)
l.simple_bind_s(server.root_dn,
server.root_pw)
self.ldap = l
self.server = server

def test_add_object(self):
base = self.server.suffix
dn = "cn=Added,ou=Container," + base
self.ldap.add_ext_s(dn, [
("objectClass", [b'organizationalRole']),
("cn", [b'Added']),
])

# Lookup the object
result = self.ldap.search_s(base, ldap.SCOPE_SUBTREE, '(cn=Added)', ['*'])
self.assertEqual(result, [
("cn=Added,ou=Container," + base,
{'cn': [b'Added'], 'objectClass': [b'organizationalRole']}),
])


if __name__ == '__main__':
unittest.main()

0 comments on commit 2949e78

Please sign in to comment.