def test_invite_existing_user(self):
     '''
         Create user and VF, login, invite existing user,
         login with second user and verify user has joined to engagement
     '''
     user_content = API.VirtualFunction.create_engagement(
         wait_for_gitlab=False)
     second_user_content = API.VirtualFunction.create_engagement(
         wait_for_gitlab=False)
     activationUrl = DB.User.get_activation_url(user_content['email'])
     Frontend.General.re_open(activationUrl)
     Frontend.User.login(user_content['email'],
                         Constants.Default.Password.TEXT)
     vfFullName = user_content[
         'engagement_manual_id'] + ": " + user_content['vfName']
     actualVfNameid = "clickable-" + vfFullName
     Click.id(actualVfNameid, wait_for_page=True)
     Wait.id(Constants.Dashboard.Overview.TeamMember.ID)
     Frontend.Wizard.invite_team_members_modal(second_user_content['email'])
     enguuid = DB.General.select_where(
         "uuid", "ice_engagement", "engagement_manual_id",
         user_content['engagement_manual_id'],
         1)  # Fetch one is_service_provider_contact user ID.
     invitation_token = DB.User.select_invitation_token(
         "invitation_token", "ice_invitation", "engagement_uuid", enguuid,
         second_user_content['email'], 1)
     inviterURL = Constants.Default.InviteURL.Login.TEXT + invitation_token
     Frontend.General.re_open(inviterURL)
     actualVfNameid = "clickable-" + vfFullName
     Frontend.User.login(second_user_content['email'],
                         Constants.Default.Password.TEXT, actualVfNameid)
     Wait.modal_to_dissappear()
     Frontend.Overview.click_on_vf(user_content)
     Wait.text_by_id(Constants.Dashboard.Overview.Title.ID, vfFullName)
Пример #2
0
 def validate_filtering_by_stage(user_content, stage):
     FEGeneral.re_open(Constants.Default.LoginURL.TEXT)
     # Validate Scrolling    #
     FEUser.login(user_content['el_email'], Constants.Default.Password.TEXT)
     FEOverview.click_on_vf(user_content)
     Click.id(Constants.Dashboard.Statuses.ID, wait_for_page=True)
     Wait.text_by_id("dashboard-title", "Statuses", wait_for_page=True)
     Wait.id("search-filter-stage")
     Select(session.ice_driver.find_element_by_id(
         "search-filter-stage")).select_by_visible_text(stage)
     Wait.id(Constants.Dashboard.Statuses.ExportExcel.ID,
             wait_for_page=True)
     engLeadID = DBUser.select_user_native_id(user_content['el_email'])
     # Query for fetching count of rows per stage.
     countOfEngInStagePerUser = DBUser.select_user_engagements_by_stage(
         stage, engLeadID)
     #    Calculate number of pages    #
     NUM_OF_RESULTS_PER_PAGES = 8
     number_of_pages = countOfEngInStagePerUser // NUM_OF_RESULTS_PER_PAGES
     logger.debug("Number of pages: " + str(number_of_pages))
     if (countOfEngInStagePerUser % NUM_OF_RESULTS_PER_PAGES != 0):
         number_of_pages += 1
     logger.debug("number_of_pages " + str(number_of_pages))  # Scroll    #
     Wait.id("engagements-pagination", wait_for_page=True)
     element = session.ice_driver.find_element_by_id(
         "engagements-pagination")
     element.location_once_scrolled_into_view
     Click.link_text(str(number_of_pages), wait_for_page=True)
 def open_validation_details():
     Click.id(Constants.Dashboard.DetailedView.ValidationDetails.PLUS,
              wait_for_page=True)
     Wait.text_by_id(
         Constants.Dashboard.Modal.TITLE_ID,
         Constants.Dashboard.DetailedView.ValidationDetails.TITLE,
         wait_for_page=True)
 def remove_vfc(user_content):
     vf_id = DBGeneral.select_where("uuid", "ice_vf", "name",
                                    user_content['vfName'], 1)
     djoni_uuid = None
     counter = 0
     while not djoni_uuid and counter <= Constants.DBConstants.\
             RETRIES_NUMBER:
         time.sleep(session.wait_until_time_pause_long)
         djoni_uuid = DBGeneral.select_where_and("uuid", "ice_vfc", "vf_id",
                                                 vf_id, "name", "djoni", 1)
         logger.debug("Checklist state not changed yet  (%s of %s)" %
                      (counter, Constants.DBConstants.RETRIES_NUMBER))
         counter += 1
     logger.debug("VFC_UUID was successfully selecteded : " + djoni_uuid +
                  ", and was verified over the DB")
     Wait.text_by_id(Constants.Dashboard.DetailedView.VFC.ID + "djoni",
                     "djoni (loka)",
                     wait_for_page=True)
     Wait.text_by_id(Constants.Dashboard.DetailedView.VFC.ID + "djoni2",
                     "djoni2 (loka2)",
                     wait_for_page=True)
     Click.id(Constants.Dashboard.DetailedView.VFC.ID + "djoni",
              wait_for_page=True)
     Click.id(Constants.Dashboard.DetailedView.VFC.Remove.ID + djoni_uuid,
              wait_for_page=True)
 def click_on_update_ecomp_release():
     Click.id(Constants.Dashboard.DetailedView.ValidationDetails.PLUS,
              wait_for_page=True)
     Wait.text_by_id(
         Constants.Dashboard.Modal.TITLE_ID,
         Constants.Dashboard.DetailedView.ValidationDetails.TITLE,
         wait_for_page=True)
