Beispiel #1
0
 def authenticated_user_view_unpublished_module(self):
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     utilities.page_reload(self.driver)
     # search_page.search_for_module_and_click(self.driver, constants.unpublished_module)
     search_beta_page.select_repo(self.driver, fixture.repo_name)
     search_beta_page.search_module_and_click(self.driver,
                                              constants.unpublished_module)
     check_that(
         "Button",
         utilities.get_text(self.driver, By.ID,
                            locators.MODULE_DISPLAY_PUBLISH_BUTTON_ID),
         contains_string("Publish"))
     check_that(
         "Button",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.MODULE_DISPLAY_PREVIEW_BUTTON_CSS),
         contains_string("Preview"))
     check_that(
         "First Published date",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.MODULE_DISPLAY_FIRST_PUBLISHED_CSS),
         contains_string("--"))
     check_that(
         "Last Published date",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.MODULE_DISPLAY_LAST_PUBLISHED_CSS),
         contains_string("--"))
     check_that(
         "Module display page title",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.MODULE_DISPLAY_TITLE_CSS),
         contains_string(constants.unpublished_module))
Beispiel #2
0
 def edit_metadata_successfully(self):
     display_module_page.reset_edit_metadata_from(self.driver)
     display_module_page.fill_edit_metadata_form(self.driver, constants.product_name, constants.product_version,
                                                 constants.use_case, constants.url_fragment)
     check_that("Success message displayed",
                utilities.get_text(self.driver, By.CSS_SELECTOR, locators.UPDATE_SUCCESS_MESSAGE_CSS),
                contains_string(constants.success_message))
     check_that("Product name reflected on displayed module page",
                utilities.get_text(self.driver, By.CSS_SELECTOR, locators.PRODUCT_INFO_CSS),
                contains_string(constants.product_name))
     check_that("Product version reflected on displayed module page",
                utilities.get_text(self.driver, By.CSS_SELECTOR, locators.PRODUCT_INFO_CSS),
                contains_string(constants.product_version))
 def publish_assembly(self):
     utilities.wait(5)
     utilities.click_element(self.driver, By.ID,
                             locators.MODULE_DISPLAY_PUBLISH_BUTTON_ID)
     check_that(
         "Button",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.MODULE_DISPLAY_PREVIEW_BUTTON_CSS),
         contains_string("Preview"))
     check_that(
         "Button",
         utilities.get_text(self.driver, By.ID,
                            locators.MODULE_DISPLAY_UNPUBLISH_BUTTON_ID),
         contains_string("Unpublish"))
 def modules_bulk_unpublish(self):
     poll(lambda: len(
         utilities.find_elements_by_css_selector(self.driver, locators.
                                                 MODULES_LIST_CSS)) == 4,
          ignore_exceptions=[NoSuchElementException],
          timeout=5,
          step=0.5)
     utilities.wait(3)
     utilities.click_element(self.driver, By.XPATH,
                             locators.MODULES_SELECT_ALL_TITLE_XPATH)
     utilities.wait(3)
     # Deselect first title
     utilities.click_element(self.driver, By.XPATH,
                             locators.FIRST_MODULE_CHECKBOX_XPATH)
     utilities.wait(2)
     bulk_unpublish = utilities.find_element(self.driver, By.CSS_SELECTOR,
                                             locators.BULK_UNPUBLISH_CSS)
     bulk_unpublish.click()
     check_that(
         "Confirmation modal title",
         utilities.get_text(self.driver,
                            By.CSS_SELECTOR, locators.MODAL_TITLE_CSS),
         equal_to("Unpublish"))
     check_that(
         "Count of modules being unpublished",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.TITLES_FOR_UNPUBLISH_CSS),
         contains_string("3"))
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.CONFIRM_BUTTON_CSS)
     poll(lambda: utilities.get_text(self.driver, By.CSS_SELECTOR, locators.
                                     PROGRESS_SUCCESS_STATUS) == "100%",
          ignore_exceptions=[NoSuchElementException],
          timeout=20,
          step=1)
     utilities.click_element(self.driver, By.XPATH,
                             locators.VIEW_DETAILS_LINK)
     modules_updated = utilities.find_elements_by_css_selector(
         self.driver, locators.UPDATED_TITLES_LIST_CSS)
     check_that("Count of successfully updated modules",
                len(modules_updated), equal_to(3))
     check_that(
         "Failed modules section text",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.FAILED_TITLES_LIST_CSS),
         equal_to("n/a"))
     utilities.click_element(self.driver, By.XPATH,
                             locators.CLOSE_DETAILS_XPATH)
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.CLOSE_STATUS_ALERT)
 def create_product_blank_name(self):
     utilities.click_element(self.driver, By.XPATH, locators.MENU_PRODUCTS_LINK_XPATH)
     utilities.click_element(self.driver, By.LINK_TEXT, locators.MENU_NEW_PRODUCT_LINK_TEXT)
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.SAVE_PRODUCT_BUTTON_CSS)
     check_that("Warning is displayed", utilities.get_text(self.driver, By.CSS_SELECTOR, locators.WARNING_ALERT_CSS),
                contains_string(constants.blank_product_name_warning))
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.CLOSE_WARNING_ALERT_CSS)
 def no_repo_selected(self):
     utilities.wait(2)
     utilities.click_element(self.driver, By.LINK_TEXT,
                             locators.MENU_SEARCH_PAGE_LINK_TEXT)
     utilities.page_reload(self.driver)
     utilities.wait(1)
     # clicking on filter funnel icon twice to close and re-open the filter by repo pannel
     utilities.click_element(self.driver, By.ID, locators.TOGGLE_ID)
     utilities.wait(1)
     utilities.click_element(self.driver, By.ID, locators.TOGGLE_ID)
     utilities.wait(1)
     check_that(
         "Filter by repo section is displayed",
         utilities.find_element(
             self.driver, By.CLASS_NAME,
             locators.FILTER_BY_REPO_SECTION_CLASS_NAME).is_displayed(),
         is_true())
     check_that(
         "No results found warning message",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.NO_MODULE_RESULTS_FOUND_CSS),
         contains_string(constants.no_results_found))
     utilities.click_element(self.driver, By.XPATH,
                             locators.FILTER_BY_REPO_TOGGLE_XPATH)
     utilities.wait(1)
     utilities.click_element(self.driver, By.XPATH,
                             locators.FILTER_BY_REPO_TOGGLE_XPATH)
     utilities.wait(1)
     check_that(
         "Repository list is displayed after expanding Filter by Repo",
         utilities.find_element(self.driver, By.XPATH,
                                locators.REPO_LIST_XPATH).is_displayed(),
         is_true())
 def select_product_and_version_filter(self):
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     utilities.wait(2)
     utilities.select_value_from_dropdown(self.driver, By.CSS_SELECTOR,
                                          locators.SELECT_PRODUCT_NAME_CSS,
                                          constants.product_name)
     utilities.select_value_from_dropdown(
         self.driver, By.CSS_SELECTOR, locators.SELECT_PRODUCT_VERSION_CSS,
         constants.product_version)
     lcc.log_info(
         "product and version selected and displayed on search page")
     utilities.find_element(
         self.driver, By.XPATH,
         locators.PRODUCT_FILTER_DISPLAY_XPATH).is_displayed()
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.SEARCH_BUTTON_CSS)
     utilities.wait(2)
     utilities.click_element(self.driver, By.XPATH,
                             locators.SEARCH_MODULE_XPATH)
     utilities.wait(2)
     check_that(
         "verify that 'filter by product and version' functionality filters results correctly",
         utilities.get_text(self.driver, By.XPATH,
                            locators.PRODUCT_VERSION_DISPLAY_PAGE_XPATH),
         contains_string(constants.product_name + " " +
                         constants.product_version))
