]> git.openstreetmap.org Git - rails.git/blob - test/unit/relation_test.rb
try and make the OpenStreetBugs API a bit more consistent with the rest of the API
[rails.git] / test / unit / relation_test.rb
1 require File.dirname(__FILE__) + '/../test_helper'
2
3 class RelationTest < ActiveSupport::TestCase
4   api_fixtures
5   
6   def test_relation_count
7     assert_equal 6, Relation.count
8   end
9   
10   def test_from_xml_no_id
11     noid = "<osm><relation version='12' changeset='23' /></osm>"
12     assert_nothing_raised(OSM::APIBadXMLError) {
13       Relation.from_xml(noid, true)
14     }
15     message = assert_raise(OSM::APIBadXMLError) {
16       Relation.from_xml(noid, false)
17     }
18     assert_match /ID is required when updating/, message.message
19   end
20   
21   def test_from_xml_no_changeset_id
22     nocs = "<osm><relation id='123' version='12' /></osm>"
23     message_create = assert_raise(OSM::APIBadXMLError) {
24       Relation.from_xml(nocs, true)
25     }
26     assert_match /Changeset id is missing/, message_create.message
27     message_update = assert_raise(OSM::APIBadXMLError) {
28       Relation.from_xml(nocs, false)
29     }
30     assert_match /Changeset id is missing/, message_update.message
31   end
32   
33   def test_from_xml_no_version
34     no_version = "<osm><relation id='123' changeset='23' /></osm>"
35     assert_nothing_raised(OSM::APIBadXMLError) {
36       Relation.from_xml(no_version, true)
37     }
38     message_update = assert_raise(OSM::APIBadXMLError) {
39       Relation.from_xml(no_version, false)
40     }
41     assert_match /Version is required when updating/, message_update.message
42   end
43   
44   def test_from_xml_id_zero
45     id_list = ["", "0", "00", "0.0", "a"]
46     id_list.each do |id|
47       zero_id = "<osm><relation id='#{id}' changeset='332' version='23' /></osm>"
48       assert_nothing_raised(OSM::APIBadUserInput) {
49         Relation.from_xml(zero_id, true)
50       }
51       message_update = assert_raise(OSM::APIBadUserInput) {
52         Relation.from_xml(zero_id, false)
53       }
54       assert_match /ID of relation cannot be zero when updating/, message_update.message
55     end
56   end
57   
58   def test_from_xml_no_text
59     no_text = ""
60     message_create = assert_raise(OSM::APIBadXMLError) {
61       Relation.from_xml(no_text, true)
62     }
63     assert_match /Must specify a string with one or more characters/, message_create.message
64     message_update = assert_raise(OSM::APIBadXMLError) {
65       Relation.from_xml(no_text, false)
66     }
67     assert_match /Must specify a string with one or more characters/, message_update.message
68   end
69   
70   def test_from_xml_no_k_v
71     nokv = "<osm><relation id='23' changeset='23' version='23'><tag /></relation></osm>"
72     message_create = assert_raise(OSM::APIBadXMLError) {
73       Relation.from_xml(nokv, true)
74     }
75     assert_match /tag is missing key/, message_create.message
76     message_update = assert_raise(OSM::APIBadXMLError) {
77       Relation.from_xml(nokv, false)
78     }
79     assert_match /tag is missing key/, message_update.message
80   end
81   
82   def test_from_xml_no_v
83     no_v = "<osm><relation id='23' changeset='23' version='23'><tag k='key' /></relation></osm>"
84     message_create = assert_raise(OSM::APIBadXMLError) {
85       Relation.from_xml(no_v, true)
86     }
87     assert_match /tag is missing value/, message_create.message
88     message_update = assert_raise(OSM::APIBadXMLError) {
89       Relation.from_xml(no_v, false)
90     }
91     assert_match /tag is missing value/, message_update.message
92   end
93   
94   def test_from_xml_duplicate_k
95     dupk = "<osm><relation id='23' changeset='23' version='23'><tag k='dup' v='test'/><tag k='dup' v='tester'/></relation></osm>"
96     message_create = assert_raise(OSM::APIDuplicateTagsError) {
97       Relation.from_xml(dupk, true)
98     }
99     assert_equal "Element relation/ has duplicate tags with key dup", message_create.message
100     message_update = assert_raise(OSM::APIDuplicateTagsError) {
101       Relation.from_xml(dupk, false)
102     }
103     assert_equal "Element relation/23 has duplicate tags with key dup", message_update.message
104   end
105 end