Пример #6
0
 def get_to_create_new_ns_modal_via_overview():
     Click.id(Constants.Dashboard.Overview.NextSteps.Add.ID,
              wait_for_page=True)
     Wait.text_by_css(Constants.Dashboard.Checklist.AddNS.CSS,
                      Constants.Dashboard.Overview.NextSteps.Add.TITLE)
     Helper.internal_assert(Constants.Dashboard.Checklist.AddNS.TITLE,
                            Get.by_css(Constants.FEGeneral.CSS.H2))
Пример #7
0
 def validate_multi_eng(user_content, checklist_content, newEL_content,
                        actualVfNameid):
     query = "UPDATE ice_user_profile SET role_id=2 WHERE email = '" + \
         str(newEL_content['email']) + "';"
     DBGeneral.update_by_query(query)
     FEWizard.invite_team_members_modal(newEL_content['email'])
     # Fetch one AT&T user ID.
     enguuid = DBGeneral.select_where("uuid", "ice_engagement",
                                      "engagement_manual_id",
                                      user_content['engagement_manual_id'],
                                      1)
     invitation_token = DBUser.select_invitation_token(
         "invitation_token", "ice_invitation", "engagement_uuid", enguuid,
         newEL_content['email'], 1)
     URL = Constants.Default.InviteURL.Login.TEXT + invitation_token
     FEGeneral.re_open(URL)
     FEUser.login(newEL_content['email'],
                  Constants.Default.Password.TEXT,
                  expected_element=actualVfNameid)
     Click.id(actualVfNameid, wait_for_page=True)
     count = None
     try:
         session.ice_driver.find_element_by_id("checklist-" +
                                               checklist_content['uuid'])
         count += 1
     except BaseException:
         logger.debug("check list not visible for EL invited : " +
                      str(newEL_content['email']))
     assertTrue(count is None)
     query = "UPDATE ice_user_profile SET role_id=1 WHERE email = '" + \
         str(newEL_content['email']) + "';"
     DBGeneral.update_by_query(query)
Пример #8
0
 def search_by_manual_id(manual_id):
     Enter.text_by_id(Constants.Dashboard.LeftPanel.SearchBox.ID,
                      manual_id,
                      wait_for_page=True)
     Click.css(Constants.Dashboard.LeftPanel.SearchBox.Results.CSS,
               wait_for_page=True)
     Wait.id(Constants.Dashboard.Overview.Title.ID)
Пример #9
0
 def edit_template_and_save():
     Click.id(Constants.Dashboard.LeftPanel.EditChecklistTemplate.
              FIRST_SECTION_ID)
     Enter.text_by_id(
         Constants.Dashboard.LeftPanel.EditChecklistTemplate.
         FIRST_SECTION_INPUT_ID, "Ros Is My Mentor")
     FEChecklistTemplate.click_on_save_and_assert_success_msg()