Beispiel #8
0
 def edit_metadata_empty_usecase(self):
     display_module_page.reset_edit_metadata_from(self.driver)
     display_module_page.fill_edit_metadata_form(self.driver, constants.product_name, constants.product_version,
                                                 constants.default_use_case, constants.url_fragment)
     check_that("Warning displayed", utilities.get_text(self.driver, By.CSS_SELECTOR, locators.WARNING_ALERT_CSS),
                contains_string(constants.edit_metadata_modal_warning))
     utilities.wait(2)
def verify_module_type_after_publishing(driver, module_type):
    lcc.log_info("Verifying if module type persists after publishing")
    display_module_page.add_metadata_and_publish(driver)
    module_type_on_display_page_again = utilities.get_text(
        driver, By.CSS_SELECTOR, locators.VIEW_MODULE_TYPE_CSS)
    check_that("Module type displayed on UI after publishing",
               module_type_on_display_page_again.upper(),
               equal_to(module_type.upper()))
 def invalid_product_version_url_fragment(self):
     #Verify invalid input for url fragment
     utilities.enter_text(self.driver, By.ID, locators.NEW_PRODUCT_VERSION_TEXTBOX_ID, constants.product_version_1)
     utilities.enter_text(self.driver, By.ID, locators.VERSION_URL_FRAGMENT_ID, "#")
     check_that("Warning is displayed", utilities.get_text(self.driver, By.CSS_SELECTOR, locators.WARNING_ALERT_CSS),
                contains_string(constants.version_url_fragment_warning))
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.CLOSE_WARNING_ALERT_CSS)
     utilities.find_element(self.driver, By.ID, locators.NEW_PRODUCT_VERSION_TEXTBOX_ID).clear()
