Source code for galaxy_test.selenium.test_history_panel

from galaxy.selenium.navigates_galaxy import edit_details
from .framework import (
    retry_assertion_during_transitions,
    selenium_test,
    SeleniumTestCase,
)

NEW_HISTORY_NAME = "New History Name"
HISTORY_PANEL_AXE_IMPACT_LEVEL = "moderate"


[docs]class TestHistoryPanel(SeleniumTestCase): ensure_registered = True
[docs] @selenium_test def test_history_panel_landing_state(self): self.assert_initial_history_panel_state_correct() editor = self.components.history_panel.editor.selector(scope=".history-index") self.components.history_panel._.assert_no_axe_violations_with_impact_of_at_least(HISTORY_PANEL_AXE_IMPACT_LEVEL) toggle = editor.toggle toggle.wait_for_visible()
[docs] @selenium_test def test_history_panel_rename(self): self.history_panel_rename(NEW_HISTORY_NAME) self.assert_name_changed()
[docs] @selenium_test def test_history_rename_cancel_with_escape(self): self.open_history_editor() editable_text_input_element = self.history_panel_name_input() editable_text_input_element.send_keys(NEW_HISTORY_NAME) self.components.history_panel._.assert_no_axe_violations_with_impact_of_at_least(HISTORY_PANEL_AXE_IMPACT_LEVEL) self.send_escape(editable_text_input_element) self.components.history_panel.name_edit_input.wait_for_absent_or_hidden() assert NEW_HISTORY_NAME not in self.history_panel_name()
[docs] @selenium_test @edit_details def test_history_tags_and_annotations_buttons(self): history_editor = self.components.history_panel.editor.selector(scope=".history-index") history_editor.annotation_input.wait_for_clickable() history_editor.tags_input.wait_for_clickable()
[docs] @selenium_test def test_history_panel_annotations_change(self): history_panel = self.components.history_panel @retry_assertion_during_transitions def assert_current_annotation(expected, error_message="History annotation", is_equal=True): text_component = history_panel.annotation_editable_text current_annotation = text_component.wait_for_visible() error_message += " given: [%s] expected [%s] " if is_equal: assert current_annotation.text == expected, error_message % (current_annotation.text, expected) else: assert current_annotation.text != expected, error_message % (current_annotation.text, expected) def set_random_annotation(clear_text=True): random_annotation = self._get_random_name(prefix="arbitrary_annotation_") self.set_history_annotation(random_annotation, clear_text) return random_annotation # assert that annotation wasn't set before history_panel.annotation_area.assert_absent_or_hidden() # assign annotation random text initial_annotation = set_random_annotation() assert_current_annotation(initial_annotation) # change annotation text changed_annotation = set_random_annotation() assert_current_annotation( initial_annotation, error_message="History annotation was not changed!", is_equal=False ) assert_current_annotation( changed_annotation, error_message="History annotation was changed, but annotation text is wrong!", is_equal=True, )
[docs] @selenium_test def test_history_panel_tags_change(self): def create_tags(size): history_panel_tags = [] for i in range(size): history_panel_tags.append(self._get_random_name(prefix="arbitrary_tag_%s_") % i) return history_panel_tags def add_tags(tags_size): tags = create_tags(tags_size) self.history_panel_add_tags(tags) return tags # check tags against list def assert_current_tags(expected_tags): current_tags = self.open_tags() errmsg = f"tags [{current_tags}] are not the same as expected [{expected_tags}]" assert [tag.text for tag in current_tags.all()] == expected_tags, errmsg # looks like this is intended to check if the tag editor is open def assert_no_tags(): tags_component = self.components.history_panel.tag_editor.selector(scope=".history-index") tags_component.display.assert_absent_or_hidden() assert_no_tags() # add new tags to empty tags area tags_size = 6 tags = add_tags(tags_size) assert_current_tags(tags) # add more tags to non-empty tags area tags += add_tags(tags_size) self.sleep_for(self.wait_types.UX_RENDER) tags.sort() assert_current_tags(tags) # delete all tags expected_tags_len = len(tags) self.clear_tags(expected_tags_len) self.sleep_for(self.wait_types.UX_RENDER) assert_no_tags()
# after about 5 tags, a toggle link shows up and you have to click it to see the full list
[docs] def open_tags(self): tags_component = self.components.history_panel.tag_editor.selector(scope=".history-index") if tags_component.tag_area.is_absent: tags_component.toggle.wait_for_and_click() tags_component.display.wait_for_visible() return tags_component.display
[docs] @edit_details def clear_tags(self, expected_tags_size): self.open_tags() tags = self.components.history_panel.tag_editor.selector(scope=".history-index") close_tag_buttons = tags.tag_close_btn.all() current_tags_size = len(close_tag_buttons) errmsg = f"there are more tags than expected! current {current_tags_size}, expected {expected_tags_size}" assert expected_tags_size == current_tags_size, errmsg for close_btn in reversed(close_tag_buttons): close_btn.click() self.sleep_for(self.wait_types.UX_RENDER)
[docs] @selenium_test def test_refresh_preserves_state(self): self.perform_upload(self.get_filename("1.txt")) self.wait_for_history() # Open the details, verify they are open and do a refresh. self.history_panel_ensure_showing_item_details(hid=1) self.history_panel_item_body_component(1, wait=True) self._refresh() self.wait_for_history() # After the refresh, verify the details are still open. self.sleep_for(self.wait_types.UX_TRANSITION) self.wait_for_selector_clickable(self.history_panel_item_selector(hid=1)) assert self.history_panel_item_showing_details(hid=1) # Close the detailed display, refresh, and ensure they are still closed. self.history_panel_click_item_title(hid=1, wait=False) assert not self.history_panel_item_showing_details(hid=1) self._refresh() self.sleep_for(self.wait_types.UX_TRANSITION) self.wait_for_selector_clickable(self.history_panel_item_selector(hid=1)) assert not self.history_panel_item_showing_details(hid=1)
[docs] @retry_assertion_during_transitions def assert_name_changed(self): name = self.history_panel_name() assert name == NEW_HISTORY_NAME
def _refresh(self): self.home()