aboutsummaryrefslogtreecommitdiffstats
path: root/tests/uiTests/test_dashboard_feature.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/uiTests/test_dashboard_feature.py')
-rw-r--r--tests/uiTests/test_dashboard_feature.py164
1 files changed, 164 insertions, 0 deletions
diff --git a/tests/uiTests/test_dashboard_feature.py b/tests/uiTests/test_dashboard_feature.py
new file mode 100644
index 0000000..2303eb8
--- /dev/null
+++ b/tests/uiTests/test_dashboard_feature.py
@@ -0,0 +1,164 @@
+
+# ============LICENSE_START==========================================
+# org.onap.vvp/test-engine
+# ===================================================================
+# Copyright © 2017 AT&T Intellectual Property. All rights reserved.
+# ===================================================================
+#
+# Unless otherwise specified, all software contained herein is licensed
+# under the Apache License, Version 2.0 (the “License”);
+# you may not use this software except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+#
+#
+# Unless otherwise specified, all documentation contained herein is licensed
+# under the Creative Commons License, Attribution 4.0 Intl. (the “License”);
+# you may not use this documentation except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# https://creativecommons.org/licenses/by/4.0/
+#
+# Unless required by applicable law or agreed to in writing, documentation
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# ============LICENSE_END============================================
+#
+# ECOMP is a trademark and service mark of AT&T Intellectual Property.
+from iceci.decorator.exception_decor import exception
+from services.constants import Constants
+from services.logging_service import LoggingServiceFactory
+from services.session import session
+from services.types import API, DB, Frontend
+from tests.uiTests.test_ui_base import TestUiBase
+
+
+logger = LoggingServiceFactory.get_logger()
+
+
+class TestDashboardFeature(TestUiBase):
+ user_content = None
+
+ @classmethod
+ def setUpClass(cls):
+ super(TestDashboardFeature, cls).setUpClass()
+
+ cls.user_content = API.VirtualFunction.create_engagement(
+ wait_for_gitlab=False)
+
+ @exception()
+ def test_validate_filtering_by_stage_intake(self):
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.validate_filtering_by_stage(
+ self.user_content, Constants.EngagementStages.INTAKE)
+
+ @exception()
+ def test_validate_filtering_by_stage_active(self):
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.validate_filtering_by_stage_with_page_ids(
+ self.user_content, Constants.EngagementStages.ACTIVE)
+
+ @exception()
+ def test_validate_filtering_by_stage_validated(self):
+ query = "UPDATE ice_engagement SET engagement_stage='Validated' WHERE engagement_manual_id ='" + \
+ str(self.user_content['engagement_manual_id']) + "';"
+ DB.General.update_by_query(query)
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.validate_filtering_by_stage_with_page_ids(
+ self.user_content, Constants.EngagementStages.VALIDATED)
+
+ @exception()
+ def test_validate_filtering_by_stage_completed(self):
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.validate_filtering_by_stage_with_page_ids(
+ self.user_content, Constants.EngagementStages.COMPLETED)
+
+ @exception()
+ def test_validate_filtering_by_stage_all(self):
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.validate_filtering_by_stage_with_page_ids(
+ self.user_content, Constants.EngagementStages.ALL)
+
+ @exception()
+ def test_validate_statistics_by_stages(self):
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.validate_statistics_by_stages(self.user_content)
+
+ @exception()
+ def test_assigned_next_steps(self):
+ Frontend.User.login(
+ self.user_content['email'], Constants.Default.Password.TEXT)
+ Frontend.User.assigned_one_NS_to_user(self.user_content)
+ Frontend.Dashboard.check_if_the_eng_of_NS_is_the_correct_one(
+ self.user_content)
+ Frontend.Dashboard.check_if_creator_of_NS_is_the_EL(self.user_content)
+ Frontend.Overview.go_to_eng_overview_by_clicking_on_the_created_NS(
+ self.user_content)
+
+ @exception()
+ def test_search_engagement(self):
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.DetailedView.search_vf_and_go_to_detailed_view(
+ self.user_content['engagement_manual_id'],
+ self.user_content['vfName'])
+ vfcName = Frontend.DetailedView.add_vfc()
+ users = [self.user_content['el_email'], self.user_content['pr_email'],
+ self.user_content['email'],
+ Constants.Users.Admin.EMAIL, Constants.Users.AdminRO.EMAIL]
+ session.wait_until_retires = 20
+ Frontend.Dashboard.search_in_dashboard(
+ self.user_content, vfcName, users)
+ session.wait_until_retires = session.positive_wait_until_retires
+
+ @exception()
+ def test_validate_statistics_modal_appears_for_peer_re(self):
+ Frontend.User.login(
+ self.user_content['pr_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.click_on_dashboard_and_validate_statistics(
+ is_negative=False)
+
+ @exception()
+ def test_validate_statistics_modal_appears_for_el(self):
+ Frontend.User.login(
+ self.user_content['el_email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.click_on_dashboard_and_validate_statistics(
+ is_negative=False)
+
+ @exception()
+ def test_validate_statistics_modal_appears_for_standart_user(self):
+ Frontend.User.login(
+ self.user_content['email'], Constants.Default.Password.TEXT)
+ Frontend.Dashboard.click_on_dashboard_and_validate_statistics(
+ is_negative=True)
+
+ @exception()
+ def test_validate_statistics_modal_appears_for_admin(self):
+ Frontend.User.login(
+ Constants.Users.Admin.EMAIL, Constants.Default.Password.TEXT)
+ Frontend.Dashboard.click_on_dashboard_and_validate_statistics(
+ is_negative=False)
+
+ @exception()
+ def test_validate_statistics_modal_appears_for_admin_ro(self):
+ Frontend.User.login(
+ Constants.Users.AdminRO.EMAIL, Constants.Default.Password.TEXT)
+ Frontend.Dashboard.click_on_dashboard_and_validate_statistics(
+ is_negative=False)