Beispiel #11
0
 def edit_metadata_blank_data(self):
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     utilities.page_reload(self.driver)
     # # Click on the title if it is displayed on the first page
     utilities.wait(5)
     # search_page.search_for_module_and_click(self.driver, constants.module_to_be_published)
     search_beta_page.select_repo(self.driver, fixture.repo_name)
     search_beta_page.search_module_and_click(self.driver, constants.module_to_be_published)
     self.driver.refresh()
     utilities.click_element(self.driver, By.XPATH, locators.ADD_METADATA_BUTTON_XPATH)
     check_that("Edit metadata modal title",
                utilities.get_text(self.driver, By.CSS_SELECTOR, locators.EDIT_METADATA_MODAL_TITLE_CSS),
                contains_string(constants.edit_metadata_modal_title))
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.EDIT_METADATA_SAVE_CSS)
     check_that("Warning displayed", utilities.get_text(self.driver, By.CSS_SELECTOR, locators.WARNING_ALERT_CSS),
                contains_string(constants.edit_metadata_modal_warning))
     utilities.wait(2)
Beispiel #12
0
 def authenticated_user_view_published_module(self):
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     # search_page.search_for_module_and_click(self.driver, constants.published_module)
     search_beta_page.select_repo(self.driver, fixture.repo_name)
     search_beta_page.search_module_and_click(self.driver,
                                              constants.published_module)
     # utilities.find_element(self.driver, By.ID, locators.MODULE_DISPLAY_PUBLISH_BUTTON_ID)
     check_that(
         "Button",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.MODULE_DISPLAY_PREVIEW_BUTTON_CSS),
         contains_string("Preview"))
     check_that(
         "Button",
         utilities.get_text(self.driver, By.ID,
                            locators.MODULE_DISPLAY_UNPUBLISH_BUTTON_ID),
         contains_string("Unpublish"))
 def git_import_for_empty_git_repo(self):
     utilities.click_element(self.driver, By.LINK_TEXT,
                             locators.MENU_GIT_IMPORT_LINK_TEXT)
     git_import_page.import_git_repo(self.driver, None, None)
     check_that(
         "Empty git repo url warning message",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.WARNING_ALERT_CSS),
         contains_string(constants.repo_url_empty_warning_message))
def verify_module_type_from_UI(driver, module_type):
    module_type_on_display_page = utilities.get_text(
        driver, By.CSS_SELECTOR, locators.VIEW_MODULE_TYPE_CSS)
    lcc.log_info(
        "Verifying that the module type is displayed on the UI as: %s " %
        module_type)
    check_that("Module type displayed on UI ",
               module_type_on_display_page.upper(),
               equal_to(module_type.upper()))
