g.usernames = ['wizuser', 'baruser']
g.save()
- def test_filter(self):
+ def test_count(self):
+ # empty query
+ qs = LdapGroup.objects.none()
+ self.assertEquals(qs.count(), 0)
+
qs = LdapGroup.objects.none()
self.assertEquals(len(qs), 0)
+ # all query
+ qs = LdapGroup.objects.all()
+ self.assertEquals(qs.count(), 3)
+
qs = LdapGroup.objects.all()
self.assertEquals(len(qs), 3)
+ def test_filter(self):
+ qs = LdapGroup.objects.filter(name='foogroup')
+ self.assertEquals(qs.count(), 1)
+
qs = LdapGroup.objects.filter(name='foogroup')
self.assertEquals(len(qs), 1)
g = qs[0]
- self.assertEquals(g.dn, 'cn=foogroup,ou=groups,dc=nodomain')
+ self.assertEquals(g.dn, 'cn=foogroup,%s' % LdapGroup.base_dn)
self.assertEquals(g.name, 'foogroup')
self.assertEquals(g.gid, 1000)
self.assertEquals(g.usernames, ['foouser', 'baruser'])
# try to filter non-existent entries
+ qs = LdapGroup.objects.filter(name='does_not_exist')
+ self.assertEquals(qs.count(), 0)
+
qs = LdapGroup.objects.filter(name='does_not_exist')
self.assertEquals(len(qs), 0)
def test_get(self):
g = LdapGroup.objects.get(name='foogroup')
- self.assertEquals(g.dn, 'cn=foogroup,ou=groups,dc=nodomain')
+ self.assertEquals(g.dn, 'cn=foogroup,%s' % LdapGroup.base_dn)
self.assertEquals(g.name, 'foogroup')
self.assertEquals(g.gid, 1000)
self.assertEquals(g.usernames, ['foouser', 'baruser'])
qs = LdapGroup.objects.all()
self.assertEquals(len(qs), 0)
+ def test_slice(self):
+ qs = LdapGroup.objects.all()
+ objs = list(qs)
+ self.assertEquals(len(objs), 3)
+ self.assertEquals(objs[0].gid, 1000)
+ self.assertEquals(objs[1].gid, 1001)
+ self.assertEquals(objs[2].gid, 1002)
+
+ # limit only
+ qs = LdapGroup.objects.all()
+ objs = qs[:2]
+ self.assertEquals(objs.count(), 2)
+
+ objs = qs[:2]
+ self.assertEquals(len(objs), 2)
+ self.assertEquals(objs[0].gid, 1000)
+ self.assertEquals(objs[1].gid, 1001)
+
+ # offset only
+ qs = LdapGroup.objects.all()
+ objs = qs[1:]
+ self.assertEquals(objs.count(), 2)
+
+ objs = qs[1:]
+ self.assertEquals(len(objs), 2)
+ self.assertEquals(objs[0].gid, 1001)
+ self.assertEquals(objs[1].gid, 1002)
+
+ # offset and limit
+ qs = LdapGroup.objects.all()
+ objs = qs[1:2]
+ self.assertEquals(objs.count(), 1)
+
+ objs = qs[1:2]
+ self.assertEquals(len(objs), 1)
+ self.assertEquals(objs[0].gid, 1001)
+
def test_update(self):
g = LdapGroup.objects.get(name='foogroup')
# make sure DN gets updated if we change the pk
g.name = 'foogroup2'
g.save()
- self.assertEquals(g.dn, 'cn=foogroup2,ou=groups,dc=nodomain')
+ self.assertEquals(g.dn, 'cn=foogroup2,%s' % LdapGroup.base_dn)
+
+ def test_values(self):
+ qs = LdapGroup.objects.values('name')
+ self.assertEquals(len(qs), 3)
+ self.assertEquals(qs[0], {'name': 'foogroup'})
+ self.assertEquals(qs[1], {'name': 'bargroup'})
+ self.assertEquals(qs[2], {'name': 'wizgroup'})
+
+ def test_values_list(self):
+ qs = LdapGroup.objects.values_list('name')
+ self.assertEquals(len(qs), 3)
+ self.assertEquals(qs[0], ('foogroup',))
+ self.assertEquals(qs[1], ('bargroup',))
+ self.assertEquals(qs[2], ('wizgroup',))
def test_delete(self):
g = LdapGroup.objects.get(name='foogroup')
# make sure DN gets updated if we change the pk
u.username = 'foouser2'
u.save()
- self.assertEquals(u.dn, 'uid=foouser2,ou=people,dc=nodomain')
+ self.assertEquals(u.dn, 'uid=foouser2,%s' % LdapUser.base_dn)
class AdminTestCase(BaseTestCase):
fixtures = ['test_users.json']