X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/2f3e23f6eb2bd571a39486773f0f10d65a2398a1..e3693d487a8da3743d53e90926e8064ed8bf34c7:/test/unit/node_test.rb?ds=sidebyside
diff --git a/test/unit/node_test.rb b/test/unit/node_test.rb
index acad7218c..d65fe5568 100644
--- a/test/unit/node_test.rb
+++ b/test/unit/node_test.rb
@@ -167,4 +167,69 @@ class NodeTest < ActiveSupport::TestCase
#assert_equal node_template.tags, old_node.tags
assert_equal node_template.timestamp.to_i, old_node.timestamp.to_i
end
+
+ def test_from_xml_no_id
+ lat = 56.7
+ lon = -2.3
+ changeset = 2
+ version = 1
+ noid = ""
+ # First try a create which doesn't need the id
+ assert_nothing_raised(OSM::APIBadXMLError) {
+ Node.from_xml(noid, true)
+ }
+ # Now try an update with no id, and make sure that it gives the appropriate exception
+ message = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(noid, false)
+ }
+ assert_match /ID is required when updating./, message.message
+ end
+
+ def test_from_xml_no_lat
+ nolat = ""
+ message_create = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nolat, true)
+ }
+ assert_match /lat missing/, message_create.message
+ message_update = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nolat, false)
+ }
+ assert_match /lat missing/, message_update.message
+ end
+
+ def test_from_xml_no_lon
+ nolon = ""
+ message_create = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nolon, true)
+ }
+ assert_match /lon missing/, message_create.message
+ message_update = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nolon, false)
+ }
+ assert_match /lon missing/, message_update.message
+ end
+
+ def test_from_xml_no_changeset_id
+ nocs = ""
+ message_create = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nocs, true)
+ }
+ assert_match /changeset id missing/, message_create.message
+ message_update = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nocs, false)
+ }
+ assert_match /changeset id missing/, message_update.message
+ end
+
+ def test_from_xml_double_lat
+ nocs = ""
+ message_create = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nocs, true)
+ }
+ assert_match /Fatal error: Attribute lat redefined at/, message_create.message
+ message_update = assert_raise(OSM::APIBadXMLError) {
+ Node.from_xml(nocs, false)
+ }
+ assert_match /Fatal error: Attribute lat redefined at/, message_update.message
+ end
end