def add_metadata_and_publish(driver):
    # f = fixture()
    # lcc.log_info("Added following product information to the module::\nProduct name:" + f.product_name +"\nProduct version:"+constants.product_version+"\nUse case:"+constants.use_case)
    string = driver.current_url
    str = string.split("?")
    lcc.log_info(str[0])
    if "module" in str[0]:
        path = (str[0].replace("pantheon/#/module", "content"))
    elif "assembly" in str[0]:
        path = (str[0].replace("pantheon/#/assembly", "content"))
    else:
        lcc.log_info("Invalid url!!!")
    var = str[1].split("=")
    metadata_path = path + "/en_US/variants/" + var[1] + "/draft/metadata"
    product_uuid = fixture.get_product_id()
    body = {
        "productVersion": product_uuid,
        "documentUsecase": "Deploy",
        "urlFragment": "",
        "searchKeywords": ""
    }
    # Add metadata from api
    add_metadata = requests.post(url=metadata_path,
                                 data=body,
                                 auth=(username, api_auth))
    lcc.log_info("Added metadata to::")
    lcc.log_info(path)
    utilities.wait(2)
    # print(add_metadata.content)
    utilities.page_reload(driver)

    # utilities.click_element(driver, By.XPATH, locators.ADD_METADATA_BUTTON_XPATH)
    # fill_edit_metadata_form(driver, constants.product_name, constants.product_version,
    #                                             constants.use_case, constants.url_fragment)
    body = {":operation": "pant:publish", "locale": "en_US", "variant": var[1]}
    publish = requests.post(url=path, data=body, auth=(username, api_auth))
    lcc.log_info(publish.text)
    lcc.log_info("Published document::")
    lcc.log_info(path)
    # utilities.click_element(driver, By.ID, locators.MODULE_DISPLAY_PUBLISH_BUTTON_ID)
    # utilities.wait(10)
    utilities.wait(2)
    # print(publish.content)
    utilities.page_reload(driver)
    utilities.wait(3)
    assert_that(
        "Button contains text",
        utilities.get_text(driver, By.ID,
                           locators.MODULE_DISPLAY_UNPUBLISH_BUTTON_ID),
        contains_string("Unpublish"))
    utilities.wait(5)
 def search_for_module(self):
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     utilities.page_reload(self.driver)
     utilities.wait(2)
     utilities.enter_text(self.driver, By.ID, locators.SEARCH_BOX_ID,
                          constants.module_to_search)
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.SEARCH_BUTTON_CSS)
     utilities.wait(3)
     check_that(
         "module is found on search page",
         utilities.get_text(self.driver, By.XPATH,
                            locators.SEARCH_MODULE_XPATH),
         contains_string(constants.module_to_search))
 def git_import_for_invalid_git_repo_url(self):
     git_import_page.import_git_repo(self.driver,
                                     constants.invalid_git_repo_url,
                                     git_import_repo_branch)
     text = utilities.get_text(self.driver, By.CSS_SELECTOR,
                               locators.GIT_IMPORT_ALERT_CSS)
     print(text)
     check_that("Invalid git repo url error alert", text,
                contains_string(constants.failure_alert_message))
     check_that("Invalid git repo url files count", text,
                contains_string(constants.failure_alert_files_uploaded))
     utilities.verify_and_accept_confirmation_modal(
         self.driver, locators.GIT_IMPORT_REQUEST_SUBMITTED_TITLE,
         constants.git_import_submitted_modal_title,
         locators.GIT_IMPORT_REQUEST_SUBMITTED_NO)
 def add_metadata(self):
     utilities.wait(5)
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     utilities.page_reload(self.driver)
     # search_page.search_for_module_and_click(self.driver, constants.assembly_to_be_published)
     search_beta_page.select_repo(self.driver, fixture.repo_name)
     search_beta_page.search_module_and_click(
         self.driver, constants.assembly_to_be_published)
     utilities.click_element(self.driver, By.XPATH,
                             locators.ADD_METADATA_BUTTON_XPATH)
     check_that(
         "Edit metadata modal title",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.EDIT_METADATA_MODAL_TITLE_CSS),
         contains_string(constants.edit_metadata_modal_title))
     display_module_page.fill_edit_metadata_form(self.driver,
                                                 constants.product_name,
                                                 constants.product_version,
                                                 constants.use_case,
                                                 constants.url_fragment)
     check_that(
         "Success message displayed",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.UPDATE_SUCCESS_MESSAGE_CSS),
         contains_string(constants.success_message))
     check_that(
         "Product name reflected on displayed module page",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.PRODUCT_INFO_CSS),
         contains_string(constants.product_name))
     check_that(
         "Product version reflected on displayed module page",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.PRODUCT_INFO_CSS),
         contains_string(constants.product_version))
     utilities.wait(2)
 def search_for_random_text(self):
     utilities.find_elements_by_id(self.driver,
                                   locators.SEARCH_BOX_ID).clear()
     utilities.enter_text(self.driver, By.ID, locators.SEARCH_BOX_ID,
                          constants.random_string_search)
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.SEARCH_BUTTON_CSS)
     utilities.wait(2)
     check_that(
         "warning alert displayed",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.ALERT_TITLE_CSS),
         contains_string(constants.no_module_found))
     utilities.click_element(self.driver, By.XPATH,
                             locators.CANCEL_BUTTON_XPATH)
     utilities.wait(2)
 def create_product_blank_version(self):
     # utilities.click_element(self.driver, By.LINK_TEXT, locators.MENU_NEW_PRODUCT_LINK_TEXT)
     lcc.log_info("Product name input: %s " % product_name)
     # Reload new product to clear old values
     utilities.page_reload(self.driver)
     utilities.wait(3)
     # Fill new product form
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_NAME_TEXTBOX_ID, product_name)
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_URL_FRAGMENT_TEXTBOX_ID, constants.url_fragment)
     utilities.find_element(self.driver, By.ID, locators.NEW_PRODUCT_VERSION_TEXTBOX_ID).clear()
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_VERSION_URL_FRAGMENT_ID, constants.product_version)
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_DESCRIPTION_TEXTBOX_ID, constants.new_product_description)
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.SAVE_PRODUCT_BUTTON_CSS)
     check_that("Warning is displayed", utilities.get_text(self.driver, By.CSS_SELECTOR, locators.WARNING_ALERT_CSS),
                contains_string(constants.blank_product_name_warning))
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.CLOSE_WARNING_ALERT_CSS)
    def select_repo_filter(self):
        search_beta_page.select_repo(self.driver, self.repo_name)
        utilities.wait(1)
        utilities.find_element(self.driver, By.CSS_SELECTOR,
                               locators.REPOSITORY_CHECKBOX_CSS).is_selected()
        check_that(
            "Repository name displayed correctly on right side panel",
            utilities.get_text(self.driver, By.XPATH,
                               locators.REPOSITORY_NAME_XPATH),
            equal_to(self.repo_name))
        check_that(
            "Modules section has data displayed for selected repo",
            utilities.find_element(self.driver, By.CSS_SELECTOR,
                                   locators.MODULES_CSS).is_displayed(),
            is_true())
        check_that(
            "Assemblies section has data displayed for selected repo",
            utilities.find_element(self.driver, By.CSS_SELECTOR,
                                   locators.ASSEMBLY_CSS).is_displayed(),
            is_true())

        utilities.click_element(self.driver, By.XPATH,
                                locators.MODULES_TOGGLE_BUTTON_XPATH)
        utilities.wait(1)
        check_that(
            "Modules section is collapsible",
            utilities.find_element(
                self.driver, By.XPATH,
                locators.MODULE_ASSEMBLY_TOGGLE_XPATH).is_displayed(),
            is_true())
        utilities.click_element(self.driver, By.XPATH,
                                locators.MODULES_TOGGLE_BUTTON_XPATH)
        utilities.wait(1)
        utilities.click_element(self.driver, By.XPATH,
                                locators.ASSEMBLY_TOGGLE_BUTTON_XPATH)
        utilities.wait(1)
        check_that(
            "Assemblies section is collapsible",
            utilities.find_element(
                self.driver, By.XPATH,
                locators.MODULE_ASSEMBLY_TOGGLE_XPATH).is_displayed(),
            is_true())
        utilities.wait(1)
        utilities.click_element(self.driver, By.XPATH,
                                locators.ASSEMBLY_TOGGLE_BUTTON_XPATH)
 def search_for_module_with_asian_chars(self):
     utilities.find_elements_by_id(self.driver,
                                   locators.SEARCH_BOX_ID).clear()
     utilities.enter_text(self.driver, By.ID, locators.SEARCH_BOX_ID,
                          constants.asian_char_module)
     # module will be searchable once CCS-3754 is fixed
     # verifying warning alert as of now
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.SEARCH_BUTTON_CSS)
     utilities.wait(2)
     check_that(
         "module with asian character should be found once CCS-3754 is fixed, checking for warning alert as of now..",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.ALERT_TITLE_CSS),
         contains_string(constants.no_module_found))
     utilities.click_element(self.driver, By.XPATH,
                             locators.CANCEL_BUTTON_XPATH)
     utilities.wait(2)
 def published_title_add_metadata(self):
     utilities.click_element(self.driver, By.XPATH,
                             locators.FIRST_MODULE_CHECKBOX_XPATH)
     utilities.wait(2)
     bulk_edit_metadata = utilities.find_element(
         self.driver, By.XPATH, locators.BULK_EDIT_METADATA_XPATH)
     bulk_edit_metadata.click()
     utilities.wait(2)
     search_beta_page.add_bulk_metadata(self.driver)
     utilities.wait(2)
     check_that(
         "Alert message displayed when trying to add metadata to published title",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.ALERT_TITLE_CSS),
         equal_to(constants.error_message_on_edit_metadata))
     utilities.click_element(self.driver, By.XPATH,
                             locators.CLOSE_DETAILS_XPATH)
     utilities.wait(15)
     lcc.log_info("End of tests, executing teardown")
 def duplicate_product_name(self):
     # Navigate to New product page from Product listing page
     utilities.click_element(self.driver, By.XPATH, locators.MENU_PRODUCTS_LINK_XPATH)
     utilities.click_element(self.driver, By.LINK_TEXT, locators.MENU_NEW_PRODUCT_LINK_TEXT)
     lcc.log_info("Product name input: %s " % product_name)
     # Reload new product page to clear old values
     utilities.page_reload(self.driver)
     # Fill new product form
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_NAME_TEXTBOX_ID, product_name)
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_URL_FRAGMENT_TEXTBOX_ID, constants.url_fragment)
     utilities.enter_text(self.driver, By.ID, locators.NEW_PRODUCT_VERSION_TEXTBOX_ID, constants.product_version)
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_VERSION_URL_FRAGMENT_ID, constants.product_version)
     utilities.enter_text(self.driver, By.ID, locators.PRODUCT_DESCRIPTION_TEXTBOX_ID,
                          constants.new_product_description)
     utilities.enter_text(self.driver, By.ID, locators.NEW_PRODUCT_VERSION_TEXTBOX_ID, constants.product_version)
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.SAVE_PRODUCT_BUTTON_CSS)
     check_that("Duplicate Product warning is displayed",
                utilities.get_text(self.driver, By.CSS_SELECTOR, locators.WARNING_ALERT_CSS),
                contains_string(constants.duplicate_product_name_warning))
     utilities.click_element(self.driver, By.CSS_SELECTOR, locators.CLOSE_WARNING_ALERT_CSS)
