4 class NotesControllerTest < ActionDispatch::IntegrationTest
7 # Stub nominatim response for note locations
8 stub_request(:get, %r{^https://nominatim\.openstreetmap\.org/reverse\?})
9 .to_return(:status => 404)
13 # test all routes which lead to this controller
16 { :path => "/api/0.6/notes", :method => :post },
17 { :controller => "api/notes", :action => "create" }
20 { :path => "/api/0.6/notes/1", :method => :get },
21 { :controller => "api/notes", :action => "show", :id => "1" }
24 { :controller => "api/notes", :action => "show", :id => "1", :format => "xml" },
25 { :path => "/api/0.6/notes/1.xml", :method => :get }
28 { :path => "/api/0.6/notes/1.rss", :method => :get },
29 { :controller => "api/notes", :action => "show", :id => "1", :format => "rss" }
32 { :path => "/api/0.6/notes/1.json", :method => :get },
33 { :controller => "api/notes", :action => "show", :id => "1", :format => "json" }
36 { :path => "/api/0.6/notes/1.gpx", :method => :get },
37 { :controller => "api/notes", :action => "show", :id => "1", :format => "gpx" }
40 { :path => "/api/0.6/notes/1/comment", :method => :post },
41 { :controller => "api/notes", :action => "comment", :id => "1" }
44 { :path => "/api/0.6/notes/1/close", :method => :post },
45 { :controller => "api/notes", :action => "close", :id => "1" }
48 { :path => "/api/0.6/notes/1/reopen", :method => :post },
49 { :controller => "api/notes", :action => "reopen", :id => "1" }
52 { :path => "/api/0.6/notes/1", :method => :delete },
53 { :controller => "api/notes", :action => "destroy", :id => "1" }
57 { :path => "/api/0.6/notes", :method => :get },
58 { :controller => "api/notes", :action => "index" }
61 { :controller => "api/notes", :action => "index", :format => "xml" },
62 { :path => "/api/0.6/notes.xml", :method => :get }
65 { :path => "/api/0.6/notes.rss", :method => :get },
66 { :controller => "api/notes", :action => "index", :format => "rss" }
69 { :path => "/api/0.6/notes.json", :method => :get },
70 { :controller => "api/notes", :action => "index", :format => "json" }
73 { :path => "/api/0.6/notes.gpx", :method => :get },
74 { :controller => "api/notes", :action => "index", :format => "gpx" }
78 { :path => "/api/0.6/notes/search", :method => :get },
79 { :controller => "api/notes", :action => "search" }
82 { :controller => "api/notes", :action => "search", :format => "xml" },
83 { :path => "/api/0.6/notes/search.xml", :method => :get }
86 { :path => "/api/0.6/notes/search.rss", :method => :get },
87 { :controller => "api/notes", :action => "search", :format => "rss" }
90 { :path => "/api/0.6/notes/search.json", :method => :get },
91 { :controller => "api/notes", :action => "search", :format => "json" }
94 { :path => "/api/0.6/notes/search.gpx", :method => :get },
95 { :controller => "api/notes", :action => "search", :format => "gpx" }
99 { :path => "/api/0.6/notes/feed", :method => :get },
100 { :controller => "api/notes", :action => "feed", :format => "rss" }
104 { :controller => "api/notes", :action => "create" },
105 { :path => "/api/0.6/notes/addPOIexec", :method => :post }
108 { :controller => "api/notes", :action => "close" },
109 { :path => "/api/0.6/notes/closePOIexec", :method => :post }
112 { :controller => "api/notes", :action => "comment" },
113 { :path => "/api/0.6/notes/editPOIexec", :method => :post }
116 { :controller => "api/notes", :action => "index", :format => "gpx" },
117 { :path => "/api/0.6/notes/getGPX", :method => :get }
120 { :controller => "api/notes", :action => "feed", :format => "rss" },
121 { :path => "/api/0.6/notes/getRSSfeed", :method => :get }
125 def test_create_success
126 assert_difference "Note.count", 1 do
127 assert_difference "NoteComment.count", 1 do
128 post api_notes_path(:lat => -1.0, :lon => -1.0, :text => "This is a comment", :format => "json")
131 assert_response :success
132 js = ActiveSupport::JSON.decode(@response.body)
134 assert_equal "Feature", js["type"]
135 assert_equal "Point", js["geometry"]["type"]
136 assert_equal [-1.0, -1.0], js["geometry"]["coordinates"]
137 assert_equal "open", js["properties"]["status"]
138 assert_equal 1, js["properties"]["comments"].count
139 assert_equal "opened", js["properties"]["comments"].last["action"]
140 assert_equal "This is a comment", js["properties"]["comments"].last["text"]
141 assert_nil js["properties"]["comments"].last["user"]
142 id = js["properties"]["id"]
144 get api_note_path(:id => id, :format => "json")
145 assert_response :success
146 js = ActiveSupport::JSON.decode(@response.body)
148 assert_equal "Feature", js["type"]
149 assert_equal "Point", js["geometry"]["type"]
150 assert_equal [-1.0, -1.0], js["geometry"]["coordinates"]
151 assert_equal id, js["properties"]["id"]
152 assert_equal "open", js["properties"]["status"]
153 assert_equal 1, js["properties"]["comments"].count
154 assert_equal "opened", js["properties"]["comments"].last["action"]
155 assert_equal "This is a comment", js["properties"]["comments"].last["text"]
156 assert_nil js["properties"]["comments"].last["user"]
160 assert_no_difference "Note.count" do
161 assert_no_difference "NoteComment.count" do
162 post api_notes_path(:lon => -1.0, :text => "This is a comment")
165 assert_response :bad_request
167 assert_no_difference "Note.count" do
168 assert_no_difference "NoteComment.count" do
169 post api_notes_path(:lat => -1.0, :text => "This is a comment")
172 assert_response :bad_request
174 assert_no_difference "Note.count" do
175 assert_no_difference "NoteComment.count" do
176 post api_notes_path(:lat => -1.0, :lon => -1.0)
179 assert_response :bad_request
181 assert_no_difference "Note.count" do
182 assert_no_difference "NoteComment.count" do
183 post api_notes_path(:lat => -1.0, :lon => -1.0, :text => "")
186 assert_response :bad_request
188 assert_no_difference "Note.count" do
189 assert_no_difference "NoteComment.count" do
190 post api_notes_path(:lat => -100.0, :lon => -1.0, :text => "This is a comment")
193 assert_response :bad_request
195 assert_no_difference "Note.count" do
196 assert_no_difference "NoteComment.count" do
197 post api_notes_path(:lat => -1.0, :lon => -200.0, :text => "This is a comment")
200 assert_response :bad_request
202 assert_no_difference "Note.count" do
203 assert_no_difference "NoteComment.count" do
204 post api_notes_path(:lat => "abc", :lon => -1.0, :text => "This is a comment")
207 assert_response :bad_request
209 assert_no_difference "Note.count" do
210 assert_no_difference "NoteComment.count" do
211 post api_notes_path(:lat => -1.0, :lon => "abc", :text => "This is a comment")
214 assert_response :bad_request
216 assert_no_difference "Note.count" do
217 assert_no_difference "NoteComment.count" do
218 post api_notes_path(:lat => -1.0, :lon => -1.0, :text => "x\u0000y")
221 assert_response :bad_request
224 def test_comment_success
225 open_note_with_comment = create(:note_with_comments)
227 auth_header = basic_authorization_header user.email, "test"
228 assert_difference "NoteComment.count", 1 do
229 assert_no_difference "ActionMailer::Base.deliveries.size" do
230 perform_enqueued_jobs do
231 post comment_api_note_path(:id => open_note_with_comment, :text => "This is an additional comment", :format => "json"), :headers => auth_header
235 assert_response :success
236 js = ActiveSupport::JSON.decode(@response.body)
238 assert_equal "Feature", js["type"]
239 assert_equal open_note_with_comment.id, js["properties"]["id"]
240 assert_equal "open", js["properties"]["status"]
241 assert_equal 2, js["properties"]["comments"].count
242 assert_equal "commented", js["properties"]["comments"].last["action"]
243 assert_equal "This is an additional comment", js["properties"]["comments"].last["text"]
244 assert_equal user.display_name, js["properties"]["comments"].last["user"]
246 get api_note_path(:id => open_note_with_comment, :format => "json")
247 assert_response :success
248 js = ActiveSupport::JSON.decode(@response.body)
250 assert_equal "Feature", js["type"]
251 assert_equal open_note_with_comment.id, js["properties"]["id"]
252 assert_equal "open", js["properties"]["status"]
253 assert_equal 2, js["properties"]["comments"].count
254 assert_equal "commented", js["properties"]["comments"].last["action"]
255 assert_equal "This is an additional comment", js["properties"]["comments"].last["text"]
256 assert_equal user.display_name, js["properties"]["comments"].last["user"]
258 # Ensure that emails are sent to users
259 first_user = create(:user)
260 second_user = create(:user)
261 third_user = create(:user)
263 note_with_comments_by_users = create(:note) do |note|
264 create(:note_comment, :note => note, :author => first_user)
265 create(:note_comment, :note => note, :author => second_user)
268 auth_header = basic_authorization_header third_user.email, "test"
270 assert_difference "NoteComment.count", 1 do
271 assert_difference "ActionMailer::Base.deliveries.size", 2 do
272 perform_enqueued_jobs do
273 post comment_api_note_path(:id => note_with_comments_by_users, :text => "This is an additional comment", :format => "json"), :headers => auth_header
277 assert_response :success
278 js = ActiveSupport::JSON.decode(@response.body)
280 assert_equal "Feature", js["type"]
281 assert_equal note_with_comments_by_users.id, js["properties"]["id"]
282 assert_equal "open", js["properties"]["status"]
283 assert_equal 3, js["properties"]["comments"].count
284 assert_equal "commented", js["properties"]["comments"].last["action"]
285 assert_equal "This is an additional comment", js["properties"]["comments"].last["text"]
286 assert_equal third_user.display_name, js["properties"]["comments"].last["user"]
288 email = ActionMailer::Base.deliveries.find { |e| e.to.first == first_user.email }
290 assert_equal 1, email.to.length
291 assert_equal "[OpenStreetMap] #{third_user.display_name} has commented on one of your notes", email.subject
292 assert_equal first_user.email, email.to.first
294 email = ActionMailer::Base.deliveries.find { |e| e.to.first == second_user.email }
296 assert_equal 1, email.to.length
297 assert_equal "[OpenStreetMap] #{third_user.display_name} has commented on a note you are interested in", email.subject
299 get api_note_path(:id => note_with_comments_by_users, :format => "json")
300 assert_response :success
301 js = ActiveSupport::JSON.decode(@response.body)
303 assert_equal "Feature", js["type"]
304 assert_equal note_with_comments_by_users.id, js["properties"]["id"]
305 assert_equal "open", js["properties"]["status"]
306 assert_equal 3, js["properties"]["comments"].count
307 assert_equal "commented", js["properties"]["comments"].last["action"]
308 assert_equal "This is an additional comment", js["properties"]["comments"].last["text"]
309 assert_equal third_user.display_name, js["properties"]["comments"].last["user"]
311 ActionMailer::Base.deliveries.clear
314 def test_comment_fail
315 open_note_with_comment = create(:note_with_comments)
319 assert_no_difference "NoteComment.count" do
320 post comment_api_note_path(:id => open_note_with_comment)
321 assert_response :unauthorized
324 auth_header = basic_authorization_header user.email, "test"
326 assert_no_difference "NoteComment.count" do
327 post comment_api_note_path(:id => open_note_with_comment), :headers => auth_header
329 assert_response :bad_request
331 assert_no_difference "NoteComment.count" do
332 post comment_api_note_path(:id => open_note_with_comment, :text => ""), :headers => auth_header
334 assert_response :bad_request
336 assert_no_difference "NoteComment.count" do
337 post comment_api_note_path(:id => 12345, :text => "This is an additional comment"), :headers => auth_header
339 assert_response :not_found
341 hidden_note_with_comment = create(:note_with_comments, :status => "hidden")
343 assert_no_difference "NoteComment.count" do
344 post comment_api_note_path(:id => hidden_note_with_comment, :text => "This is an additional comment"), :headers => auth_header
346 assert_response :gone
348 closed_note_with_comment = create(:note_with_comments, :status => "closed", :closed_at => Time.now.utc)
350 assert_no_difference "NoteComment.count" do
351 post comment_api_note_path(:id => closed_note_with_comment, :text => "This is an additional comment"), :headers => auth_header
353 assert_response :conflict
355 assert_no_difference "NoteComment.count" do
356 post comment_api_note_path(:id => open_note_with_comment, :text => "x\u0000y"), :headers => auth_header
358 assert_response :bad_request
361 def test_close_success
362 open_note_with_comment = create(:note_with_comments)
365 post close_api_note_path(:id => open_note_with_comment, :text => "This is a close comment", :format => "json")
366 assert_response :unauthorized
368 auth_header = basic_authorization_header user.email, "test"
370 post close_api_note_path(:id => open_note_with_comment, :text => "This is a close comment", :format => "json"), :headers => auth_header
371 assert_response :success
372 js = ActiveSupport::JSON.decode(@response.body)
374 assert_equal "Feature", js["type"]
375 assert_equal open_note_with_comment.id, js["properties"]["id"]
376 assert_equal "closed", js["properties"]["status"]
377 assert_equal 2, js["properties"]["comments"].count
378 assert_equal "closed", js["properties"]["comments"].last["action"]
379 assert_equal "This is a close comment", js["properties"]["comments"].last["text"]
380 assert_equal user.display_name, js["properties"]["comments"].last["user"]
382 get api_note_path(:id => open_note_with_comment.id, :format => "json")
383 assert_response :success
384 js = ActiveSupport::JSON.decode(@response.body)
386 assert_equal "Feature", js["type"]
387 assert_equal open_note_with_comment.id, js["properties"]["id"]
388 assert_equal "closed", js["properties"]["status"]
389 assert_equal 2, js["properties"]["comments"].count
390 assert_equal "closed", js["properties"]["comments"].last["action"]
391 assert_equal "This is a close comment", js["properties"]["comments"].last["text"]
392 assert_equal user.display_name, js["properties"]["comments"].last["user"]
396 post close_api_note_path(:id => 12345)
397 assert_response :unauthorized
399 auth_header = basic_authorization_header create(:user).email, "test"
401 post close_api_note_path(:id => 12345), :headers => auth_header
402 assert_response :not_found
404 hidden_note_with_comment = create(:note_with_comments, :status => "hidden")
406 post close_api_note_path(:id => hidden_note_with_comment), :headers => auth_header
407 assert_response :gone
409 closed_note_with_comment = create(:note_with_comments, :status => "closed", :closed_at => Time.now.utc)
411 post close_api_note_path(:id => closed_note_with_comment), :headers => auth_header
412 assert_response :conflict
415 def test_reopen_success
416 closed_note_with_comment = create(:note_with_comments, :status => "closed", :closed_at => Time.now.utc)
419 post reopen_api_note_path(:id => closed_note_with_comment, :text => "This is a reopen comment", :format => "json")
420 assert_response :unauthorized
422 auth_header = basic_authorization_header user.email, "test"
424 post reopen_api_note_path(:id => closed_note_with_comment, :text => "This is a reopen comment", :format => "json"), :headers => auth_header
425 assert_response :success
426 js = ActiveSupport::JSON.decode(@response.body)
428 assert_equal "Feature", js["type"]
429 assert_equal closed_note_with_comment.id, js["properties"]["id"]
430 assert_equal "open", js["properties"]["status"]
431 assert_equal 2, js["properties"]["comments"].count
432 assert_equal "reopened", js["properties"]["comments"].last["action"]
433 assert_equal "This is a reopen comment", js["properties"]["comments"].last["text"]
434 assert_equal user.display_name, js["properties"]["comments"].last["user"]
436 get api_note_path(:id => closed_note_with_comment, :format => "json")
437 assert_response :success
438 js = ActiveSupport::JSON.decode(@response.body)
440 assert_equal "Feature", js["type"]
441 assert_equal closed_note_with_comment.id, js["properties"]["id"]
442 assert_equal "open", js["properties"]["status"]
443 assert_equal 2, js["properties"]["comments"].count
444 assert_equal "reopened", js["properties"]["comments"].last["action"]
445 assert_equal "This is a reopen comment", js["properties"]["comments"].last["text"]
446 assert_equal user.display_name, js["properties"]["comments"].last["user"]
450 hidden_note_with_comment = create(:note_with_comments, :status => "hidden")
452 post reopen_api_note_path(:id => hidden_note_with_comment)
453 assert_response :unauthorized
455 auth_header = basic_authorization_header create(:user).email, "test"
457 post reopen_api_note_path(:id => 12345), :headers => auth_header
458 assert_response :not_found
460 post reopen_api_note_path(:id => hidden_note_with_comment), :headers => auth_header
461 assert_response :gone
463 open_note_with_comment = create(:note_with_comments)
465 post reopen_api_note_path(:id => open_note_with_comment), :headers => auth_header
466 assert_response :conflict
469 def test_show_success
470 open_note = create(:note_with_comments)
472 get api_note_path(:id => open_note, :format => "xml")
473 assert_response :success
474 assert_equal "application/xml", @response.media_type
475 assert_select "osm", :count => 1 do
476 assert_select "note[lat='#{open_note.lat}'][lon='#{open_note.lon}']", :count => 1 do
477 assert_select "id", open_note.id.to_s
478 assert_select "url", api_note_url(open_note, :format => "xml")
479 assert_select "comment_url", comment_api_note_url(open_note, :format => "xml")
480 assert_select "close_url", close_api_note_url(open_note, :format => "xml")
481 assert_select "date_created", open_note.created_at.to_s
482 assert_select "status", open_note.status
483 assert_select "comments", :count => 1 do
484 assert_select "comment", :count => 1
489 get api_note_path(:id => open_note, :format => "rss")
490 assert_response :success
491 assert_equal "application/rss+xml", @response.media_type
492 assert_select "rss", :count => 1 do
493 assert_select "channel", :count => 1 do
494 assert_select "item", :count => 1 do
495 assert_select "link", note_url(open_note)
496 assert_select "guid", api_note_url(open_note)
497 assert_select "pubDate", open_note.created_at.to_fs(:rfc822)
498 assert_select "geo|lat", open_note.lat.to_s
499 assert_select "geo|long", open_note.lon.to_s
500 assert_select "georss|point", "#{open_note.lon} #{open_note.lon}"
505 get api_note_path(:id => open_note, :format => "json")
506 assert_response :success
507 assert_equal "application/json", @response.media_type
508 js = ActiveSupport::JSON.decode(@response.body)
510 assert_equal "Feature", js["type"]
511 assert_equal "Point", js["geometry"]["type"]
512 assert_equal open_note.lat, js["geometry"]["coordinates"][0]
513 assert_equal open_note.lon, js["geometry"]["coordinates"][1]
514 assert_equal open_note.id, js["properties"]["id"]
515 assert_equal api_note_url(open_note, :format => "json"), js["properties"]["url"]
516 assert_equal comment_api_note_url(open_note, :format => "json"), js["properties"]["comment_url"]
517 assert_equal close_api_note_url(open_note, :format => "json"), js["properties"]["close_url"]
518 assert_equal open_note.created_at.to_s, js["properties"]["date_created"]
519 assert_equal open_note.status, js["properties"]["status"]
521 get api_note_path(:id => open_note, :format => "gpx")
522 assert_response :success
523 assert_equal "application/gpx+xml", @response.media_type
524 assert_select "gpx", :count => 1 do
525 assert_select "wpt[lat='#{open_note.lat}'][lon='#{open_note.lon}']", :count => 1 do
526 assert_select "time", :count => 1
527 assert_select "name", "Note: #{open_note.id}"
528 assert_select "desc", :count => 1
529 assert_select "link[href='http://www.example.com/note/#{open_note.id}']", :count => 1
530 assert_select "extensions", :count => 1 do
531 assert_select "id", open_note.id.to_s
532 assert_select "url", api_note_url(open_note, :format => "gpx")
533 assert_select "comment_url", comment_api_note_url(open_note, :format => "gpx")
534 assert_select "close_url", close_api_note_url(open_note, :format => "gpx")
540 def test_show_hidden_comment
541 note_with_hidden_comment = create(:note) do |note|
542 create(:note_comment, :note => note, :body => "Valid comment for hidden note")
543 create(:note_comment, :note => note, :visible => false)
544 create(:note_comment, :note => note, :body => "Another valid comment for hidden note")
547 get api_note_path(:id => note_with_hidden_comment, :format => "json")
548 assert_response :success
549 js = ActiveSupport::JSON.decode(@response.body)
551 assert_equal "Feature", js["type"]
552 assert_equal note_with_hidden_comment.id, js["properties"]["id"]
553 assert_equal 2, js["properties"]["comments"].count
554 assert_equal "Valid comment for hidden note", js["properties"]["comments"][0]["text"]
555 assert_equal "Another valid comment for hidden note", js["properties"]["comments"][1]["text"]
559 get api_note_path(:id => 12345)
560 assert_response :not_found
562 get api_note_path(:id => create(:note, :status => "hidden"))
563 assert_response :gone
566 def test_destroy_success
567 open_note_with_comment = create(:note_with_comments)
569 moderator_user = create(:moderator_user)
571 delete api_note_path(:id => open_note_with_comment, :text => "This is a hide comment", :format => "json")
572 assert_response :unauthorized
574 auth_header = basic_authorization_header user.email, "test"
576 delete api_note_path(:id => open_note_with_comment, :text => "This is a hide comment", :format => "json"), :headers => auth_header
577 assert_response :forbidden
579 auth_header = basic_authorization_header moderator_user.email, "test"
581 delete api_note_path(:id => open_note_with_comment, :text => "This is a hide comment", :format => "json"), :headers => auth_header
582 assert_response :success
583 js = ActiveSupport::JSON.decode(@response.body)
585 assert_equal "Feature", js["type"]
586 assert_equal open_note_with_comment.id, js["properties"]["id"]
587 assert_equal "hidden", js["properties"]["status"]
588 assert_equal 2, js["properties"]["comments"].count
589 assert_equal "hidden", js["properties"]["comments"].last["action"]
590 assert_equal "This is a hide comment", js["properties"]["comments"].last["text"]
591 assert_equal moderator_user.display_name, js["properties"]["comments"].last["user"]
593 get api_note_path(:id => open_note_with_comment, :format => "json"), :headers => auth_header
594 assert_response :success
596 auth_header = basic_authorization_header user.email, "test"
598 get api_note_path(:id => open_note_with_comment, :format => "json"), :headers => auth_header
599 assert_response :gone
602 def test_destroy_fail
604 moderator_user = create(:moderator_user)
606 delete api_note_path(:id => 12345, :format => "json")
607 assert_response :unauthorized
609 auth_header = basic_authorization_header user.email, "test"
611 delete api_note_path(:id => 12345, :format => "json"), :headers => auth_header
612 assert_response :forbidden
614 auth_header = basic_authorization_header moderator_user.email, "test"
616 delete api_note_path(:id => 12345, :format => "json"), :headers => auth_header
617 assert_response :not_found
619 hidden_note_with_comment = create(:note_with_comments, :status => "hidden")
621 delete api_note_path(:id => hidden_note_with_comment, :format => "json"), :headers => auth_header
622 assert_response :gone
625 def test_index_success
626 position = (1.1 * GeoRecord::SCALE).to_i
627 create(:note_with_comments, :latitude => position, :longitude => position)
628 create(:note_with_comments, :latitude => position, :longitude => position)
630 get api_notes_path(:bbox => "1,1,1.2,1.2", :format => "rss")
631 assert_response :success
632 assert_equal "application/rss+xml", @response.media_type
633 assert_select "rss", :count => 1 do
634 assert_select "channel", :count => 1 do
635 assert_select "description", :text => /1\.2/, :count => 1
636 assert_select "item", :count => 2
640 get api_notes_path(:bbox => "1,1,1.2,1.2", :format => "json")
641 assert_response :success
642 assert_equal "application/json", @response.media_type
643 js = ActiveSupport::JSON.decode(@response.body)
645 assert_equal "FeatureCollection", js["type"]
646 assert_equal 2, js["features"].count
648 get api_notes_path(:bbox => "1,1,1.2,1.2", :format => "xml")
649 assert_response :success
650 assert_equal "application/xml", @response.media_type
651 assert_select "osm", :count => 1 do
652 assert_select "note", :count => 2
655 get api_notes_path(:bbox => "1,1,1.2,1.2", :format => "gpx")
656 assert_response :success
657 assert_equal "application/gpx+xml", @response.media_type
658 assert_select "gpx", :count => 1 do
659 assert_select "wpt", :count => 2
664 position = (1.1 * GeoRecord::SCALE).to_i
665 create(:note_with_comments, :latitude => position, :longitude => position)
666 create(:note_with_comments, :latitude => position, :longitude => position)
668 get api_notes_path(:bbox => "1,1,1.2,1.2", :limit => 1, :format => "rss")
669 assert_response :success
670 assert_equal "application/rss+xml", @response.media_type
671 assert_select "rss", :count => 1 do
672 assert_select "channel", :count => 1 do
673 assert_select "item", :count => 1
677 get api_notes_path(:bbox => "1,1,1.2,1.2", :limit => 1, :format => "json")
678 assert_response :success
679 assert_equal "application/json", @response.media_type
680 js = ActiveSupport::JSON.decode(@response.body)
682 assert_equal "FeatureCollection", js["type"]
683 assert_equal 1, js["features"].count
685 get api_notes_path(:bbox => "1,1,1.2,1.2", :limit => 1, :format => "xml")
686 assert_response :success
687 assert_equal "application/xml", @response.media_type
688 assert_select "osm", :count => 1 do
689 assert_select "note", :count => 1
692 get api_notes_path(:bbox => "1,1,1.2,1.2", :limit => 1, :format => "gpx")
693 assert_response :success
694 assert_equal "application/gpx+xml", @response.media_type
695 assert_select "gpx", :count => 1 do
696 assert_select "wpt", :count => 1
699 get api_notes_path(:bbox => "1,1,1.2,1.2", :limit => Settings.max_note_query_limit, :format => "rss")
700 assert_response :success
703 def test_index_empty_area
704 get api_notes_path(:bbox => "5,5,5.1,5.1", :format => "rss")
705 assert_response :success
706 assert_equal "application/rss+xml", @response.media_type
707 assert_select "rss", :count => 1 do
708 assert_select "channel", :count => 1 do
709 assert_select "item", :count => 0
713 get api_notes_path(:bbox => "5,5,5.1,5.1", :format => "json")
714 assert_response :success
715 assert_equal "application/json", @response.media_type
716 js = ActiveSupport::JSON.decode(@response.body)
718 assert_equal "FeatureCollection", js["type"]
719 assert_equal 0, js["features"].count
721 get api_notes_path(:bbox => "5,5,5.1,5.1", :format => "xml")
722 assert_response :success
723 assert_equal "application/xml", @response.media_type
724 assert_select "osm", :count => 1 do
725 assert_select "note", :count => 0
728 get api_notes_path(:bbox => "5,5,5.1,5.1", :format => "gpx")
729 assert_response :success
730 assert_equal "application/gpx+xml", @response.media_type
731 assert_select "gpx", :count => 1 do
732 assert_select "wpt", :count => 0
736 def test_index_large_area
737 get api_notes_path(:bbox => "-2.5,-2.5,2.5,2.5", :format => :json)
738 assert_response :success
739 assert_equal "application/json", @response.media_type
741 get api_notes_path(:l => "-2.5", :b => "-2.5", :r => "2.5", :t => "2.5", :format => :json)
742 assert_response :success
743 assert_equal "application/json", @response.media_type
745 get api_notes_path(:bbox => "-10,-10,12,12", :format => :json)
746 assert_response :bad_request
747 assert_equal "text/plain", @response.media_type
749 get api_notes_path(:l => "-10", :b => "-10", :r => "12", :t => "12", :format => :json)
750 assert_response :bad_request
751 assert_equal "text/plain", @response.media_type
754 def test_index_closed
755 create(:note_with_comments, :status => "closed", :closed_at => Time.now.utc - 5.days)
756 create(:note_with_comments, :status => "closed", :closed_at => Time.now.utc - 100.days)
757 create(:note_with_comments, :status => "hidden")
758 create(:note_with_comments)
760 # Open notes + closed in last 7 days
761 get api_notes_path(:bbox => "1,1,1.7,1.7", :closed => "7", :format => "json")
762 assert_response :success
763 assert_equal "application/json", @response.media_type
764 js = ActiveSupport::JSON.decode(@response.body)
766 assert_equal "FeatureCollection", js["type"]
767 assert_equal 2, js["features"].count
770 get api_notes_path(:bbox => "1,1,1.7,1.7", :closed => "0", :format => "json")
771 assert_response :success
772 assert_equal "application/json", @response.media_type
773 js = ActiveSupport::JSON.decode(@response.body)
775 assert_equal "FeatureCollection", js["type"]
776 assert_equal 1, js["features"].count
778 # Open notes + all closed notes
779 get api_notes_path(:bbox => "1,1,1.7,1.7", :closed => "-1", :format => "json")
780 assert_response :success
781 assert_equal "application/json", @response.media_type
782 js = ActiveSupport::JSON.decode(@response.body)
784 assert_equal "FeatureCollection", js["type"]
785 assert_equal 3, js["features"].count
788 def test_index_bad_params
789 get api_notes_path(:bbox => "-2.5,-2.5,2.5")
790 assert_response :bad_request
792 get api_notes_path(:bbox => "-2.5,-2.5,2.5,2.5,2.5")
793 assert_response :bad_request
795 get api_notes_path(:b => "-2.5", :r => "2.5", :t => "2.5")
796 assert_response :bad_request
798 get api_notes_path(:l => "-2.5", :r => "2.5", :t => "2.5")
799 assert_response :bad_request
801 get api_notes_path(:l => "-2.5", :b => "-2.5", :t => "2.5")
802 assert_response :bad_request
804 get api_notes_path(:l => "-2.5", :b => "-2.5", :r => "2.5")
805 assert_response :bad_request
807 get api_notes_path(:bbox => "1,1,1.7,1.7", :limit => "0", :format => "json")
808 assert_response :bad_request
810 get api_notes_path(:bbox => "1,1,1.7,1.7", :limit => Settings.max_note_query_limit + 1, :format => "json")
811 assert_response :bad_request
814 def test_search_success
815 create(:note_with_comments)
817 get search_api_notes_path(:q => "note comment", :format => "xml")
818 assert_response :success
819 assert_equal "application/xml", @response.media_type
820 assert_select "osm", :count => 1 do
821 assert_select "note", :count => 1
824 get search_api_notes_path(:q => "note comment", :format => "json")
825 assert_response :success
826 assert_equal "application/json", @response.media_type
827 js = ActiveSupport::JSON.decode(@response.body)
829 assert_equal "FeatureCollection", js["type"]
830 assert_equal 1, js["features"].count
832 get search_api_notes_path(:q => "note comment", :format => "rss")
833 assert_response :success
834 assert_equal "application/rss+xml", @response.media_type
835 assert_select "rss", :count => 1 do
836 assert_select "channel", :count => 1 do
837 assert_select "item", :count => 1
841 get search_api_notes_path(:q => "note comment", :format => "gpx")
842 assert_response :success
843 assert_equal "application/gpx+xml", @response.media_type
844 assert_select "gpx", :count => 1 do
845 assert_select "wpt", :count => 1
848 get search_api_notes_path(:q => "note comment", :limit => Settings.max_note_query_limit, :format => "xml")
849 assert_response :success
852 def test_search_by_display_name_success
855 create(:note) do |note|
856 create(:note_comment, :note => note, :author => user)
859 get search_api_notes_path(:display_name => user.display_name, :format => "xml")
860 assert_response :success
861 assert_equal "application/xml", @response.media_type
862 assert_select "osm", :count => 1 do
863 assert_select "note", :count => 1
866 get search_api_notes_path(:display_name => user.display_name, :format => "json")
867 assert_response :success
868 assert_equal "application/json", @response.media_type
869 js = ActiveSupport::JSON.decode(@response.body)
871 assert_equal "FeatureCollection", js["type"]
872 assert_equal 1, js["features"].count
874 get search_api_notes_path(:display_name => user.display_name, :format => "rss")
875 assert_response :success
876 assert_equal "application/rss+xml", @response.media_type
877 assert_select "rss", :count => 1 do
878 assert_select "channel", :count => 1 do
879 assert_select "item", :count => 1
883 get search_api_notes_path(:display_name => user.display_name, :format => "gpx")
884 assert_response :success
885 assert_equal "application/gpx+xml", @response.media_type
886 assert_select "gpx", :count => 1 do
887 assert_select "wpt", :count => 1
891 def test_search_by_user_success
894 create(:note) do |note|
895 create(:note_comment, :note => note, :author => user)
898 get search_api_notes_path(:user => user.id, :format => "xml")
899 assert_response :success
900 assert_equal "application/xml", @response.media_type
901 assert_select "osm", :count => 1 do
902 assert_select "note", :count => 1
905 get search_api_notes_path(:user => user.id, :format => "json")
906 assert_response :success
907 assert_equal "application/json", @response.media_type
908 js = ActiveSupport::JSON.decode(@response.body)
910 assert_equal "FeatureCollection", js["type"]
911 assert_equal 1, js["features"].count
913 get search_api_notes_path(:user => user.id, :format => "rss")
914 assert_response :success
915 assert_equal "application/rss+xml", @response.media_type
916 assert_select "rss", :count => 1 do
917 assert_select "channel", :count => 1 do
918 assert_select "item", :count => 1
922 get search_api_notes_path(:user => user.id, :format => "gpx")
923 assert_response :success
924 assert_equal "application/gpx+xml", @response.media_type
925 assert_select "gpx", :count => 1 do
926 assert_select "wpt", :count => 1
930 def test_search_no_match
931 create(:note_with_comments)
933 get search_api_notes_path(:q => "no match", :format => "xml")
934 assert_response :success
935 assert_equal "application/xml", @response.media_type
936 assert_select "osm", :count => 1 do
937 assert_select "note", :count => 0
940 get search_api_notes_path(:q => "no match", :format => "json")
941 assert_response :success
942 assert_equal "application/json", @response.media_type
943 js = ActiveSupport::JSON.decode(@response.body)
945 assert_equal "FeatureCollection", js["type"]
946 assert_equal 0, js["features"].count
948 get search_api_notes_path(:q => "no match", :format => "rss")
949 assert_response :success
950 assert_equal "application/rss+xml", @response.media_type
951 assert_select "rss", :count => 1 do
952 assert_select "channel", :count => 1 do
953 assert_select "item", :count => 0
957 get search_api_notes_path(:q => "no match", :format => "gpx")
958 assert_response :success
959 assert_equal "application/gpx+xml", @response.media_type
960 assert_select "gpx", :count => 1 do
961 assert_select "wpt", :count => 0
965 def test_search_by_time_no_match
966 create(:note_with_comments)
968 get search_api_notes_path(:from => "01.01.2010", :to => "01.10.2010", :format => "xml")
969 assert_response :success
970 assert_equal "application/xml", @response.media_type
971 assert_select "osm", :count => 1 do
972 assert_select "note", :count => 0
975 get search_api_notes_path(:from => "01.01.2010", :to => "01.10.2010", :format => "json")
976 assert_response :success
977 assert_equal "application/json", @response.media_type
978 js = ActiveSupport::JSON.decode(@response.body)
980 assert_equal "FeatureCollection", js["type"]
981 assert_equal 0, js["features"].count
983 get search_api_notes_path(:from => "01.01.2010", :to => "01.10.2010", :format => "rss")
984 assert_response :success
985 assert_equal "application/rss+xml", @response.media_type
986 assert_select "rss", :count => 1 do
987 assert_select "channel", :count => 1 do
988 assert_select "item", :count => 0
992 get search_api_notes_path(:from => "01.01.2010", :to => "01.10.2010", :format => "gpx")
993 assert_response :success
994 assert_equal "application/gpx+xml", @response.media_type
995 assert_select "gpx", :count => 1 do
996 assert_select "wpt", :count => 0
1000 def test_search_bad_params
1001 get search_api_notes_path(:q => "no match", :limit => "0", :format => "json")
1002 assert_response :bad_request
1004 get search_api_notes_path(:q => "no match", :limit => Settings.max_note_query_limit + 1, :format => "json")
1005 assert_response :bad_request
1007 get search_api_notes_path(:display_name => "non-existent")
1008 assert_response :bad_request
1010 get search_api_notes_path(:user => "-1")
1011 assert_response :bad_request
1013 get search_api_notes_path(:from => "wrong-date", :to => "wrong-date")
1014 assert_response :bad_request
1016 get search_api_notes_path(:from => "01.01.2010", :to => "2010.01.2010")
1017 assert_response :bad_request
1020 def test_feed_success
1021 position = (1.1 * GeoRecord::SCALE).to_i
1022 create(:note_with_comments, :latitude => position, :longitude => position)
1023 create(:note_with_comments, :latitude => position, :longitude => position)
1024 position = (1.5 * GeoRecord::SCALE).to_i
1025 create(:note_with_comments, :latitude => position, :longitude => position)
1026 create(:note_with_comments, :latitude => position, :longitude => position)
1028 get feed_api_notes_path(:format => "rss")
1029 assert_response :success
1030 assert_equal "application/rss+xml", @response.media_type
1031 assert_select "rss", :count => 1 do
1032 assert_select "channel", :count => 1 do
1033 assert_select "item", :count => 4
1037 get feed_api_notes_path(:bbox => "1,1,1.2,1.2", :format => "rss")
1038 assert_response :success
1039 assert_equal "application/rss+xml", @response.media_type
1040 assert_select "rss", :count => 1 do
1041 assert_select "channel", :count => 1 do
1042 assert_select "description", :text => /1\.2/, :count => 1
1043 assert_select "item", :count => 2
1047 get feed_api_notes_path(:bbox => "1,1,1.2,1.2", :limit => Settings.max_note_query_limit, :format => "rss")
1048 assert_response :success
1052 get feed_api_notes_path(:bbox => "1,1,1.2", :format => "rss")
1053 assert_response :bad_request
1055 get feed_api_notes_path(:bbox => "1,1,1.2,1.2,1.2", :format => "rss")
1056 assert_response :bad_request
1058 get feed_api_notes_path(:bbox => "1,1,1.2,1.2", :limit => "0", :format => "rss")
1059 assert_response :bad_request
1061 get feed_api_notes_path(:bbox => "1,1,1.2,1.2", :limit => Settings.max_note_query_limit + 1, :format => "rss")
1062 assert_response :bad_request