2009-06-24 08:12:27 -05:00
|
|
|
# Authors:
|
|
|
|
# Rob Crittenden <rcritten@redhat.com>
|
|
|
|
# Pavel Zuna <pzuna@redhat.com>
|
2009-12-09 10:09:53 -06:00
|
|
|
# Jason Gerard DeRose <jderose@redhat.com>
|
2009-06-24 08:12:27 -05:00
|
|
|
#
|
2009-12-09 10:09:53 -06:00
|
|
|
# Copyright (C) 2008, 2009 Red Hat
|
2009-06-24 08:12:27 -05:00
|
|
|
# see file 'COPYING' for use and warranty information
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License as
|
|
|
|
# published by the Free Software Foundation; version 2 only
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
2009-12-09 10:09:53 -06:00
|
|
|
|
2009-06-24 08:12:27 -05:00
|
|
|
"""
|
|
|
|
Test the `ipalib/plugins/user.py` module.
|
|
|
|
"""
|
|
|
|
|
2009-12-09 10:09:53 -06:00
|
|
|
from ipalib import api, errors
|
2009-12-17 07:16:18 -06:00
|
|
|
from tests.test_xmlrpc import objectclasses
|
|
|
|
from xmlrpc_test import Declarative, fuzzy_digits, fuzzy_uuid
|
|
|
|
|
2009-12-09 10:09:53 -06:00
|
|
|
|
2009-12-18 09:57:40 -06:00
|
|
|
user_memberof = (u'cn=ipausers,cn=groups,cn=accounts,%s' % api.env.basedn,)
|
2009-12-17 07:16:18 -06:00
|
|
|
user1=u'tuser1'
|
2009-12-09 10:09:53 -06:00
|
|
|
|
2010-07-27 15:35:23 -05:00
|
|
|
invaliduser1=u'+tuser1'
|
|
|
|
invaliduser2=u'tuser1234567890123456789012345678901234567890'
|
|
|
|
|
2009-12-09 10:09:53 -06:00
|
|
|
|
|
|
|
class test_user(Declarative):
|
|
|
|
|
|
|
|
cleanup_commands = [
|
2009-12-17 07:16:18 -06:00
|
|
|
('user_del', [user1], {}),
|
2009-12-09 10:09:53 -06:00
|
|
|
]
|
|
|
|
|
|
|
|
tests = [
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Try to retrieve non-existent %r' % user1,
|
|
|
|
command=('user_show', [user1], {}),
|
|
|
|
expected=errors.NotFound(reason='no such entry'),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
|
|
|
desc='Try to update non-existent %r' % user1,
|
|
|
|
command=('user_mod', [user1], dict(givenname=u'Foo')),
|
2009-12-09 10:09:53 -06:00
|
|
|
expected=errors.NotFound(reason='no such entry'),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Try to delete non-existent %r' % user1,
|
|
|
|
command=('user_del', [user1], {}),
|
|
|
|
expected=errors.NotFound(reason='no such entry'),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
|
|
|
desc='Create %r' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
|
|
|
'user_add', [], dict(givenname=u'Test', sn=u'User1')
|
|
|
|
),
|
|
|
|
expected=dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
value=user1,
|
|
|
|
summary=u'Added user "tuser1"',
|
2009-12-09 10:09:53 -06:00
|
|
|
result=dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
gecos=[user1],
|
|
|
|
givenname=[u'Test'],
|
|
|
|
homedirectory=[u'/home/tuser1'],
|
|
|
|
krbprincipalname=[u'tuser1@' + api.env.realm],
|
|
|
|
loginshell=[u'/bin/sh'],
|
|
|
|
objectclass=objectclasses.user,
|
|
|
|
sn=[u'User1'],
|
|
|
|
uid=[user1],
|
2010-07-27 15:35:23 -05:00
|
|
|
uidnumber=[fuzzy_digits],
|
2009-12-17 07:16:18 -06:00
|
|
|
ipauniqueid=[fuzzy_uuid],
|
|
|
|
dn=u'uid=tuser1,cn=users,cn=accounts,' + api.env.basedn,
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Try to create duplicate %r' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
|
|
|
'user_add', [], dict(givenname=u'Test', sn=u'User1')
|
|
|
|
),
|
|
|
|
expected=errors.DuplicateEntry(),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Retrieve %r' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
2009-12-17 07:16:18 -06:00
|
|
|
'user_show', [user1], {}
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
expected=dict(
|
|
|
|
result=dict(
|
2009-12-18 09:57:40 -06:00
|
|
|
dn=u'uid=tuser1,cn=users,cn=accounts,%s' % api.env.basedn,
|
2009-12-17 07:16:18 -06:00
|
|
|
givenname=[u'Test'],
|
|
|
|
homedirectory=[u'/home/tuser1'],
|
|
|
|
loginshell=[u'/bin/sh'],
|
|
|
|
sn=[u'User1'],
|
|
|
|
uid=[user1],
|
2010-02-12 15:34:21 -06:00
|
|
|
memberof_group=[u'ipausers'],
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
2009-12-17 07:16:18 -06:00
|
|
|
value=user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
summary=None,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Search for %r with all=True' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
2009-12-17 07:16:18 -06:00
|
|
|
'user_find', [user1], {'all': True}
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
expected=dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
result=[
|
2009-12-09 10:09:53 -06:00
|
|
|
{
|
2010-02-22 13:29:26 -06:00
|
|
|
'dn': u'uid=tuser1,cn=users,cn=accounts,' + api.env.basedn,
|
2009-12-17 07:16:18 -06:00
|
|
|
'cn': [u'Test User1'],
|
|
|
|
'gecos': [user1],
|
|
|
|
'givenname': [u'Test'],
|
|
|
|
'homedirectory': [u'/home/tuser1'],
|
|
|
|
'krbprincipalname': [u'tuser1@' + api.env.realm],
|
|
|
|
'loginshell': [u'/bin/sh'],
|
2010-02-12 15:34:21 -06:00
|
|
|
'memberof_group': [u'ipausers'],
|
2009-12-17 07:16:18 -06:00
|
|
|
'objectclass': objectclasses.user,
|
|
|
|
'sn': [u'User1'],
|
|
|
|
'uid': [user1],
|
|
|
|
'uidnumber': [fuzzy_digits],
|
|
|
|
'gidnumber': [fuzzy_digits],
|
|
|
|
'ipauniqueid': [fuzzy_uuid],
|
2009-12-09 10:09:53 -06:00
|
|
|
},
|
2009-12-17 07:16:18 -06:00
|
|
|
],
|
2009-12-09 10:09:53 -06:00
|
|
|
summary=u'1 user matched',
|
2010-02-12 15:34:21 -06:00
|
|
|
count=1, truncated=False,
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Search for %r with minimal attributes' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
2009-12-17 07:16:18 -06:00
|
|
|
'user_find', [user1], {}
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
expected=dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
result=[
|
2009-12-09 10:09:53 -06:00
|
|
|
dict(
|
2010-02-22 13:29:26 -06:00
|
|
|
dn=u'uid=tuser1,cn=users,cn=accounts,' + api.env.basedn,
|
2009-12-17 07:16:18 -06:00
|
|
|
givenname=[u'Test'],
|
|
|
|
homedirectory=[u'/home/tuser1'],
|
|
|
|
loginshell=[u'/bin/sh'],
|
|
|
|
sn=[u'User1'],
|
|
|
|
uid=[user1],
|
2010-02-12 15:34:21 -06:00
|
|
|
memberof_group=[u'ipausers'],
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
2009-12-17 07:16:18 -06:00
|
|
|
],
|
2009-12-09 10:09:53 -06:00
|
|
|
summary=u'1 user matched',
|
|
|
|
count=1,
|
|
|
|
truncated=False,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
|
|
|
desc='Search for all users',
|
|
|
|
command=(
|
|
|
|
'user_find', [], {}
|
|
|
|
),
|
|
|
|
expected=dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
result=[
|
2009-12-09 10:09:53 -06:00
|
|
|
dict(
|
2010-02-22 13:29:26 -06:00
|
|
|
dn=u'uid=admin,cn=users,cn=accounts,' + api.env.basedn,
|
2009-12-17 07:16:18 -06:00
|
|
|
homedirectory=[u'/home/admin'],
|
|
|
|
loginshell=[u'/bin/bash'],
|
|
|
|
sn=[u'Administrator'],
|
|
|
|
uid=[u'admin'],
|
2010-02-12 15:34:21 -06:00
|
|
|
memberof_group=[u'admins'],
|
2010-07-27 15:35:23 -05:00
|
|
|
memberof_rolegroup=[u'replicaadmin'],
|
|
|
|
memberof_taskgroup=[u'managereplica', u'deletereplica'],
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
dict(
|
2010-02-22 13:29:26 -06:00
|
|
|
dn=u'uid=tuser1,cn=users,cn=accounts,' + api.env.basedn,
|
2009-12-17 07:16:18 -06:00
|
|
|
givenname=[u'Test'],
|
|
|
|
homedirectory=[u'/home/tuser1'],
|
|
|
|
loginshell=[u'/bin/sh'],
|
|
|
|
sn=[u'User1'],
|
|
|
|
uid=[user1],
|
2010-02-12 15:34:21 -06:00
|
|
|
memberof_group=[u'ipausers'],
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
2009-12-17 07:16:18 -06:00
|
|
|
],
|
2009-12-09 10:09:53 -06:00
|
|
|
summary=u'2 users matched',
|
|
|
|
count=2,
|
|
|
|
truncated=False,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Lock %r' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
2009-12-17 07:16:18 -06:00
|
|
|
'user_lock', [user1], {}
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
expected=dict(
|
|
|
|
result=True,
|
2009-12-17 07:16:18 -06:00
|
|
|
value=user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
summary=u'Locked user "tuser1"',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Unlock %r' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
2009-12-17 07:16:18 -06:00
|
|
|
'user_unlock', [user1], {}
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
expected=dict(
|
|
|
|
result=True,
|
2009-12-17 07:16:18 -06:00
|
|
|
value=user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
summary=u'Unlocked user "tuser1"',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Update %r' % user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
command=(
|
2009-12-17 07:16:18 -06:00
|
|
|
'user_mod', [user1], dict(givenname=u'Finkle')
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
expected=dict(
|
|
|
|
result=dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
givenname=[u'Finkle'],
|
2010-02-12 15:34:21 -06:00
|
|
|
homedirectory=[u'/home/tuser1'],
|
|
|
|
loginshell=[u'/bin/sh'],
|
|
|
|
sn=[u'User1'],
|
|
|
|
uid=[user1],
|
|
|
|
memberof_group=[u'ipausers'],
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
summary=u'Modified user "tuser1"',
|
2009-12-17 07:16:18 -06:00
|
|
|
value=user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Retrieve %r to verify update' % user1,
|
|
|
|
command=('user_show', [user1], {}),
|
2009-12-09 10:09:53 -06:00
|
|
|
expected=dict(
|
|
|
|
result=dict(
|
2009-12-18 09:57:40 -06:00
|
|
|
dn=u'uid=tuser1,cn=users,cn=accounts,%s' % api.env.basedn,
|
2009-12-17 07:16:18 -06:00
|
|
|
givenname=[u'Finkle'],
|
|
|
|
homedirectory=[u'/home/tuser1'],
|
|
|
|
loginshell=[u'/bin/sh'],
|
|
|
|
sn=[u'User1'],
|
|
|
|
uid=[user1],
|
2010-02-12 15:34:21 -06:00
|
|
|
memberof_group=[u'ipausers'],
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
summary=None,
|
2009-12-17 07:16:18 -06:00
|
|
|
value=user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Delete %r' % user1,
|
|
|
|
command=('user_del', [user1], {}),
|
2009-12-09 10:09:53 -06:00
|
|
|
expected=dict(
|
|
|
|
result=True,
|
|
|
|
summary=u'Deleted user "tuser1"',
|
2009-12-17 07:16:18 -06:00
|
|
|
value=user1,
|
2009-12-09 10:09:53 -06:00
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Try to delete non-existent %r' % user1,
|
|
|
|
command=('user_del', [user1], {}),
|
2009-12-09 10:09:53 -06:00
|
|
|
expected=errors.NotFound(reason='no such entry'),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
2009-12-17 07:16:18 -06:00
|
|
|
desc='Try to retrieve non-existent %r' % user1,
|
|
|
|
command=('user_show', [user1], {}),
|
|
|
|
expected=errors.NotFound(reason='no such entry'),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
|
|
|
desc='Try to update non-existent %r' % user1,
|
|
|
|
command=('user_mod', [user1], dict(givenname=u'Foo')),
|
2009-12-09 10:09:53 -06:00
|
|
|
expected=errors.NotFound(reason='no such entry'),
|
|
|
|
),
|
2009-06-24 08:12:27 -05:00
|
|
|
|
2009-12-17 07:16:18 -06:00
|
|
|
|
2010-07-27 15:35:23 -05:00
|
|
|
dict(
|
|
|
|
desc='Test an invalid login name %r' % invaliduser1,
|
|
|
|
command=('user_add', [invaliduser1], dict(givenname=u'Test', sn=u'User1')),
|
|
|
|
expected=errors.ValidationError(name='uid', error='may only include letters, numbers, _, -, . and $'),
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
|
|
dict(
|
|
|
|
desc='Test a login name that is too long %r' % invaliduser2,
|
|
|
|
command=('user_add', [invaliduser2], dict(givenname=u'Test', sn=u'User1')),
|
|
|
|
expected=errors.ValidationError(name='uid', error='can be at most 33 characters'),
|
|
|
|
),
|
|
|
|
|
2009-12-09 10:09:53 -06:00
|
|
|
]
|