Beispiel #25
0
 def no_product_info_publish_module(self):
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     utilities.page_reload(self.driver)
     # # Click on the title if it is displayed on the first page
     utilities.wait(5)
     # search_page.search_for_module_and_click(self.driver, constants.unpublished_module)
     search_beta_page.select_repo(self.driver, fixture.repo_name)
     search_beta_page.search_module_and_click(self.driver,
                                              constants.unpublished_module)
     utilities.wait(5)
     tooltip_icon = utilities.find_element(self.driver, By.CSS_SELECTOR,
                                           locators.NO_URL_TOOLTIP_ICON)
     check_that("No url tooltip icon is displayed",
                tooltip_icon.is_displayed(), is_true())
     utilities.click_element(self.driver, By.ID,
                             locators.MODULE_DISPLAY_PUBLISH_BUTTON_ID)
     check_that(
         "Button contains text",
         utilities.get_text(self.driver, By.ID,
                            locators.MODULE_DISPLAY_PUBLISH_BUTTON_ID),
         contains_string("Publish"))
    def blank_product_versions(self):
        utilities.click_element(self.driver, By.XPATH, locators.MENU_PRODUCTS_LINK_XPATH)
        utilities.click_element(self.driver, By.LINK_TEXT, locators.MENU_PRODUCT_LISTING_LINK_TEXT)
        # User clicks on 'Product details' button for the product created above.
        lcc.log_info("Product name to add versions for: %s " % product_name)
        utilities.wait(10)
        products = utilities.find_elements_by_class_name(self.driver, locators.PRODUCT_NAMES_LIST_CLASS_NAME)
        lcc.log_info("Number of products found in the list %s" % str(len(products)))
        for product in products:
            if product_name in product.text:
                lcc.log_info("Adding versions to %s" % product.text)
                product.find_element_by_class_name("pf-c-options-menu").click()
                lcc.log_info("Clicking on the dropdown to add product details")
                product.find_element_by_class_name(locators.PRODUCT_DETAILS_BUTTON_CLASS_NAME).click()
                break

        #Verify blank product version and url fragment
        utilities.find_element(self.driver, By.ID, locators.NEW_PRODUCT_VERSION_TEXTBOX_ID).clear()
        utilities.find_element(self.driver, By.ID, locators.VERSION_URL_FRAGMENT_ID).clear()
        utilities.click_element(self.driver, By.CSS_SELECTOR, locators.PRODUCT_VERSION_SAVE_BUTTON_CSS)
        check_that("Warning is displayed", utilities.get_text(self.driver, By.CSS_SELECTOR, locators.WARNING_ALERT_CSS),
                   contains_string(constants.blank_product_name_warning))
        utilities.click_element(self.driver, By.CSS_SELECTOR, locators.CLOSE_WARNING_ALERT_CSS)
