X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/94cf6ece2dc27909f2d01af099a3960e75ed6da5..c7ba9694118f0f4caf862ff89a9434d7d6e81913:/test/functional/way_controller_test.rb?ds=inline
diff --git a/test/functional/way_controller_test.rb b/test/functional/way_controller_test.rb
index be4c41a39..607f2dc6f 100644
--- a/test/functional/way_controller_test.rb
+++ b/test/functional/way_controller_test.rb
@@ -4,14 +4,6 @@ require 'way_controller'
class WayControllerTest < ActionController::TestCase
api_fixtures
- def basic_authorization(user, pass)
- @request.env["HTTP_AUTHORIZATION"] = "Basic %s" % Base64.encode64("#{user}:#{pass}")
- end
-
- def content(c)
- @request.env["RAW_POST_DATA"] = c.to_s
- end
-
# -------------------------------------
# Test reading ways.
# -------------------------------------
@@ -64,13 +56,33 @@ class WayControllerTest < ActionController::TestCase
# -------------------------------------
def test_create
+ ## First check that it fails when creating a way using a non-public user
nid1 = current_nodes(:used_node_1).id
nid2 = current_nodes(:used_node_2).id
- basic_authorization "test@openstreetmap.org", "test"
+ basic_authorization users(:normal_user).email, "test"
# use the first user's open changeset
changeset_id = changesets(:normal_user_first_change).id
+ # create a way with pre-existing nodes
+ content "" +
+ "" +
+ ""
+ put :create
+ # hope for success
+ assert_response :forbidden,
+ "way upload did not return success status"
+ # read id of created way and search for it
+ wayid = @response.body
+
+ ## Now use a public user
+ nid1 = current_nodes(:used_node_1).id
+ nid2 = current_nodes(:used_node_2).id
+ basic_authorization users(:public_user).email, "test"
+
+ # use the first user's open changeset
+ changeset_id = changesets(:public_user_first_change).id
+
# create a way with pre-existing nodes
content "" +
"" +
@@ -93,7 +105,7 @@ class WayControllerTest < ActionController::TestCase
"saved way does not contain the right node on pos 1"
assert_equal checkway.changeset_id, changeset_id,
"saved way does not belong to the correct changeset"
- assert_equal users(:normal_user).id, checkway.changeset.user_id,
+ assert_equal users(:public_user).id, checkway.changeset.user_id,
"saved way does not belong to user that created it"
assert_equal true, checkway.visible,
"saved way is not visible"
@@ -104,13 +116,47 @@ class WayControllerTest < ActionController::TestCase
# -------------------------------------
def test_create_invalid
- basic_authorization "test@openstreetmap.org", "test"
+ ## First test with a private user to make sure that they are not authorized
+ basic_authorization users(:normal_user).email, "test"
# use the first user's open changeset
open_changeset_id = changesets(:normal_user_first_change).id
closed_changeset_id = changesets(:normal_user_closed_change).id
nid1 = current_nodes(:used_node_1).id
+ # create a way with non-existing node
+ content "" +
+ ""
+ put :create
+ # expect failure
+ assert_response :forbidden,
+ "way upload with invalid node using a private user did not return 'forbidden'"
+
+ # create a way with no nodes
+ content "" +
+ ""
+ put :create
+ # expect failure
+ assert_response :forbidden,
+ "way upload with no node using a private userdid not return 'forbidden'"
+
+ # create a way inside a closed changeset
+ content "" +
+ ""
+ put :create
+ # expect failure
+ assert_response :forbidden,
+ "way upload to closed changeset with a private user did not return 'forbidden'"
+
+
+ ## Now test with a public user
+ basic_authorization users(:public_user).email, "test"
+
+ # use the first user's open changeset
+ open_changeset_id = changesets(:public_user_first_change).id
+ closed_changeset_id = changesets(:public_user_closed_change).id
+ nid1 = current_nodes(:used_node_1).id
+
# create a way with non-existing node
content "" +
""
@@ -118,6 +164,7 @@ class WayControllerTest < ActionController::TestCase
# expect failure
assert_response :precondition_failed,
"way upload with invalid node did not return 'precondition failed'"
+ assert_equal "Precondition failed: Way requires the nodes with id in (0), which either do not exist, or are not visible.", @response.body
# create a way with no nodes
content "" +
@@ -126,6 +173,7 @@ class WayControllerTest < ActionController::TestCase
# expect failure
assert_response :precondition_failed,
"way upload with no node did not return 'precondition failed'"
+ assert_equal "Precondition failed: Cannot create way: data is invalid.", @response.body
# create a way inside a closed changeset
content "" +
@@ -134,6 +182,16 @@ class WayControllerTest < ActionController::TestCase
# expect failure
assert_response :conflict,
"way upload to closed changeset did not return 'conflict'"
+
+ # create a way with a tag which is too long
+ content "" +
+ "" +
+ "" +
+ ""
+ put :create
+ # expect failure
+ assert_response :bad_request,
+ "way upload to with too long tag did not return 'bad_request'"
end
# -------------------------------------
@@ -145,8 +203,59 @@ class WayControllerTest < ActionController::TestCase
delete :delete, :id => current_ways(:visible_way).id
assert_response :unauthorized
+ # now set auth using the private user
+ basic_authorization(users(:normal_user).email, "test");
+
+ # this shouldn't work as with the 0.6 api we need pay load to delete
+ delete :delete, :id => current_ways(:visible_way).id
+ assert_response :forbidden
+
+ # Now try without having a changeset
+ content ""
+ delete :delete, :id => current_ways(:visible_way).id
+ assert_response :forbidden
+
+ # try to delete with an invalid (closed) changeset
+ content update_changeset(current_ways(:visible_way).to_xml,
+ changesets(:normal_user_closed_change).id)
+ delete :delete, :id => current_ways(:visible_way).id
+ assert_response :forbidden
+
+ # try to delete with an invalid (non-existent) changeset
+ content update_changeset(current_ways(:visible_way).to_xml,0)
+ delete :delete, :id => current_ways(:visible_way).id
+ assert_response :forbidden
+
+ # Now try with a valid changeset
+ content current_ways(:visible_way).to_xml
+ delete :delete, :id => current_ways(:visible_way).id
+ assert_response :forbidden
+
+ # check the returned value - should be the new version number
+ # valid delete should return the new version number, which should
+ # be greater than the old version number
+ #assert @response.body.to_i > current_ways(:visible_way).version,
+ # "delete request should return a new version number for way"
+
+ # this won't work since the way is already deleted
+ content current_ways(:invisible_way).to_xml
+ delete :delete, :id => current_ways(:invisible_way).id
+ assert_response :forbidden
+
+ # this shouldn't work as the way is used in a relation
+ content current_ways(:used_way).to_xml
+ delete :delete, :id => current_ways(:used_way).id
+ assert_response :forbidden,
+ "shouldn't be able to delete a way used in a relation (#{@response.body}), when done by a private user"
+
+ # this won't work since the way never existed
+ delete :delete, :id => 0
+ assert_response :forbidden
+
+
+ ### Now check with a public user
# now set auth
- basic_authorization("test@openstreetmap.org", "test");
+ basic_authorization(users(:public_user).email, "test");
# this shouldn't work as with the 0.6 api we need pay load to delete
delete :delete, :id => current_ways(:visible_way).id
@@ -159,7 +268,7 @@ class WayControllerTest < ActionController::TestCase
# try to delete with an invalid (closed) changeset
content update_changeset(current_ways(:visible_way).to_xml,
- changesets(:normal_user_closed_change).id)
+ changesets(:public_user_closed_change).id)
delete :delete, :id => current_ways(:visible_way).id
assert_response :conflict
@@ -189,6 +298,7 @@ class WayControllerTest < ActionController::TestCase
delete :delete, :id => current_ways(:used_way).id
assert_response :precondition_failed,
"shouldn't be able to delete a way used in a relation (#{@response.body})"
+ assert_equal "Precondition failed: Way 3 still used by relation 1.", @response.body
# this won't work since the way never existed
delete :delete, :id => 0
@@ -202,6 +312,7 @@ class WayControllerTest < ActionController::TestCase
##
# Try adding a duplicate of an existing tag to a way
def test_add_duplicate_tags
+ ## Try with the non-public user
# setup auth
basic_authorization(users(:normal_user).email, "test")
@@ -214,16 +325,37 @@ class WayControllerTest < ActionController::TestCase
way_xml = current_ways(:visible_way).to_xml
way_xml.find("//osm/way").first << tag_xml
+ # try and upload it
+ content way_xml
+ put :update, :id => current_ways(:visible_way).id
+ assert_response :forbidden,
+ "adding a duplicate tag to a way for a non-public should fail with 'forbidden'"
+
+ ## Now try with the public user
+ # setup auth
+ basic_authorization(users(:public_user).email, "test")
+
+ # add an identical tag to the way
+ tag_xml = XML::Node.new("tag")
+ tag_xml['k'] = current_way_tags(:t1).k
+ tag_xml['v'] = current_way_tags(:t1).v
+
+ # add the tag into the existing xml
+ way_xml = current_ways(:visible_way).to_xml
+ way_xml.find("//osm/way").first << tag_xml
+
# try and upload it
content way_xml
put :update, :id => current_ways(:visible_way).id
assert_response :bad_request,
"adding a duplicate tag to a way should fail with 'bad request'"
+ assert_equal "Element way/#{current_ways(:visible_way).id} has duplicate tags with key #{current_way_tags(:t1).k}", @response.body
end
##
# Try adding a new duplicate tags to a way
def test_new_duplicate_tags
+ ## First test with the non-public user so should be rejected
# setup auth
basic_authorization(users(:normal_user).email, "test")
@@ -238,48 +370,73 @@ class WayControllerTest < ActionController::TestCase
# add two copies of the tag
way_xml.find("//osm/way").first << tag_xml.copy(true) << tag_xml
+ # try and upload it
+ content way_xml
+ put :update, :id => current_ways(:visible_way).id
+ assert_response :forbidden,
+ "adding new duplicate tags to a way using a non-public user should fail with 'forbidden'"
+
+ ## Now test with the public user
+ # setup auth
+ basic_authorization(users(:public_user).email, "test")
+
+ # create duplicate tag
+ tag_xml = XML::Node.new("tag")
+ tag_xml['k'] = "i_am_a_duplicate"
+ tag_xml['v'] = "foobar"
+
+ # add the tag into the existing xml
+ way_xml = current_ways(:visible_way).to_xml
+
+ # add two copies of the tag
+ way_xml.find("//osm/way").first << tag_xml.copy(true) << tag_xml
+
# try and upload it
content way_xml
put :update, :id => current_ways(:visible_way).id
assert_response :bad_request,
"adding new duplicate tags to a way should fail with 'bad request'"
+ assert_equal "Element way/#{current_ways(:visible_way).id} has duplicate tags with key i_am_a_duplicate", @response.body
+
end
##
# Try adding a new duplicate tags to a way.
# But be a bit subtle - use unicode decoding ambiguities to use different
# binary strings which have the same decoding.
- #
- # NOTE: I'm not sure this test is working correctly, as a lot of the tag
- # keys seem to come out as "addr��housenumber". It might be something to
- # do with Ruby's unicode handling...?
def test_invalid_duplicate_tags
+ ## First make sure that you can't with a non-public user
# setup auth
basic_authorization(users(:normal_user).email, "test")
# add the tag into the existing xml
way_str = ""
way_str << ""
+ way_str << ""
+ way_str << "";
- # all of these keys have the same unicode decoding, but are binary
- # not equal. libxml should make these identical as it decodes the
- # XML document...
- [ "addr\xc0\xbahousenumber",
- "addr\xe0\x80\xbahousenumber",
- "addr\xf0\x80\x80\xbahousenumber" ].each do |key|
- # copy the XML doc to add the tags
- way_str_copy = way_str.clone
-
- # add all new tags to the way
- way_str_copy << ""
- way_str_copy << "";
-
- # try and upload it
- content way_str_copy
- put :create
- assert_response :bad_request,
- "adding new duplicate tags to a way should fail with 'bad request'"
- end
+ # try and upload it
+ content way_str
+ put :create
+ assert_response :forbidden,
+ "adding new duplicate tags to a way with a non-public user should fail with 'forbidden'"
+
+ ## Now do it with a public user
+ # setup auth
+ basic_authorization(users(:public_user).email, "test")
+
+ # add the tag into the existing xml
+ way_str = ""
+ way_str << ""
+ way_str << ""
+ way_str << "";
+
+ # try and upload it
+ content way_str
+ put :create
+ assert_response :bad_request,
+ "adding new duplicate tags to a way should fail with 'bad request'"
+ assert_equal "Element way/ has duplicate tags with key addr:housenumber", @response.body
end
##