Merge remote-tracking branch 'upstream/pull/4565'

This commit is contained in:
Tom Hughes 2024-08-28 18:59:09 +01:00
commit 5f2a5cadcb
8 changed files with 132 additions and 56 deletions

View file

@ -0,0 +1,75 @@
require "application_system_test_case"
class ChangesetElementsTest < ApplicationSystemTestCase
test "can navigate between element subpages without losing comment input" do
element_page_size = 20
changeset = create(:changeset, :closed)
ways = create_list(:way, element_page_size + 1, :with_history, :changeset => changeset)
way_paths = ways.map { |way| way_path(way) }
nodes = create_list(:node, element_page_size + 1, :with_history, :changeset => changeset)
node_paths = nodes.map { |node| node_path(node) }
sign_in_as(create(:user))
visit changeset_path(changeset)
within_sidebar do
next_page_way_path = assert_one_missing_link way_paths
assert_no_link "Ways (1-20 of 21)"
assert_link "Ways (21-21 of 21)"
assert_one_missing_link node_paths
assert_no_link "Nodes (1-20 of 21)"
assert_link "Nodes (21-21 of 21)"
fill_in "text", :with => "Comment text we don't want to lose"
click_on "Ways (21-21 of 21)"
assert_one_present_link way_paths, next_page_way_path
assert_link "Ways (1-20 of 21)"
assert_no_link "Ways (21-21 of 21)"
next_page_node_path = assert_one_missing_link node_paths
assert_no_link "Nodes (1-20 of 21)"
assert_link "Nodes (21-21 of 21)"
assert_field "text", :with => "Comment text we don't want to lose"
click_on "Nodes (21-21 of 21)"
assert_one_present_link way_paths, next_page_way_path
assert_link "Ways (1-20 of 21)"
assert_no_link "Ways (21-21 of 21)"
assert_one_present_link node_paths, next_page_node_path
assert_link "Nodes (1-20 of 21)"
assert_no_link "Nodes (21-21 of 21)"
assert_field "text", :with => "Comment text we don't want to lose"
end
end
private
def assert_one_missing_link(hrefs)
missing_href = nil
hrefs.each do |href|
missing = true
assert_link :href => href, :minimum => 0, :maximum => 1 do
missing = false
end
if missing
assert_nil missing_href, "unexpected extra missing link '#{href}'"
missing_href = href
end
end
assert_not_nil missing_href, "expected one link missing but all are present"
missing_href
end
def assert_one_present_link(hrefs, present_href)
hrefs.each do |href|
assert_link :href => href, :count => (href == present_href ? 1 : 0)
end
end
end