Beispiel #27
0
    def publish_module(self):
        utilities.click_element(self.driver, By.LINK_TEXT, "Search")
        utilities.page_reload(self.driver)
        # search_page.search_for_module_and_click(self.driver, constants.module_to_be_published)
        search_beta_page.select_repo(self.driver, fixture.repo_name)
        search_beta_page.search_module_and_click(
            self.driver, constants.module_to_be_published)
        utilities.wait(10)

        pre_live_url = utilities.find_element(self.driver, By.LINK_TEXT,
                                              "Pre-live Customer Portal URL")
        print(pre_live_url.get_attribute('href'))
        check_that("Pre-live URL link is displayed",
                   pre_live_url.is_displayed(), is_true())
        copy_pre_live_url = utilities.find_element(self.driver, By.LINK_TEXT,
                                                   "Copy pre-live URL")
        check_that("Copy Pre-live URL is displayed",
                   copy_pre_live_url.is_displayed(), is_true())

        utilities.click_element(self.driver, By.ID,
                                locators.MODULE_DISPLAY_PUBLISH_BUTTON_ID)
        utilities.wait(20)
        print("Clicked publish")
        # The page needs a refresh because of an existing bug about the "View on Customer Portal not appearing"
        self.driver.refresh()
        utilities.find_element(self.driver, By.PARTIAL_LINK_TEXT,
                               "View on Customer Portal")
        check_that(
            "Button contains text",
            utilities.get_text(self.driver, By.ID,
                               locators.MODULE_DISPLAY_UNPUBLISH_BUTTON_ID),
            contains_string("Unpublish"))
        check_that(
            "Button contains text",
            utilities.get_text(self.driver, By.CSS_SELECTOR,
                               locators.MODULE_DISPLAY_PREVIEW_BUTTON_CSS),
            contains_string("Preview"))
        check_that(
            "Copy permanent url link is displayed",
            utilities.get_text(self.driver, By.CSS_SELECTOR,
                               locators.COPY_URL_LINK_CSS),
            contains_string(constants.copy_url_link))
        check_that(
            "View on portal link is displayed",
            utilities.get_text(self.driver, By.CSS_SELECTOR,
                               locators.VIEW_ON_PORTAL_LINK_CSS),
            contains_string(constants.view_on_portal_link))

        # get UPLOADED date in variable and covert into desired format- (DD Month YYYY)
        self.first_pub_date_details_page = (utilities.get_text(
            self.driver, By.CSS_SELECTOR,
            locators.FIRST_PUB_DATE_MODULE_PAGE_CSS))
        lcc.log_info("captured 1st published date from module info page : " +
                     self.first_pub_date_details_page)

        # get published date in variable and convert into desired format-(DD Month YYYY)
        self.last_pub_date_details_page = (utilities.get_text(
            self.driver, By.CSS_SELECTOR,
            locators.LAST_PUB_DATE_MODULE_PAGE_CSS))
        lcc.log_info("captured last published date from module info page : " +
                     test_publish_module.last_pub_date_details_page)

        # adding checks if the module is displayed on the UI
        utilities.click_element(self.driver, By.CSS_SELECTOR,
                                locators.VIEW_ON_PORTAL_LINK_CSS)
        utilities.wait(5)
        try:
            utilities.switch_to_latest_tab(self.driver)
            utilities.wait(10)
            check_that("View on Portal URL path", self.driver.current_url,
                       contains_string(constants.view_on_portal_page_url))
        except (TimeoutException, StaleElementReferenceException,
                NoSuchElementException) as e:
            lcc.log_error("Element could not be located!!!")
            lcc.log_error(e)
        finally:
            if (len(self.driver.window_handles) > 1):
                self.driver.close()
                utilities.switch_to_first_tab(self.driver)
    def git_import_for_sample_repo(self):
        git_import_page.import_git_repo(self.driver, git_import_repo_URL,
                                        git_import_repo_branch)
        utilities.verify_and_accept_confirmation_modal(
            self.driver, locators.GIT_IMPORT_REQUEST_SUBMITTED_TITLE,
            constants.git_import_submitted_modal_title,
            locators.GIT_IMPORT_REQUEST_SUBMITTED_YES)
        utilities.wait(20)
        # utilities.click_element(self.driver, By.LINK_TEXT, "Search")
        poll(lambda: utilities.find_element(
            self.driver, By.CSS_SELECTOR, locators.GIT_IMPORT_SUCCESS_ALERT_CSS
        ).is_displayed(),
             step=1,
             timeout=150)
        # screenshot_filename = "git_import" + utilities.generate_random_string(3) + ".png"
        # self.driver.save_screenshot(screenshot_filename)
        # lcc.save_attachment_file(screenshot_filename)
        text = utilities.get_text(self.driver, By.CSS_SELECTOR,
                                  locators.GIT_IMPORT_SUCCESS_ALERT_CSS)
        print(text)
        check_that("Git import successful alert", text,
                   contains_string(constants.success_alert_message))
        check_that(
            "Git import successfully uploaded files count", text,
            contains_string(constants.success_alert_files_uploaded +
                            number_of_files_imported))
        utilities.page_reload(self.driver)
        repo_list = utilities.find_elements_by_css_selector(
            self.driver, locators.LIST_OF_REPOS_CSS)
        name = []
        for i in repo_list:
            name.append(i.text)

        check_that("Git import repo is listed on search page", name,
                   has_item(git_import_repo_Name))

        # utilities.page_reload(self.driver)
        search_url = fixture.url + 'pantheon/internal/modules.json?repo=' + fixture.git_import_repo \
                     + '&search=' + module_title_prefix + '&key=Updated&direction=desc'

        lcc.log_info("Git import functionality verified using endpoint: %s" %
                     search_url)
        lcc.log_info(
            "Trying to poll the endpoint until we get the required number of search results as"
            " per the test data ...")
        req = requests.get(search_url)
        print(req.content)
        # poll(lambda: requests.get(search_url).json()["size"] == 9, step=5, timeout=120)

        imported_modules_request = requests.get(search_url)
        imported_modules = imported_modules_request.json()
        lcc.log_info(str(imported_modules))
        total_modules = imported_modules["size"]

        lcc.log_info(
            "Number of modules listed with the similar title name: %s" %
            str(total_modules))
        lcc.log_info(
            "Capturing the number of modules uploaded from the repo: %s ..." %
            git_import_repo_Name)
        results = imported_modules["results"]
        imported_modules_array = []
        for result in results:
            if result["pant:transientSourceName"] == git_import_repo_Name:
                imported_modules_array.append(result["jcr:title"])
        lcc.log_info(
            "Modules imported successfully via git import: %s with title prefix"
            % str(imported_modules_array))
        lcc.log_info(
            "Number of modules imported successfully from repo: %s is %s" %
            (git_import_repo_URL, str(len(imported_modules_array))))
        check_that("Count of modules uploaded using git import",
                   len(imported_modules_array),
                   equal_to(int(number_of_modules)))