Пример #10
0
 def search_in_left_searchbox_by_param(manual_id, vf_name, param):
     myVfName = manual_id + ": " + vf_name
     Enter.text_by_xpath(
         Constants.Dashboard.LeftPanel.SearchBox.Results.XPATH, param)
     Wait.text_by_css(Constants.Dashboard.LeftPanel.SearchBox.Results.CSS,
                      myVfName)
     Click.css(Constants.Dashboard.LeftPanel.SearchBox.Results.CSS)
Пример #11
0
 def get_rgwa_access_secret():
     Click.id(Constants.Dashboard.Avatar.Account.RGWA.Secret.BUTTON_ID,
              wait_for_page=True)
     secret = Get.by_id(
         Constants.Dashboard.Avatar.Account.RGWA.Secret.SECRET_ID,
         wait_for_page=True)
     return secret
Пример #12
0
 def validate_statistics_by_stages(user_content):
     #    Validate Scrolling    #
     FEOverview.click_on_vf(user_content)
     Click.id(Constants.Dashboard.Statuses.ID)
     Wait.text_by_id("dashboard-title", "Statuses")
     Wait.css(Constants.Dashboard.Statuses.Statistics.FilterDropdown.CSS)
     Select(
         session.ice_driver.find_element_by_css_selector(
             Constants.Dashboard.Statuses.Statistics.FilterDropdown.CSS)
     ).select_by_visible_text("All")
     engLeadID = DBUser.select_user_native_id(user_content['el_email'])
     countOfEngInStagePerUser = DBUser.select_all_user_engagements(
         engLeadID)  # Scroll    #
     Wait.text_by_id(
         Constants.Dashboard.Statuses.Statistics.EngagementsNumber.ID,
         str(countOfEngInStagePerUser),
         wait_for_page=True)
     element = session.ice_driver.find_element_by_id(
         Constants.Dashboard.Statuses.Statistics.EngagementsNumber.ID)
     # Stage Active Validation    #
     element.location_once_scrolled_into_view
     Wait.css(Constants.Dashboard.Statuses.Statistics.FilterDropdown.CSS,
              wait_for_page=True)
     Select(
         session.ice_driver.find_element_by_css_selector(
             Constants.Dashboard.Statuses.Statistics.FilterDropdown.CSS)
     ).select_by_visible_text("Active")
     countOfEngInStagePerUser = DBUser.select_user_engagements_by_stage(
         "Active", engLeadID)
     Wait.text_by_id(
         Constants.Dashboard.Statuses.Statistics.EngagementsNumber.ID,
         str(countOfEngInStagePerUser),
         wait_for_page=True)
Пример #13
0
 def add_vf():
     try:
         logger.debug("Tab Add Virtual Functions")
         Wait.text_by_css(
             Constants.Dashboard.Wizard.Title.CSS,
             Constants.Dashboard.Wizard.AddVF.Title.TEXT,
             wait_for_page=True)
         vfName = "newVF" + Helper.rand_string("randomString")
         vfVersion = "newVFVersion" + \
             Helper.rand_string(
                 "randomNumber") + Helper.rand_string("randomString")
         Enter.text_by_name("virtualFunction", vfName)
         Enter.text_by_name("VFversion", vfVersion, wait_for_page=True)
         FEWizard.date_picker_wizard()
         Select(session.ice_driver.find_element_by_id(
             Constants.Dashboard.Wizard.AddVF.AIC_Version.TEXT
         )).select_by_visible_text("AIC 3.5")
         Select(session.ice_driver.find_element_by_id(
             Constants.Dashboard.Wizard.AddVF.ECOMP_Release.TEXT
         )).select_by_visible_text("Unknown")
         session.E2Edate = FEWizard.get_lab_entry_date()
         Click.css(Constants.SubmitButton.CSS, wait_for_page=True)
         Wait.page_has_loaded()
         Wait.name_to_dissappear("Add Virtual Function")
         return vfName
     # If failed - count the failure and add the error to list of errors.
     except Exception as e:
         errorMsg = "Failed to add a Virtual Function via modal window. " +\
             "Exception " +\
             str(e)
         raise Exception(errorMsg)
