mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2024-12-28 01:41:14 -06:00
0a64e9bd70
Web UI tests were marked as tier1 tests. The tier system is intended to be used together with CI system to make sure the more complicated tests are being run only when all of the basic functionality is working. The system is using pytest's marker system. E.g. an invocation of all tier1 tests with listing will look like: $ py.test -v -m tier1 ipatests or in case of out of tree tests: $ ipa-run-tests -m tier1 Reviewed-By: Ales 'alich' Marecek <amarecek@redhat.com>
419 lines
14 KiB
Python
419 lines
14 KiB
Python
# Authors:
|
|
# Rob Crittenden <rcritten@redhat.com>
|
|
#
|
|
# Copyright (C) 2010 Red Hat
|
|
# 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, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# 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, see <http://www.gnu.org/licenses/>.
|
|
|
|
"""
|
|
Test --setattr and --addattr and other attribute-specific issues
|
|
"""
|
|
|
|
from ipalib import errors
|
|
from ipatests.test_xmlrpc.xmlrpc_test import Declarative
|
|
from ipatests.test_xmlrpc.test_user_plugin import get_user_result
|
|
import pytest
|
|
|
|
user1=u'tuser1'
|
|
|
|
|
|
@pytest.mark.tier1
|
|
class test_attr(Declarative):
|
|
|
|
cleanup_commands = [
|
|
('user_del', [user1], {}),
|
|
]
|
|
|
|
tests = [
|
|
|
|
dict(
|
|
desc='Try to add user %r with single-value attribute set via '
|
|
'option and --addattr' % user1,
|
|
command=(
|
|
'user_add', [user1], dict(givenname=u'Test', sn=u'User1',
|
|
addattr=u'sn=User2')
|
|
),
|
|
expected=errors.OnlyOneValueAllowed(attr='sn'),
|
|
),
|
|
|
|
dict(
|
|
desc='Create %r' % user1,
|
|
command=(
|
|
'user_add', [user1], dict(givenname=u'Test', sn=u'User1',
|
|
setattr=None)
|
|
),
|
|
expected=dict(
|
|
value=user1,
|
|
summary=u'Added user "tuser1"',
|
|
result=get_user_result(user1, u'Test', u'User1', 'add'),
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Change givenname, add mail %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(setattr=(u'givenname=Finkle', u'mail=test@example.com'))
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Add another mail %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(addattr=u'mail=test2@example.com')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Add two phone numbers at once %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(setattr=u'telephoneNumber=410-555-1212', addattr=u'telephoneNumber=301-555-1212')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'410-555-1212', u'301-555-1212'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Go from two phone numbers to one %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(setattr=u'telephoneNumber=301-555-1212')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'301-555-1212'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Add two more phone numbers %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(addattr=(u'telephoneNumber=703-555-1212', u'telephoneNumber=202-888-9833'))
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'301-555-1212', u'703-555-1212',
|
|
u'202-888-9833'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Delete one phone number for %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(delattr=u'telephoneNumber=301-555-1212')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'703-555-1212', u'202-888-9833'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Try deleting the number again for %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(delattr=u'telephoneNumber=301-555-1212')
|
|
),
|
|
expected=errors.AttrValueNotFound(attr=u'telephonenumber',
|
|
value=u'301-555-1212')
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Add and delete one phone number for %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(addattr=u'telephoneNumber=301-555-1212',
|
|
delattr=u'telephoneNumber=202-888-9833')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'703-555-1212', u'301-555-1212'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Add and delete the same phone number for %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(addattr=(u'telephoneNumber=301-555-1212',
|
|
u'telephoneNumber=202-888-9833'),
|
|
delattr=u'telephoneNumber=301-555-1212')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'703-555-1212', u'301-555-1212',
|
|
u'202-888-9833'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Set and delete a phone number for %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(setattr=(u'telephoneNumber=301-555-1212',
|
|
u'telephoneNumber=202-888-9833'),
|
|
delattr=u'telephoneNumber=301-555-1212')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'202-888-9833'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Try setting givenname to None with setattr in %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(setattr=(u'givenname='))
|
|
),
|
|
expected=errors.RequirementError(name='givenname'),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Try setting givenname to None with option in %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(givenname=None)
|
|
),
|
|
expected=errors.RequirementError(name='first'),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Make sure setting givenname works with option in %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(givenname=u'Fred')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Fred', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'202-888-9833'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
|
|
dict(
|
|
desc='Make sure setting givenname works with setattr in %r' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(setattr=u'givenname=Finkle')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'202-888-9833'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
dict(
|
|
desc='Try to "remove" empty location from %r' % user1,
|
|
command=('user_mod', [user1], dict(l=None)),
|
|
expected=errors.EmptyModlist(),
|
|
),
|
|
|
|
dict(
|
|
desc='Lock %r using setattr' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(setattr=u'nsaccountlock=TrUe')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'202-888-9833'],
|
|
nsaccountlock=True,
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
dict(
|
|
desc='Unlock %r using addattr&delattr' % user1,
|
|
command=(
|
|
'user_mod', [user1], dict(
|
|
addattr=u'nsaccountlock=FaLsE',
|
|
delattr=u'nsaccountlock=TRUE')
|
|
),
|
|
expected=dict(
|
|
result=get_user_result(
|
|
user1, u'Finkle', u'User1', 'mod',
|
|
mail=[u'test@example.com', u'test2@example.com'],
|
|
telephonenumber=[u'202-888-9833'],
|
|
),
|
|
summary=u'Modified user "tuser1"',
|
|
value=user1,
|
|
),
|
|
),
|
|
|
|
dict(
|
|
desc='Try adding a new group search fields config entry',
|
|
command=(
|
|
'config_mod', [], dict(addattr=u'ipagroupsearchfields=newattr')
|
|
),
|
|
expected=errors.OnlyOneValueAllowed(attr='ipagroupsearchfields'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try adding a new cert subject base config entry',
|
|
command=(
|
|
'config_mod', [], dict(addattr=u'ipacertificatesubjectbase=0=DOMAIN.COM')
|
|
),
|
|
expected=errors.ValidationError(name='ipacertificatesubjectbase',
|
|
error='attribute is not configurable'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try deleting a required config entry',
|
|
command=(
|
|
'config_mod', [], dict(delattr=u'ipasearchrecordslimit=100')
|
|
),
|
|
expected=errors.RequirementError(name='ipasearchrecordslimit'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try setting nonexistent attribute',
|
|
command=('config_mod', [], dict(setattr=u'invalid_attr=false')),
|
|
expected=errors.ObjectclassViolation(
|
|
info='attribute "invalid_attr" not allowed'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try setting out-of-range krbpwdmaxfailure',
|
|
command=('pwpolicy_mod', [], dict(setattr=u'krbpwdmaxfailure=-1')),
|
|
expected=errors.ValidationError(name='krbpwdmaxfailure',
|
|
error='must be at least 0'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try setting out-of-range maxfail',
|
|
command=('pwpolicy_mod', [], dict(krbpwdmaxfailure=u'-1')),
|
|
expected=errors.ValidationError(name='maxfail',
|
|
error='must be at least 0'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try setting non-numeric krbpwdmaxfailure',
|
|
command=('pwpolicy_mod', [], dict(setattr=u'krbpwdmaxfailure=abc')),
|
|
expected=errors.ConversionError(name='krbpwdmaxfailure',
|
|
error='must be an integer'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try setting non-numeric maxfail',
|
|
command=('pwpolicy_mod', [], dict(krbpwdmaxfailure=u'abc')),
|
|
expected=errors.ConversionError(name='maxfail',
|
|
error='must be an integer'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try deleting bogus attribute',
|
|
command=('config_mod', [], dict(delattr=u'bogusattribute=xyz')),
|
|
expected=errors.ValidationError(name='bogusattribute',
|
|
error='No such attribute on this entry'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try deleting empty attribute',
|
|
command=('config_mod', [],
|
|
dict(delattr=u'ipaCustomFields=See Also,seealso,false')),
|
|
expected=errors.ValidationError(name='ipacustomfields',
|
|
error='No such attribute on this entry'),
|
|
),
|
|
|
|
dict(
|
|
desc='Set and delete one value, plus try deleting a missing one',
|
|
command=('config_mod', [], dict(
|
|
delattr=[u'ipaCustomFields=See Also,seealso,false',
|
|
u'ipaCustomFields=Country,c,false'],
|
|
addattr=u'ipaCustomFields=See Also,seealso,false')),
|
|
expected=errors.AttrValueNotFound(attr='ipacustomfields',
|
|
value='Country,c,false'),
|
|
),
|
|
|
|
dict(
|
|
desc='Try to delete an operational attribute with --delattr',
|
|
command=('config_mod', [], dict(
|
|
delattr=u'creatorsName=cn=directory manager')),
|
|
expected=errors.DatabaseError(
|
|
desc='Server is unwilling to perform', info=''),
|
|
),
|
|
|
|
]
|