From a04cedf19d55c4518b5ad50d604c9b5d45c5a942 Mon Sep 17 00:00:00 2001 From: Antonin Pagac Date: Wed, 17 Jul 2019 15:44:00 +0200 Subject: [PATCH] Adding test coverage --- cfme/tests/cloud/test_snapshot.py | 60 ++++----- cfme/tests/configure/test_access_control.py | 139 ++++++++++++++++++++ cfme/tests/integration/test_cfme_auth.py | 69 ++++++++++ 3 files changed, 235 insertions(+), 33 deletions(-) diff --git a/cfme/tests/cloud/test_snapshot.py b/cfme/tests/cloud/test_snapshot.py index 407a37b510..bdf3d81626 100644 --- a/cfme/tests/cloud/test_snapshot.py +++ b/cfme/tests/cloud/test_snapshot.py @@ -6,39 +6,6 @@ from cfme.cloud.provider.openstack import OpenStackProvider -@pytest.mark.manual -@pytest.mark.provider([OpenStackProvider]) -@test_requirements.snapshot -@pytest.mark.tier(1) -def test_osp_snapshot_buttons(): - """ - Test new OSP snapshot button and make sure Snapshot link is removed from Instance Details - page. - - Polarion: - assignee: apagac - casecomponent: Cloud - caseimportance: medium - initialEstimate: 1/4h - startsin: 5.10 - setup: - 1. Have OSP provider added and test instance created - testSteps: - 1. Navigate to test instance - 2. Make sure the snapshot button is displayed in the top menu - 3. Try snapshot crud - 4. Navigate to instance summary screen; Check if the original Snapshot link is present - expectedResults: - 1. Test instance summary page displayed - 2. Snapshot button displayed - 3. Snapshot created; Snapshot deleted - 4. Snapshot link is not displayed - Bugzilla: - 1690954 - """ - pass - - @pytest.mark.manual @pytest.mark.provider([OpenStackProvider]) @test_requirements.snapshot @@ -165,3 +132,30 @@ def test_snapshot_cloud_tenant(): 1685300 """ pass + + +@pytest.mark.manual +@pytest.mark.provider([OpenStackProvider]) +@test_requirements.snapshot +@pytest.mark.tier(2) +def test_snapshot_description_mandatory(): + """ + Test that when creating snapshots on Openstack provider the Description field is mandatory. + + Polarion: + assignee: apagac + casecomponent: Cloud + caseimportance: high + initialEstimate: 1/4h + setup: + 1. Have OSP provider added and test VM created + testSteps: + 1. Try to create a snapshot with no description + 2. Try to create a snapshot with description + expectedResults: + 1. Snapshot not created; 'Required' displayed + 2. Snapshot created successfully + Bugzilla: + 1647916 + """ + pass diff --git a/cfme/tests/configure/test_access_control.py b/cfme/tests/configure/test_access_control.py index 0156a72d09..a33ceb20ea 100644 --- a/cfme/tests/configure/test_access_control.py +++ b/cfme/tests/configure/test_access_control.py @@ -2674,3 +2674,142 @@ def test_tenant_template_visibility(): initialEstimate: 1/10h """ pass + + +@pytest.mark.manual +@test_requirements.rbac +@pytest.mark.tier(2) +def test_create_higher_permission_child_tenant(): + """ + Test creating a group with higher permission that the user currently has on a new tenant. + + Polarion: + assignee: apagac + casecomponent: Configuration + caseimportance: medium + initialEstimate: 1/4h + testSteps: + 1. Create child tenant: "My tenant" + 2. Create group with: + - "My Tenant admin group" with role: "EvmRole-tenant_administrator" + - Tenant: "My tenant" + 3. Create tenant admin user "tenantadmin" with group "My Tenant admin group" + 4. login as tenant admin + 5. Try to create group with EvmRole-super_administrator + expectedResults: + 1. + 2. + 3. + 4. + 5. EvmRole-super_administrator should not be available + Bugzilla: + 1418297 + """ + pass + + +@pytest.mark.manual +@test_requirements.rbac +@pytest.mark.tier(2) +def test_create_higher_permission(): + """ + Test creating a group with higher permission that the user currently has. + + Polarion: + assignee: apagac + casecomponent: Configuration + caseimportance: medium + initialEstimate: 1/4h + testSteps: + 1. Create user with tenant_administrator role + 2. Log in as that user + 3. Go to Users + expectedResults: + 1. + 2. + 3. Users without super-administator role and administator role visible + Bugzilla: + 1447370 + """ + pass + + +@pytest.mark.manual +@test_requirements.rbac +@pytest.mark.tier(2) +def test_multiple_notifications(): + """ + Test that user that is a member of multiple groups receives only one notification. + + Polarion: + assignee: apagac + casecomponent: Configuration + caseimportance: medium + initialEstimate: 1/4h + testSteps: + 1. Create a user, assign him to multiple groups + 2. As the user, provision a VM + expectedResults: + 1. + 2. Only one notification displayed upon successfull provision + Bugzilla: + 1549898 + """ + pass + + +@pytest.mark.manual +@test_requirements.rbac +@pytest.mark.tier(2) +def test_cluster_filters(): + """ + Test that filters work even when deleting the item they were in place for. + + Polarion: + assignee: apagac + casecomponent: Configuration + caseimportance: medium + initialEstimate: 1/4h + setup: + 1. Have a provider with multiple Datastores and Clusters. + 2. Assume you have Datastore1 with Cluster1 and Datastore2 with Cluster2 + testSteps: + 1. Create a role and group with the filters for only Cluster1 + 2. Create a user with this group + 3. Login and verify that you can see only Cluster1 + 4. Delete Datastore1 (with Cluster1) + 5. Verify the user now can't see any cluster + expectedResults: + 1. + 2. + 3. User can see only Cluster1 + 4. + 5. User can't see any Cluster + Bugzilla: + 1693183 + """ + pass + + +@pytest.mark.manual +@test_requirements.rbac +@pytest.mark.tier(2) +def test_delete_custom_super_admin(): + """ + Test that custom user with super_administrator group can be deleted. + + Polarion: + assignee: apagac + casecomponent: Configuration + caseimportance: medium + initialEstimate: 1/4h + testSteps: + 1. Create a new user with group EvmGroup-super_administrator + 2. Try to delete this user + expectedResults: + 1. + 2. User successfully deleted + Bugzilla: + 1720273 + """ + pass diff --git a/cfme/tests/integration/test_cfme_auth.py b/cfme/tests/integration/test_cfme_auth.py index ec6b0291e6..efed0303a9 100644 --- a/cfme/tests/integration/test_cfme_auth.py +++ b/cfme/tests/integration/test_cfme_auth.py @@ -1535,3 +1535,72 @@ def test_session_timeout(): title: Verify session timeout works fine for external auth. """ pass + + +@pytest.mark.manual +@test_requirements.auth +@pytest.mark.tier(2) +def test_certmonger_service(): + """ + Test that the certmonger service is running after SSL certs have been setup and appliance + rebooted. + + Polarion: + assignee: apagac + casecomponent: Configuration + caseimportance: medium + initialEstimate: 1/4h + setup: + 1. Have IDM (freeipa) server up and running + testSteps: + 1. Configure appliance to use external auth via IDM server: + appliance_console_cli \ + --ipaserver= \ + --ipaprincipal= \ + --ipapassword= + 2. Setup SSL certs on the appliance: + appliance_console_cli \ + --ca=ipa \ + --http-cert + 3. Reboot the appliance + 4. View status of the certmonger service: + systemctl status certmonger + expectedResults: + 1. Appliance configured. + 2. Certs installed + 3. Appliance rebooted + 4. certmonger service running + Bugzilla: + 1670604 + """ + pass + + +@pytest.mark.manual +@test_requirements.auth +@pytest.mark.tier(2) +def test_group_lookup_oidc(): + """ + Test that group lookup is disabled when using OpenID-Connect. + + Polarion: + assignee: apagac + casecomponent: Configuration + caseimportance: medium + initialEstimate: 1/4h + testSteps: + 1. Configure your appliance to use External auth: + Configuration -> Settings -> select Current Server -> Authentication -> Mode + -> set to External + 2. On the same page, choose Provider Type: Enable OpenID-Connect + 3. Navigate to Configuration -> Access Control -> Create a new Group + 4. Ensure the "(Look up External Authentication Groups)" checkbox is not displayed + expectedResults: + 1. Appliance configured + 2. OIDC enabled + 3. + 4. Checkbox not displayed + Bugzilla: + 1609321 + """ + pass