Пример #14
0
 def click_on_admin():
     try:
         Click.id(Constants.Dashboard.Avatar.Admin.Title.ID,
                  wait_for_page=True)
     except Exception as e:
         errorMsg = "Failed to click_on on Admin."
         raise Exception(errorMsg, e)
Пример #15
0
    def add_ssh_key(is_negative=False):
        logger.debug("About to add an SSH Key in modal window")
        try:  # Add SSH Key from modal window and return key value.
            Wait.text_by_name(Constants.Dashboard.Wizard.AddSSHKey.Title.NAME,
                              Constants.Dashboard.Wizard.AddSSHKey.Title.TEXT)
            # Generate an SSH Public Key.
            sshKey = Helper.generate_sshpub_key()
            if is_negative:
                sshKey = sshKey[8:]
            Enter.text_by_name("key", sshKey)

            # Check that the submit button exists.
            Wait.text_by_css(
                Constants.SubmitButton.CSS,
                Constants.Dashboard.Wizard.AddSSHKey.Title.TEXT)

            Click.css(Constants.SubmitButton.CSS)  # Click on submit button.
            if is_negative:
                Wait.text_by_id(
                    Constants.Toast.ID,
                    Constants.Dashboard.Avatar.Account
                    .SSHKey.UpdateFailed.TEXT)
            else:
                Wait.name_to_dissappear(
                    Constants.Dashboard.Wizard.AddSSHKey.Title.NAME)
                logger.debug("SSH Key added via modal window.")
            return sshKey
        # If failed - count the failure and add the error to list of errors.
        except Exception as e:
            errorMsg = "Failed to add an SSH Key in " +\
                "the modal window. Exception=" + \
                str(e)
            raise Exception(errorMsg)
Пример #16
0
 def click_on_account():
     try:
         Click.link_text(Constants.Dashboard.Avatar.Account.LINK_TEXT)
         Wait.text_by_css(Constants.Dashboard.Avatar.Account.Title.CSS,
                          Constants.Dashboard.Avatar.Account.Title.TEXT)
     except Exception as e:
         errorMsg = "Failed to click_on on Admin."
         raise Exception(errorMsg, e)
Пример #17
0
 def search_by_vfname_for_not_local(user_content):
     vfFullName = user_content[
         'engagement_manual_id'] + ": " + user_content['vfName']
     if settings.DATABASE_TYPE != 'local':
         Enter.text_by_id(Constants.Dashboard.LeftPanel.SearchBox.ID,
                          user_content['vfName'])
         Click.css(Constants.Dashboard.LeftPanel.SearchBox.Results.CSS)
         Wait.text_by_id(Constants.Dashboard.Overview.Title.ID, vfFullName)
Пример #18
0
 def click_on_checklist(user_content, checklistName, checklist_uuid=None):
     FEOverview.click_on_vf(user_content)
     if checklist_uuid is None:
         checklist_uuid = DBGeneral.select_where_not_and_order_by_desc(
             'uuid', Constants.DBConstants.IceTables.CHECKLIST, 'name',
             checklistName, 'state', Constants.ChecklistStates.Archive.TEXT,
             'create_time')[0]
     Click.id("checklist-" + checklist_uuid, True)
Пример #19
0
 def go_to_user_profile_settings():
     FEUser.go_to_account()
     Click.id(Constants.Dashboard.Avatar.Account.UserProfileSettings.ID,
              wait_for_page=True)
     Wait.text_by_id(
         Constants.Dashboard.Avatar.Account.UserProfileSettings.TitleID,
         Constants.Dashboard.Avatar.Account.UserProfileSettings.TitleText,
         wait_for_page=True)
Пример #20
0
 def delete_notification(notificationID):
     if isinstance(notificationID, tuple):
         notificationID = notificationID[0]
     delete_button = Constants.Dashboard.Avatar.Notifications.\
         DeleteNotification.ID + notificationID
     # Click on delete button.
     Click.id(delete_button, wait_for_page=True)
     Wait.id_to_dissappear(delete_button)
