X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/98184dfb9cacc74ac5bcb91a41a2d5804b3f4f7d..5a0e0b2407823f501977d362ddc09664d9fa2f3f:/test/controllers/browse_controller_test.rb diff --git a/test/controllers/browse_controller_test.rb b/test/controllers/browse_controller_test.rb index 2ab9106f1..1844dcc6c 100644 --- a/test/controllers/browse_controller_test.rb +++ b/test/controllers/browse_controller_test.rb @@ -1,163 +1,18 @@ -require 'test_helper' -require 'browse_controller' - -class BrowseControllerTest < ActionController::TestCase - api_fixtures +require "test_helper" +class BrowseControllerTest < ActionDispatch::IntegrationTest ## # test all routes which lead to this controller def test_routes assert_routing( - { :path => "/node/1", :method => :get }, - { :controller => "browse", :action => "node", :id => "1" } - ) - assert_routing( - { :path => "/node/1/history", :method => :get }, - { :controller => "browse", :action => "node_history", :id => "1" } - ) - assert_routing( - { :path => "/way/1", :method => :get }, - { :controller => "browse", :action => "way", :id => "1" } - ) - assert_routing( - { :path => "/way/1/history", :method => :get }, - { :controller => "browse", :action => "way_history", :id => "1" } - ) - assert_routing( - { :path => "/relation/1", :method => :get }, - { :controller => "browse", :action => "relation", :id => "1" } - ) - assert_routing( - { :path => "/relation/1/history", :method => :get }, - { :controller => "browse", :action => "relation_history", :id => "1" } - ) - assert_routing( - { :path => "/changeset/1", :method => :get }, - { :controller => "browse", :action => "changeset", :id => "1" } - ) - assert_routing( - { :path => "/note/1", :method => :get }, - { :controller => "browse", :action => "note", :id => "1" } - ) - assert_routing( - { :path => "/note/new", :method => :get }, - { :controller => "browse", :action => "new_note" } + { :path => "/query", :method => :get }, + { :controller => "browse", :action => "query" } ) end - def test_read_relation - browse_check 'relation', relations(:visible_relation).relation_id, 'browse/feature' - end - - def test_read_relation_history - browse_check 'relation_history', relations(:visible_relation).relation_id, 'browse/history' - end - - def test_read_way - browse_check 'way', ways(:visible_way).way_id, 'browse/feature' - end - - def test_read_way_history - browse_check 'way_history', ways(:visible_way).way_id, 'browse/history' - end - - def test_read_node - browse_check 'node', nodes(:visible_node).node_id, 'browse/feature' - end - - def test_read_node_history - browse_check 'node_history', nodes(:visible_node).node_id, 'browse/history' - end - - def test_read_changeset - browse_check 'changeset', changesets(:normal_user_first_change).id, 'browse/changeset' - end - - def test_read_note - browse_check 'note', notes(:open_note).id, 'browse/note' - end - - ## - # Methods to check redaction. - # - # note that these are presently highly reliant on the structure of the - # page for the selection tests, which doesn't work out particularly - # well if that structure changes. so... if you change the page layout - # then please make it more easily (and robustly) testable! - ## - def test_redacted_node - get :node, :id => current_nodes(:redacted_node).id - assert_response :success - assert_template "feature" - - # check that we don't show lat/lon for a redacted node. - assert_select ".browse-section", 1 - assert_select ".browse-section.browse-node", 1 - assert_select ".browse-section.browse-node .latitude", 0 - assert_select ".browse-section.browse-node .longitude", 0 - end - - def test_redacted_node_history - get :node_history, :id => nodes(:redacted_node_redacted_version).node_id - assert_response :success - assert_template "browse/history" - - # there are 2 revisions of the redacted node, but only one - # should be showing details here. - assert_select ".browse-section", 2 - assert_select ".browse-section.browse-redacted", 1 - assert_select ".browse-section.browse-node", 1 - assert_select ".browse-section.browse-node .latitude", 0 - assert_select ".browse-section.browse-node .longitude", 0 - end - - def test_redacted_way_history - get :way_history, :id => ways(:way_with_redacted_versions_v1).way_id - assert_response :success - assert_template 'browse/history' - - # there are 4 revisions of the redacted way, but only 2 - # should be showing details here. - assert_select ".browse-section", 4 - assert_select ".browse-section.browse-redacted", 2 - assert_select ".browse-section.browse-way", 2 - end - - def test_redacted_relation_history - get :relation_history, :id => relations(:relation_with_redacted_versions_v1).relation_id - assert_response :success - assert_template 'browse/history' - - # there are 4 revisions of the redacted relation, but only 2 - # should be showing details here. - assert_select ".browse-section", 4 - assert_select ".browse-section.browse-redacted", 2 - assert_select ".browse-section.browse-relation", 2 - end - -private - - # This is a convenience method for most of the above checks - # First we check that when we don't have an id, it will correctly return a 404 - # then we check that we get the correct 404 when a non-existant id is passed - # then we check that it will get a successful response, when we do pass an id - def browse_check(type, id, template) - assert_raise ActionController::UrlGenerationError do - get type - end - - assert_raise ActionController::UrlGenerationError do - get type, {:id => -10} # we won't have an id that's negative - end - - get type, {:id => id} - assert_response :success - assert_template template - assert_template :layout => "map" - - xhr :get, type, {:id => id} + def test_query + get query_path assert_response :success - assert_template template - assert_template :layout => "xhr" + assert_template "browse/query" end end