Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[6.15.z] Extend ansible-roles add/remove test for nested HG #14287

Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
44 changes: 37 additions & 7 deletions tests/foreman/api/test_ansible.py
Original file line number Diff line number Diff line change
Expand Up @@ -209,18 +209,20 @@ def test_positive_ansible_job_on_multiple_host(

@pytest.mark.e2e
@pytest.mark.tier2
@pytest.mark.upgrade
def test_add_and_remove_ansible_role_hostgroup(target_sat):
"""
Test add and remove functionality for ansible roles in hostgroup via API

:id: 7672cf86-fa31-11ed-855a-0fd307d2d66b

:steps:
1. Create a hostgroup
2. Sync few ansible roles
1. Create a hostgroup and a nested hostgroup
2. Sync a few ansible roles
3. Assign a few ansible roles with the host group
4. Add some ansible role with the host group
5. Remove the added ansible roles from the host group
5. Add some ansible roles to the nested hostgroup
6. Remove the added ansible roles from the parent and nested hostgroup

:expectedresults:
1. Ansible role assign/add/remove functionality should work as expected in API
Expand All @@ -231,29 +233,57 @@ def test_add_and_remove_ansible_role_hostgroup(target_sat):
'theforeman.foreman_scap_client',
'redhat.satellite.hostgroups',
'RedHatInsights.insights-client',
'redhat.satellite.compute_resources',
]
hg = target_sat.api.HostGroup(name=gen_string('alpha')).create()
hg_nested = target_sat.api.HostGroup(name=gen_string('alpha'), parent=hg).create()
proxy_id = target_sat.nailgun_smart_proxy.id
target_sat.api.AnsibleRoles().sync(data={'proxy_id': proxy_id, 'role_names': ROLE_NAMES})
ROLES = [
target_sat.api.AnsibleRoles().search(query={'search': f'name={role}'})[0].id
for role in ROLE_NAMES
]
# Assign first 2 roles to HG and verify it
target_sat.api.HostGroup(id=hg.id).assign_ansible_roles(data={'ansible_role_ids': ROLES[:2]})
for r1, r2 in zip(
target_sat.api.HostGroup(id=hg.id).list_ansible_roles(), ROLE_NAMES[:2], strict=True
):
assert r1['name'] == r2

# Add next role from list to HG and verify it
target_sat.api.HostGroup(id=hg.id).add_ansible_role(data={'ansible_role_id': ROLES[2]})
for r1, r2 in zip(
target_sat.api.HostGroup(id=hg.id).list_ansible_roles(), ROLE_NAMES, strict=True
target_sat.api.HostGroup(id=hg.id).list_ansible_roles(), ROLE_NAMES[:3], strict=True
):
assert r1['name'] == r2

for role in ROLES:
# Add next role to nested HG, and verify roles are also nested to HG along with assigned role
# Also, ensure the parent HG does not contain the roles assigned to nested HGs
target_sat.api.HostGroup(id=hg_nested.id).add_ansible_role(data={'ansible_role_id': ROLES[3]})
for r1, r2 in zip(
target_sat.api.HostGroup(id=hg_nested.id).list_ansible_roles(),
[ROLE_NAMES[-1]] + ROLE_NAMES[:-1],
strict=True,
):
assert r1['name'] == r2

for r1, r2 in zip(
target_sat.api.HostGroup(id=hg.id).list_ansible_roles(), ROLE_NAMES[:3], strict=True
):
assert r1['name'] == r2

# Remove roles assigned one by one from HG and nested HG
for role in ROLES[:3]:
target_sat.api.HostGroup(id=hg.id).remove_ansible_role(data={'ansible_role_id': role})
host_roles = target_sat.api.HostGroup(id=hg.id).list_ansible_roles()
assert len(host_roles) == 0
hg_roles = target_sat.api.HostGroup(id=hg.id).list_ansible_roles()
assert len(hg_roles) == 0

for role in ROLES:
target_sat.api.HostGroup(id=hg_nested.id).remove_ansible_role(
data={'ansible_role_id': role}
)
hg_nested_roles = target_sat.api.HostGroup(id=hg_nested.id).list_ansible_roles()
assert len(hg_nested_roles) == 0


@pytest.fixture
Expand Down
Loading