Пример #21
0
 def click_on_disabled_save_and_assert_for_promp_msg():
     Click.id(
         Constants.Dashboard.LeftPanel.EditChecklistTemplate.SAVE_BTN_ID)
     session.run_negative(
         lambda: Click.id(Constants.Dashboard.LeftPanel.
                          EditChecklistTemplate.APPROVE_BTN_ID),
         "Ooops modal window is opened although 'Save' " +
         "button should have been disabled")
 def test_login_page_dont_have_accaunt_button(self):
     '''
         Go to login page, click_on on "Don't have an account",
         verify user is redirected to signup page.
     '''
     Click.id(Constants.Login.DontHaveAccount.ID)
     Wait.text_by_css(Constants.Signup.Title.CSS,
                      Constants.Signup.Title.TEXT)
Пример #23
0
 def go_to_checklist(engagement_id, cl_uuid):
     try:
         Click.id(engagement_id)
         Click.id("checklist-" + cl_uuid)
         Wait.id("line-item-description")
     except Exception as e:
         errorMsg = "Failed to go to checklist page."
         raise Exception(errorMsg, e)
Пример #24
0
 def open_documentation(title):
     try:
         Click.id("documentation", wait_for_page=True)
         Wait.id("search-doc")
         Wait.text_by_id(title, title, wait_for_page=True)
     except Exception as e:
         errorMsg = "Failed to go to Announcement page."
         raise Exception(errorMsg, e)
Пример #25
0
 def check_select_deselect_all_files():
     Click.id(Constants.Dashboard.Overview.NextSteps.Add.AssociatedFiles.ID)
     Click.link_text(Constants.Dashboard.Overview.NextSteps.Add.
                     AssociatedFiles.SELECT_ALL_FILES_NAME)
     Wait.text_by_id(
         Constants.Dashboard.Overview.NextSteps.Add.AssociatedFiles.ID,
         Constants.Dashboard.Overview.NextSteps.Add.AssociatedFiles.
         ALL_FILES_SELECTED)
Пример #26
0
 def update_cl_associated_files(engagement_manual_id):
     Click.id("edit-checklist", True)
     Wait.text_by_id("modal-header-checklist-15", "Update Checklist")
     # Select associated files from multi-select drop-down.
     Click.xpath("//multiselect/div/button")
     Click.link_text("file2")
     Click.xpath("//multiselect/div/button")
     Click.css(Constants.SubmitButton.CSS)
     Wait.id(engagement_manual_id, True)
Пример #27
0
 def add_lineitem_and_check_db():
     Click.id(Constants.Dashboard.LeftPanel.EditChecklistTemplate.
              FIRST_SECTION_ID)
     Enter.text_by_id(
         Constants.Dashboard.LeftPanel.EditChecklistTemplate.
         FIRST_SECTION_INPUT_ID, "Ros Is My Mentor")
     FEChecklistTemplate.click_on_save_and_assert_success_msg()
     result = DBChecklist.checkChecklistIsUpdated()
     Helper.internal_not_equal(result, None)
Пример #28
0
 def click_on_export_excel(user_content):
     Enter.text_by_id(Constants.Dashboard.Statuses.SearchBox.ID,
                      user_content['vfName'])
     engName = user_content['engagement_manual_id'] + ": " + user_content[
         'vfName']
     engSearchID = "eng-" + engName
     Wait.id(engSearchID)
     # Find the download link and click it
     Click.id(Constants.Dashboard.Statuses.ExportExcel.ID)
Пример #29
0
 def add_feedback():
     Wait.css("textarea[name=\"description\"]", wait_for_page=True)
     description = Helper.rand_string("randomString")
     Enter.text_by_css("textarea[name=\"description\"]", description)
     Click.id(Constants.Dashboard.Feedback.FeedbackModal.SAVE_BTN_ID,
              wait_for_page=True)
     Wait.text_by_id(Constants.Toast.ID,
                     "Feedback was sent successfully.",
                     wait_for_page=True)
     return description
Пример #30
0
 def statuses_search_vf(engagement_manual_id, vf_name):
     engName = engagement_manual_id + ": " + vf_name
     # Search by VF name.
     Enter.text_by_id(Constants.Dashboard.Statuses.SearchBox.ID,
                      vf_name,
                      wait_for_page=True)
     Wait.id("eng-" + engName, wait_for_page=True)
     Click.id("eng-" + engName, wait_for_page=True)
     Wait.text_by_id(Constants.Dashboard.Overview.Title.ID,
                     engName,
                     wait_for_page=True)