Imported Upstream version 4.8.10
This commit is contained in:
@@ -21,10 +21,10 @@
|
||||
Automember tests
|
||||
"""
|
||||
|
||||
from ipatests.test_webui.ui_driver import UI_driver
|
||||
from ipatests.test_webui.ui_driver import screenshot
|
||||
from ipatests.test_webui.ui_driver import UI_driver, screenshot
|
||||
import ipatests.test_webui.data_hostgroup as hostgroup
|
||||
from ipatests.test_webui.test_host import host_tasks
|
||||
import pytest
|
||||
|
||||
ENTITY = 'automember'
|
||||
|
||||
@@ -49,15 +49,180 @@ HOST_GROUP_DATA = {
|
||||
],
|
||||
}
|
||||
|
||||
SEARCH_CASES = {
|
||||
'name': 'search-123',
|
||||
'description': 'Short description !@#$%^&*()',
|
||||
'positive': [
|
||||
'search-123',
|
||||
'search',
|
||||
'search ',
|
||||
' search',
|
||||
'SEARCH',
|
||||
'123',
|
||||
'!@#$%^&*()',
|
||||
'hort descr',
|
||||
'description !',
|
||||
],
|
||||
'negative': [
|
||||
'searc-123',
|
||||
'321',
|
||||
'search 123',
|
||||
'search Short',
|
||||
'description!',
|
||||
],
|
||||
}
|
||||
|
||||
class test_automember(UI_driver):
|
||||
# Condition types
|
||||
INCLUSIVE = 'inclusive'
|
||||
EXCLUSIVE = 'exclusive'
|
||||
|
||||
|
||||
@pytest.mark.tier1
|
||||
class TestAutomember(UI_driver):
|
||||
|
||||
AUTOMEMBER_RULE_EXISTS_ERROR = (
|
||||
'Automember rule with name "{}" already exists'
|
||||
)
|
||||
|
||||
@pytest.fixture(autouse=True)
|
||||
def automember_setup(self, ui_driver_fsetup):
|
||||
self.init_app()
|
||||
|
||||
def add_user_group_rules(self, *pkeys, **kwargs):
|
||||
# We implicitly trigger "Add and Add Another" by passing multiple
|
||||
# records to add_record method.
|
||||
# TODO: Create more transparent mechanism to test "Add <entity>" dialog
|
||||
self.add_record(
|
||||
ENTITY,
|
||||
[{
|
||||
'pkey': pkey,
|
||||
'add': [('combobox', 'cn', pkey)],
|
||||
} for pkey in pkeys],
|
||||
facet='searchgroup',
|
||||
**kwargs
|
||||
)
|
||||
|
||||
def add_host_group_rules(self, *pkeys, **kwargs):
|
||||
self.add_record(
|
||||
ENTITY,
|
||||
[{
|
||||
'pkey': pkey,
|
||||
'add': [('combobox', 'cn', pkey)],
|
||||
} for pkey in pkeys],
|
||||
facet='searchhostgroup',
|
||||
**kwargs
|
||||
)
|
||||
|
||||
def add_user(self, pkey, name, surname):
|
||||
self.add_record('user', {
|
||||
'pkey': pkey,
|
||||
'add': [
|
||||
('textbox', 'uid', pkey),
|
||||
('textbox', 'givenname', name),
|
||||
('textbox', 'sn', surname),
|
||||
]
|
||||
})
|
||||
|
||||
def add_user_group(self, pkey, description=''):
|
||||
self.add_record('group', {
|
||||
'pkey': pkey,
|
||||
'add': [
|
||||
('textbox', 'cn', pkey),
|
||||
('textarea', 'description', description),
|
||||
]
|
||||
})
|
||||
|
||||
def add_host_group(self, pkey, description=''):
|
||||
self.add_record('hostgroup', {
|
||||
'pkey': pkey,
|
||||
'add': [
|
||||
('textbox', 'cn', pkey),
|
||||
('textarea', 'description', description),
|
||||
]
|
||||
})
|
||||
|
||||
def delete_users(self, *pkeys):
|
||||
self.delete('user', [{'pkey': pkey} for pkey in pkeys])
|
||||
|
||||
def delete_user_groups(self, *pkeys):
|
||||
self.delete('group', [{'pkey': pkey} for pkey in pkeys])
|
||||
|
||||
def delete_user_group_rules(self, *pkeys):
|
||||
self.delete(ENTITY, [{'pkey': pkey} for pkey in pkeys],
|
||||
facet='searchgroup')
|
||||
|
||||
def delete_host_groups(self, *pkeys):
|
||||
self.delete('hostgroup', [{'pkey': pkey} for pkey in pkeys])
|
||||
|
||||
def delete_host_group_rules(self, *pkeys):
|
||||
self.delete(ENTITY, [{'pkey': pkey} for pkey in pkeys],
|
||||
facet='searchhostgroup')
|
||||
|
||||
def add_conditions(self, conditions, condition_type):
|
||||
"""
|
||||
Add conditions to a rule
|
||||
|
||||
:param conditions: list of conditions where condition is a pair
|
||||
(attribute, expression)
|
||||
:param condition_type: can be 'inclusive' or 'exclusive'
|
||||
"""
|
||||
|
||||
name = 'automember{}regex'.format(condition_type)
|
||||
|
||||
attribute, expression = conditions[0]
|
||||
another_conditions = conditions[1:]
|
||||
another_conditions.reverse()
|
||||
|
||||
self.add_table_record(name, {'fields': [
|
||||
('selectbox', 'key', attribute),
|
||||
('textbox', name, expression)
|
||||
]}, add_another=bool(another_conditions))
|
||||
|
||||
while another_conditions:
|
||||
attribute, expression = another_conditions.pop()
|
||||
self.add_another_table_record(
|
||||
{'fields': [
|
||||
('selectbox', 'key', attribute),
|
||||
('textbox', name, expression)
|
||||
]},
|
||||
add_another=bool(another_conditions)
|
||||
)
|
||||
|
||||
def delete_conditions(self, conditions, condition_type):
|
||||
"""
|
||||
Delete rule conditions
|
||||
|
||||
:param conditions: list of conditions where condition is a pair
|
||||
(attribute, expression)
|
||||
:param condition_type: can be 'inclusive' or 'exclusive'
|
||||
"""
|
||||
|
||||
self.delete_record(
|
||||
['{}={}'.format(attr, exp) for attr, exp in conditions],
|
||||
parent=self.get_facet(),
|
||||
table_name='automember{}regex'.format(condition_type)
|
||||
)
|
||||
|
||||
def open_new_condition_dialog(self, condition_type):
|
||||
table = self.find_by_selector(
|
||||
"table[name='automember{}regex'].table".format(condition_type),
|
||||
strict=True
|
||||
)
|
||||
btn = self.find_by_selector(".btn[name=add]", table, strict=True)
|
||||
btn.click()
|
||||
self.wait()
|
||||
|
||||
def get_host_util(self):
|
||||
host_util = host_tasks()
|
||||
host_util.driver = self.driver
|
||||
host_util.config = self.config
|
||||
return host_util
|
||||
|
||||
@screenshot
|
||||
def test_crud(self):
|
||||
"""
|
||||
Basic CRUD: automember
|
||||
"""
|
||||
self.init_app()
|
||||
|
||||
# user group rule
|
||||
self.basic_crud(ENTITY, USER_GROUP_DATA,
|
||||
@@ -90,42 +255,25 @@ class test_automember(UI_driver):
|
||||
"""
|
||||
Test automember rebuild membership feature for hosts
|
||||
"""
|
||||
self.init_app()
|
||||
|
||||
host_util = host_tasks()
|
||||
host_util = self.get_host_util()
|
||||
domain = self.config.get('ipa_domain')
|
||||
host1 = 'web1.%s' % domain
|
||||
host2 = 'web2.%s' % domain
|
||||
|
||||
# Add a hostgroup
|
||||
self.add_record('hostgroup', {
|
||||
'pkey': 'webservers',
|
||||
'add': [
|
||||
('textbox', 'cn', 'webservers'),
|
||||
('textarea', 'description', 'webservers'),
|
||||
]
|
||||
})
|
||||
self.add_host_group('webservers', 'webservers')
|
||||
|
||||
# Add hosts
|
||||
self.add_record('host', host_util.get_data("web1", domain));
|
||||
self.add_record('host', host_util.get_data("web2", domain));
|
||||
self.add_record('host', host_util.get_data("web1", domain))
|
||||
self.add_record('host', host_util.get_data("web2", domain))
|
||||
|
||||
# Add an automember rule
|
||||
self.add_record(
|
||||
'automember',
|
||||
{'pkey': 'webservers', 'add': [('combobox', 'cn', 'webservers')]},
|
||||
facet='searchhostgroup'
|
||||
)
|
||||
self.add_host_group_rules('webservers')
|
||||
|
||||
# Add a condition for automember rule
|
||||
self.navigate_to_record('webservers')
|
||||
self.add_table_record(
|
||||
'automemberinclusiveregex',
|
||||
{'fields': [
|
||||
('selectbox', 'key', 'fqdn'),
|
||||
('textbox', 'automemberinclusiveregex', '^web[1-9]+')
|
||||
]}
|
||||
)
|
||||
self.add_conditions([('fqdn', '^web[1-9]+')], condition_type=INCLUSIVE)
|
||||
|
||||
# Assert that hosts are not members of hostgroup
|
||||
self.navigate_to_record('webservers', entity='hostgroup')
|
||||
@@ -148,15 +296,18 @@ class test_automember(UI_driver):
|
||||
# Remove host from hostgroup
|
||||
self.delete_record(host1)
|
||||
|
||||
# Assert that host is not a member of hostgroup
|
||||
# Assert that host was re-added to the group.
|
||||
# The behavior is expected with the plugin default setting:
|
||||
# the entry cn=Auto Membership Plugin,cn=plugins,cn=config has
|
||||
# a default value autoMemberProcessModifyOps: on
|
||||
#
|
||||
# See https://www.port389.org/docs/389ds/design/automember-postop-modify-design.html # noqa: E501
|
||||
self.facet_button_click('refresh')
|
||||
self.wait_for_request()
|
||||
self.assert_record(host1, negative=True)
|
||||
self.assert_record(host2, negative=True)
|
||||
self.assert_record(host1)
|
||||
|
||||
# Rebuild membership for all hosts, using action on hosts search facet
|
||||
self.navigate_by_menu('identity/host')
|
||||
self.navigate_by_breadcrumb('Hosts')
|
||||
self.action_list_action('automember_rebuild')
|
||||
|
||||
# Assert that hosts are now members of hostgroup
|
||||
@@ -167,63 +318,29 @@ class test_automember(UI_driver):
|
||||
self.assert_record(host2)
|
||||
|
||||
# Delete hostgroup, hosts and automember rule
|
||||
self.delete('hostgroup', [{'pkey': 'webservers'}])
|
||||
self.delete('host', [{'pkey': host1}, {'pkey': host2}])
|
||||
self.delete('automember', [{'pkey': 'webservers'}],
|
||||
facet='searchhostgroup')
|
||||
self.delete_host_group_rules('webservers')
|
||||
self.delete_host_groups('webservers')
|
||||
|
||||
@screenshot
|
||||
def test_rebuild_membership_users(self):
|
||||
"""
|
||||
Test automember rebuild membership feature for users
|
||||
"""
|
||||
self.init_app()
|
||||
|
||||
# Add a group
|
||||
self.add_record('group', {
|
||||
'pkey': 'devel',
|
||||
'add': [
|
||||
('textbox', 'cn', 'devel'),
|
||||
('textarea', 'description', 'devel'),
|
||||
]
|
||||
})
|
||||
self.add_user_group('devel', 'devel')
|
||||
|
||||
# Add a user
|
||||
self.add_record('user', {
|
||||
'pkey': 'dev1',
|
||||
'add': [
|
||||
('textbox', 'uid', 'dev1'),
|
||||
('textbox', 'givenname', 'Dev'),
|
||||
('textbox', 'sn', 'One'),
|
||||
]
|
||||
})
|
||||
|
||||
# Add another user
|
||||
self.add_record('user', {
|
||||
'pkey': 'dev2',
|
||||
'add': [
|
||||
('textbox', 'uid', 'dev2'),
|
||||
('textbox', 'givenname', 'Dev'),
|
||||
('textbox', 'sn', 'Two'),
|
||||
]
|
||||
})
|
||||
# Add users
|
||||
self.add_user('dev1', 'Dev', 'One')
|
||||
self.add_user('dev2', 'Dev', 'Two')
|
||||
|
||||
# Add an automember rule
|
||||
self.add_record(
|
||||
'automember',
|
||||
{'pkey': 'devel', 'add': [('combobox', 'cn', 'devel')]},
|
||||
facet='searchgroup'
|
||||
)
|
||||
self.add_user_group_rules('devel')
|
||||
|
||||
# Add a condition for automember rule
|
||||
self.navigate_to_record('devel')
|
||||
self.add_table_record(
|
||||
'automemberinclusiveregex',
|
||||
{'fields': [
|
||||
('selectbox', 'key', 'uid'),
|
||||
('textbox', 'automemberinclusiveregex', '^dev[1-9]+')
|
||||
]}
|
||||
)
|
||||
self.add_conditions([('uid', '^dev[1-9]+')], condition_type=INCLUSIVE)
|
||||
|
||||
# Assert that users are not members of group
|
||||
self.navigate_to_record('devel', entity='group')
|
||||
@@ -246,15 +363,18 @@ class test_automember(UI_driver):
|
||||
# Remove user from group
|
||||
self.delete_record('dev1')
|
||||
|
||||
# Assert that user is not a member of group
|
||||
# Assert that user was re-added to the group
|
||||
# The behavior is expected with the plugin default setting:
|
||||
# the entry cn=Auto Membership Plugin,cn=plugins,cn=config has
|
||||
# a default value autoMemberProcessModifyOps: on
|
||||
#
|
||||
# See https://www.port389.org/docs/389ds/design/automember-postop-modify-design.html # noqa: E501
|
||||
self.facet_button_click('refresh')
|
||||
self.wait_for_request()
|
||||
self.assert_record('dev1', negative=True)
|
||||
self.assert_record('dev2', negative=True)
|
||||
self.assert_record('dev1')
|
||||
|
||||
# Rebuild membership for all users, using action on users search facet
|
||||
self.navigate_by_menu('identity/user')
|
||||
self.navigate_by_breadcrumb('Users')
|
||||
self.navigate_by_menu('identity/user_search')
|
||||
self.action_list_action('automember_rebuild')
|
||||
|
||||
# Assert that users are now members of group
|
||||
@@ -265,6 +385,325 @@ class test_automember(UI_driver):
|
||||
self.assert_record('dev2')
|
||||
|
||||
# Delete group, users and automember rule
|
||||
self.delete('group', [{'pkey': 'devel'}])
|
||||
self.delete('user', [{'pkey': 'dev1'}, {'pkey': 'dev2'}])
|
||||
self.delete('automember', [{'pkey': 'devel'}], facet='searchgroup')
|
||||
self.delete_users('dev1', 'dev2')
|
||||
self.delete_user_group_rules('devel')
|
||||
self.delete_user_groups('devel')
|
||||
|
||||
@screenshot
|
||||
def test_add_multiple_user_group_rules(self):
|
||||
"""
|
||||
Test creating and deleting multiple user group rules
|
||||
"""
|
||||
|
||||
groups = ['group1', 'group2', 'group3']
|
||||
|
||||
for group in groups:
|
||||
self.add_user_group(group)
|
||||
|
||||
self.add_user_group_rules(*groups)
|
||||
self.delete_user_group_rules(*groups)
|
||||
|
||||
@screenshot
|
||||
def test_add_multiple_host_group_rules(self):
|
||||
"""
|
||||
Test creating and deleting multiple host group rules
|
||||
"""
|
||||
|
||||
groups = ['group1', 'group2', 'group3']
|
||||
|
||||
for group in groups:
|
||||
self.add_host_group(group)
|
||||
|
||||
self.add_host_group_rules(*groups)
|
||||
self.delete_host_group_rules(*groups)
|
||||
|
||||
@screenshot
|
||||
def test_search_user_group_rule(self):
|
||||
"""
|
||||
Test searching user group rules using filter
|
||||
"""
|
||||
|
||||
pkey = SEARCH_CASES['name']
|
||||
self.add_user_group(pkey, '')
|
||||
self.add_user_group_rules(pkey)
|
||||
self.navigate_to_record(pkey)
|
||||
self.mod_record(ENTITY, {'mod': [
|
||||
('textarea', 'description', SEARCH_CASES['description']),
|
||||
]}, facet='usergrouprule')
|
||||
self.navigate_to_entity(ENTITY, facet='searchgroup')
|
||||
|
||||
for text in SEARCH_CASES['positive']:
|
||||
self.apply_search_filter(text)
|
||||
self.wait_for_request()
|
||||
self.assert_record(pkey)
|
||||
|
||||
for text in SEARCH_CASES['negative']:
|
||||
self.apply_search_filter(text)
|
||||
self.wait_for_request()
|
||||
self.assert_record(pkey, negative=True)
|
||||
|
||||
self.delete_user_group_rules(pkey)
|
||||
self.delete_user_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_search_host_group_rule(self):
|
||||
"""
|
||||
Test searching host group rules using filter
|
||||
"""
|
||||
|
||||
pkey = SEARCH_CASES['name']
|
||||
self.add_host_group(pkey, '')
|
||||
self.add_host_group_rules(pkey, navigate=True)
|
||||
self.navigate_to_record(pkey)
|
||||
self.mod_record(ENTITY, {'mod': [
|
||||
('textarea', 'description', SEARCH_CASES['description']),
|
||||
]}, facet='hostgrouprule')
|
||||
self.navigate_to_entity(ENTITY, facet='searchhostgroup')
|
||||
|
||||
for text in SEARCH_CASES['positive']:
|
||||
self.apply_search_filter(text)
|
||||
self.wait_for_request()
|
||||
self.assert_record(pkey)
|
||||
|
||||
for text in SEARCH_CASES['negative']:
|
||||
self.apply_search_filter(text)
|
||||
self.wait_for_request()
|
||||
self.assert_record(pkey, negative=True)
|
||||
|
||||
self.delete_host_group_rules(pkey)
|
||||
self.delete_host_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_add_user_group_rule_conditions(self):
|
||||
"""
|
||||
Test creating and deleting user group rule conditions
|
||||
"""
|
||||
|
||||
pkey = 'devel'
|
||||
one_inc_condition = ('employeetype', '*engineer*')
|
||||
inc_conditions = [
|
||||
('cn', 'inclusive-expression'),
|
||||
('description', 'other-inclusive-expression'),
|
||||
]
|
||||
one_exc_condition = ('employeetype', '*manager*')
|
||||
exc_conditions = [
|
||||
('cn', 'exclusive-expression'),
|
||||
('description', 'other-exclusive-expression'),
|
||||
]
|
||||
|
||||
self.add_user_group(pkey)
|
||||
self.add_user_group_rules(pkey)
|
||||
|
||||
self.navigate_to_record(pkey)
|
||||
|
||||
self.add_conditions([one_inc_condition], condition_type=INCLUSIVE)
|
||||
self.add_conditions(inc_conditions, condition_type=INCLUSIVE)
|
||||
self.add_conditions([one_exc_condition], condition_type=EXCLUSIVE)
|
||||
self.add_conditions(exc_conditions, condition_type=EXCLUSIVE)
|
||||
|
||||
self.delete_conditions([one_inc_condition], condition_type=INCLUSIVE)
|
||||
self.delete_conditions(inc_conditions, condition_type=INCLUSIVE)
|
||||
self.delete_conditions([one_exc_condition], condition_type=EXCLUSIVE)
|
||||
self.delete_conditions(inc_conditions, condition_type=EXCLUSIVE)
|
||||
|
||||
self.delete_user_group_rules(pkey)
|
||||
self.delete_user_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_add_host_group_rule_conditions(self):
|
||||
"""
|
||||
Test creating and deleting user group rule conditions
|
||||
"""
|
||||
|
||||
pkey = 'devel'
|
||||
one_inc_condition = ('ipaclientversion', '4.8')
|
||||
inc_conditions = [
|
||||
('cn', 'inclusive-expression'),
|
||||
('description', 'other-inclusive-expression'),
|
||||
]
|
||||
one_exc_condition = ('ipaclientversion', '4.7')
|
||||
exc_conditions = [
|
||||
('cn', 'exclusive-expression'),
|
||||
('description', 'other-exclusive-expression'),
|
||||
]
|
||||
|
||||
self.add_host_group(pkey)
|
||||
self.add_host_group_rules(pkey)
|
||||
|
||||
self.navigate_to_record(pkey)
|
||||
|
||||
self.add_conditions([one_inc_condition], condition_type=INCLUSIVE)
|
||||
self.add_conditions(inc_conditions, condition_type=INCLUSIVE)
|
||||
self.add_conditions([one_exc_condition], condition_type=EXCLUSIVE)
|
||||
self.add_conditions(exc_conditions, condition_type=EXCLUSIVE)
|
||||
|
||||
self.delete_conditions([one_inc_condition], condition_type=INCLUSIVE)
|
||||
self.delete_conditions(inc_conditions, condition_type=INCLUSIVE)
|
||||
self.delete_conditions([one_exc_condition], condition_type=EXCLUSIVE)
|
||||
self.delete_conditions(inc_conditions, condition_type=EXCLUSIVE)
|
||||
|
||||
self.delete_host_group_rules(pkey)
|
||||
self.delete_host_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_cancel_new_user_group_rule_condition_dialog(self):
|
||||
"""
|
||||
Test canceling of creating new user group rule condition
|
||||
"""
|
||||
|
||||
pkey = 'devel'
|
||||
|
||||
self.add_user_group(pkey)
|
||||
self.add_user_group_rules(pkey)
|
||||
self.navigate_to_record(pkey)
|
||||
|
||||
for condition_type in [INCLUSIVE, EXCLUSIVE]:
|
||||
self.open_new_condition_dialog(condition_type)
|
||||
self.fill_fields([('selectbox', 'key', 'title')])
|
||||
self.dialog_button_click('cancel')
|
||||
|
||||
self.delete_user_group_rules(pkey)
|
||||
self.delete_user_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_cancel_new_host_group_rule_condition_dialog(self):
|
||||
"""
|
||||
Test canceling of creating new host group rule condition
|
||||
"""
|
||||
|
||||
pkey = 'devel'
|
||||
|
||||
self.add_host_group(pkey)
|
||||
self.add_host_group_rules(pkey)
|
||||
self.navigate_to_record(pkey)
|
||||
|
||||
for condition_type in [INCLUSIVE, EXCLUSIVE]:
|
||||
self.open_new_condition_dialog(condition_type)
|
||||
self.fill_fields([('selectbox', 'key', 'serverhostname')])
|
||||
self.dialog_button_click('cancel')
|
||||
|
||||
self.delete_host_group_rules(pkey)
|
||||
self.delete_host_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_set_default_user_group(self):
|
||||
"""
|
||||
Test setting default user group
|
||||
"""
|
||||
|
||||
pkey = 'default-user-group'
|
||||
user_pkey = 'some-user'
|
||||
|
||||
self.add_user_group(pkey)
|
||||
self.navigate_by_menu('identity/automember/amgroup')
|
||||
self.select_combobox('automemberdefaultgroup', pkey)
|
||||
self.dialog_button_click('ok')
|
||||
|
||||
self.add_user(user_pkey, 'Some', 'User')
|
||||
self.navigate_to_record(user_pkey)
|
||||
self.switch_to_facet('memberof_group')
|
||||
self.assert_record(pkey)
|
||||
|
||||
# Clear default user group
|
||||
self.navigate_by_menu('identity/automember/amgroup')
|
||||
self.select_combobox('automemberdefaultgroup', '')
|
||||
self.dialog_button_click('ok')
|
||||
|
||||
self.delete_users(user_pkey)
|
||||
self.delete_user_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_set_default_host_group(self):
|
||||
"""
|
||||
Test setting default host group
|
||||
"""
|
||||
|
||||
pkey = 'default-host-group'
|
||||
host_util = self.get_host_util()
|
||||
domain = self.config.get('ipa_domain')
|
||||
|
||||
self.add_host_group(pkey)
|
||||
self.navigate_by_menu('identity/automember/amhostgroup')
|
||||
self.select_combobox('automemberdefaultgroup', pkey)
|
||||
self.dialog_button_click('ok')
|
||||
|
||||
host_data = host_util.get_data('some-host', domain)
|
||||
self.add_record('host', host_data)
|
||||
self.navigate_to_record(host_data['pkey'])
|
||||
self.switch_to_facet('memberof_hostgroup')
|
||||
self.assert_record(pkey)
|
||||
|
||||
# Clear default host group
|
||||
self.navigate_by_menu('identity/automember/amhostgroup')
|
||||
self.select_combobox('automemberdefaultgroup', '')
|
||||
self.dialog_button_click('ok')
|
||||
|
||||
self.delete('host', [{'pkey': host_data['pkey']}])
|
||||
self.delete_host_groups(pkey)
|
||||
|
||||
@screenshot
|
||||
def test_add_user_group_rule_with_no_group(self):
|
||||
|
||||
self.add_record(
|
||||
ENTITY,
|
||||
{'pkey': 'empty-user-group', 'add': []},
|
||||
facet='searchgroup',
|
||||
negative=True
|
||||
)
|
||||
|
||||
@screenshot
|
||||
def test_add_host_group_rule_with_no_group(self):
|
||||
|
||||
self.add_record(
|
||||
ENTITY,
|
||||
{'pkey': 'empty-host-group', 'add': []},
|
||||
facet='searchhostgroup',
|
||||
negative=True
|
||||
)
|
||||
|
||||
@screenshot
|
||||
def test_add_user_group_rules_for_same_group(self):
|
||||
"""
|
||||
Test creating user group rules for same group
|
||||
"""
|
||||
|
||||
group_name = 'some-user-group'
|
||||
|
||||
self.add_user_group(group_name)
|
||||
self.add_user_group_rules(group_name)
|
||||
self.add_user_group_rules(group_name, negative=True, pre_delete=False)
|
||||
|
||||
self.assert_last_error_dialog(
|
||||
self.AUTOMEMBER_RULE_EXISTS_ERROR.format(group_name)
|
||||
)
|
||||
|
||||
self.delete_user_group_rules(group_name)
|
||||
self.delete_user_groups(group_name)
|
||||
|
||||
@screenshot
|
||||
def test_add_host_group_rules_for_same_group(self):
|
||||
"""
|
||||
Test creating host group rules for same group
|
||||
"""
|
||||
|
||||
group_name = 'some-host-group'
|
||||
|
||||
self.add_host_group(group_name)
|
||||
self.add_host_group_rules(group_name)
|
||||
self.add_host_group_rules(group_name, negative=True, pre_delete=False)
|
||||
|
||||
self.assert_last_error_dialog(
|
||||
self.AUTOMEMBER_RULE_EXISTS_ERROR.format(group_name)
|
||||
)
|
||||
|
||||
self.delete_host_group_rules(group_name)
|
||||
self.delete_host_groups(group_name)
|
||||
|
||||
@screenshot
|
||||
def test_cancel_group_rule_creating(self):
|
||||
"""
|
||||
Test canceling of creating new automember group rule
|
||||
"""
|
||||
|
||||
self.add_user_group_rules('some-user-group', dialog_btn='cancel')
|
||||
self.add_host_group_rules('some-host-group', dialog_btn='cancel')
|
||||
|
||||
Reference in New Issue
Block a user