From b41f0c8057f76eac68cc50993bdff51df45117dd Mon Sep 17 00:00:00 2001 From: MariaAga Date: Mon, 11 Nov 2024 13:09:00 +0000 Subject: [PATCH] Fixes #38001 - Basic test for table sortings --- test/integration_test_helper.rb | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/test/integration_test_helper.rb b/test/integration_test_helper.rb index 33011320219..bb0c94ced8d 100644 --- a/test/integration_test_helper.rb +++ b/test/integration_test_helper.rb @@ -103,6 +103,32 @@ def assert_index_page(index_path, title_text, new_link_text = nil, has_search = assert_breadcrumb_text(title_text) (assert first(:link, new_link_text).visible?, "#{new_link_text} is not visible") if new_link_text (assert find('.autocomplete-search button').visible?, "Search button is not visible") if has_search + assert_sortable_table index_path + end + + def assert_sortable_table(index_path) + visit index_path + if page.has_selector?('table') + if page.has_selector?(:css, ".pf-c-table") + th_with_sort = "//th/button" + else + th_with_sort = "//th/a" + end + len = page.all(:xpath, th_with_sort).length + (0..len - 1).each do |i| + th = page.all(:xpath, th_with_sort)[i] + th_text = th.text + th.click + sort_by = page.all(:xpath, th_with_sort)[i] + assert( + sort_by[:class].include?('ascending') || + sort_by[:class].include?('descending') || + sort_by["aria-sort"] == 'ascending' || + sort_by["aria-sort"] == 'descending', + "sort by #{th_text} does not have 'ascending' or 'descending' class" + ) + end + end end def assert_breadcrumb_text(text)