Beispiel #29
0
def get_logged_in_username(driver):
    logged_in_user = utilities.get_text(driver, By.PARTIAL_LINK_TEXT, username)
    return logged_in_user
 def filters_on_search_page(self):
     utilities.click_element(self.driver, By.CLASS_NAME,
                             locators.STATUS_FILTER_CLASS_NAME)
     utilities.click_element(self.driver, By.CLASS_NAME,
                             locators.DRAFT_STATUS_CLASS_NAME)
     check_that(
         "Draft Status filter chip is displayed on search page",
         utilities.find_element(
             self.driver, By.CLASS_NAME,
             locators.STATUS_TOOLBAR_CHIP_CLASS_NAME).is_displayed(),
         is_true())
     last_published_date_list = utilities.find_elements_by_XPATH(
         self.driver, locators.LAST_PUBLISHED_DATE_XPATH)
     published_date_list = []
     for i in last_published_date_list:
         published_date_list.append(i.text)
     for i in published_date_list:
         check_that(
             "Published date for all titles should be '-' when draft status filter is selected",
             i, contains_string("-"))
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.CLEAR_ALL_FILTER_CSS)
     utilities.wait(1)
     search_beta_page.search_module_and_click(self.driver,
                                              constants.publish_module)
     utilities.wait(1)
     display_module_page.add_metadata_and_publish(self.driver)
     utilities.wait(2)
     utilities.click_element(self.driver, By.LINK_TEXT, "Search")
     search_beta_page.select_repo(self.driver, self.repo_name)
     utilities.wait(2)
     utilities.click_element(self.driver, By.CLASS_NAME,
                             locators.STATUS_FILTER_CLASS_NAME)
     utilities.click_element(self.driver, By.CLASS_NAME,
                             locators.PUBLISHED_STATUS_CLASS_NAME)
     utilities.wait(2)
     check_that(
         "Published module is filtered",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.FIRST_MODULE_LISTED_CSS),
         contains_string(constants.publish_module))
     check_that(
         "Green check is displayed for published module",
         utilities.find_element(
             self.driver, By.CLASS_NAME,
             locators.GREEN_CHECK_CLASS_NAME).is_displayed(), is_true())
     utilities.wait(3)
     utilities.click_element(self.driver, By.CSS_SELECTOR,
                             locators.CLEAR_ALL_FILTER_CSS)
     utilities.wait(1)
     utilities.click_element(self.driver, By.CLASS_NAME,
                             locators.CONTENT_TYPE_CLASS_NAME)
     utilities.click_element(
         self.driver, By.CLASS_NAME,
         locators.CONCEPT_CONTENT_TYPE_FILTER_CLASS_NAME)
     check_that(
         "Content Type filter chip is displayed on search page",
         utilities.find_element(
             self.driver, By.CLASS_NAME,
             locators.STATUS_TOOLBAR_CHIP_CLASS_NAME).is_displayed(),
         is_true())
     utilities.wait(3)
     check_that(
         "'Concept' content type filter is selected",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.FIRST_MODULE_LISTED_CSS),
         contains_string("Concept"))
     utilities.wait(1)
     utilities.click_element(
         self.driver, By.CLASS_NAME,
         locators.CONCEPT_CONTENT_TYPE_FILTER_CLASS_NAME)
     utilities.click_element(
         self.driver, By.CLASS_NAME,
         locators.PROCEDURE_CONTENT_TYPE_FILTER_CLASS_NAME)
     utilities.wait(3)
     check_that(
         "'Procedure' content type filter is selected",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.FIRST_MODULE_LISTED_CSS),
         contains_string("Procedure"))
     utilities.wait(1)
     utilities.click_element(
         self.driver, By.CLASS_NAME,
         locators.PROCEDURE_CONTENT_TYPE_FILTER_CLASS_NAME)
     utilities.click_element(
         self.driver, By.CLASS_NAME,
         locators.REFERENCE_CONTENT_TYPE_FILTER_CLASS_NAME)
     utilities.wait(3)
     check_that(
         "'Reference' content type filter is selected",
         utilities.get_text(self.driver, By.CSS_SELECTOR,
                            locators.FIRST_MODULE_LISTED_CSS),
         contains_string("Reference"))
     utilities.wait(2)