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))
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))
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()
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)
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)
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)
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)))
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)