Restructure notes URLs according to standard rails conventions
authorTom Hughes <tom@compton.nu>
Sat, 10 Mar 2012 15:45:33 +0000 (15:45 +0000)
committerTom Hughes <tom@compton.nu>
Sat, 10 Mar 2012 17:04:57 +0000 (17:04 +0000)
21 files changed:
app/controllers/notes_controller.rb [moved from app/controllers/note_controller.rb with 96% similarity]
app/views/notes/_description.html.erb [moved from app/views/note/_description.html.erb with 100% similarity]
app/views/notes/_note.gpx.builder [moved from app/views/note/_note.gpx.builder with 100% similarity]
app/views/notes/_note.json.jsonify [moved from app/views/note/_note.json.jsonify with 100% similarity]
app/views/notes/_note.rss.builder [moved from app/views/note/_note.rss.builder with 100% similarity]
app/views/notes/_note.xml.builder [moved from app/views/note/_note.xml.builder with 100% similarity]
app/views/notes/_notes_paging_nav.html.erb [moved from app/views/note/_notes_paging_nav.html.erb with 100% similarity]
app/views/notes/_user.html.erb [moved from app/views/note/_user.html.erb with 100% similarity]
app/views/notes/feed.rss.builder [moved from app/views/note/rss.rss.builder with 100% similarity]
app/views/notes/index.gpx.builder [moved from app/views/note/list.gpx.builder with 100% similarity]
app/views/notes/index.json.jsonify [moved from app/views/note/list.json.jsonify with 100% similarity]
app/views/notes/index.rss.builder [moved from app/views/note/list.rss.builder with 100% similarity]
app/views/notes/index.xml.builder [moved from app/views/note/list.xml.builder with 100% similarity]
app/views/notes/mine.html.erb [moved from app/views/note/mine.html.erb with 100% similarity]
app/views/notes/show.gpx.builder [moved from app/views/note/read.gpx.builder with 100% similarity]
app/views/notes/show.json.jsonify [moved from app/views/note/read.json.jsonify with 100% similarity]
app/views/notes/show.rss.builder [moved from app/views/note/read.rss.builder with 100% similarity]
app/views/notes/show.xml.builder [moved from app/views/note/read.xml.builder with 100% similarity]
config/routes.rb
test/functional/browse_controller_test.rb
test/functional/notes_controller_test.rb [moved from test/functional/note_controller_test.rb with 53% similarity]

similarity index 96%
rename from app/controllers/note_controller.rb
rename to app/controllers/notes_controller.rb
index 1eb0350..fe3615d 100644 (file)
@@ -1,4 +1,4 @@
-class NoteController < ApplicationController
+class NotesController < ApplicationController
 
   layout 'site', :only => [:mine]
 
@@ -11,7 +11,7 @@ class NoteController < ApplicationController
 
   ##
   # Return a list of notes in a given area
-  def list
+  def index
     # Figure out the bbox - we prefer a bbox argument but also
     # support the old, deprecated, method with four arguments
     if params[:bbox]
@@ -93,7 +93,7 @@ class NoteController < ApplicationController
 
   ##
   # Add a comment to an existing note
-  def update
+  def comment
     # Check the arguments are sane
     raise OSM::APIBadUserInput.new("No id was given") unless params[:id]
     raise OSM::APIBadUserInput.new("No text was given") unless params[:text]
@@ -145,7 +145,7 @@ class NoteController < ApplicationController
 
   ##
   # Get a feed of recent notes and comments
-  def rss
+  def feed
     # Get any conditions that need to be applied
     notes = closed_condition(Note.scoped)
 
@@ -170,7 +170,7 @@ class NoteController < ApplicationController
 
   ##
   # Read a note
-  def read
+  def show
     # Check the arguments are sane
     raise OSM::APIBadUserInput.new("No id was given") unless params[:id]
 
@@ -190,7 +190,7 @@ class NoteController < ApplicationController
 
   ##
   # Delete (hide) a note
-  def delete
+  def destroy
     # Check the arguments are sane
     raise OSM::APIBadUserInput.new("No id was given") unless params[:id]
 
@@ -230,10 +230,10 @@ class NoteController < ApplicationController
 
     # Render the result
     respond_to do |format|
-      format.rss { render :action => :list }
-      format.xml { render :action => :list }
-      format.json { render :action => :list }
-      format.gpx { render :action => :list }
+      format.rss { render :action => :index }
+      format.xml { render :action => :index }
+      format.json { render :action => :index }
+      format.gpx { render :action => :index }
     end
   end
 
index e466fc3..a3d503b 100644 (file)
@@ -74,19 +74,25 @@ OpenStreetMap::Application.routes.draw do
   match 'api/0.6/swf/trackpoints' => 'swf#trackpoints', :via => :get
 
   # Map notes API
-  match 'api/0.6/notes' => 'note#list', :format => :xml
-  match 'api/0.6/notes/search' => 'note#search', :format => :xml
-  match 'api/0.6/notes/rss'  => 'note#rss', :format => :rss
-  match 'api/0.6/note/create' => 'note#create'
-  match 'api/0.6/note/:id/comment' => 'note#update', :id => /\d+/
-  match 'api/0.6/note/:id/close' => 'note#close', :id => /\d+/
-  match 'api/0.6/note/:id' => 'note#read', :via => :get, :id => /\d+/, :format => :xml
-  match 'api/0.6/note/:id' => 'note#delete', :via => :delete, :id => /\d+/
-  match 'api/0.6/notes/addPOIexec' => 'note#create'
-  match 'api/0.6/notes/closePOIexec' => 'note#close'
-  match 'api/0.6/notes/editPOIexec' => 'note#update'
-  match 'api/0.6/notes/getGPX' => 'note#list', :format => :gpx
-  match 'api/0.6/notes/getRSSfeed' => 'note#rss', :format => :rss
+  scope "api/0.6" do
+    resources :notes, :except => [ :new, :edit, :update ], :constraints => { :id => /\d+/ }, :defaults => { :format => "xml" } do
+      collection do
+        get 'search'
+        get 'feed', :defaults => { :format => "rss" }
+      end
+
+      member do
+        post 'comment'
+        post 'close'
+      end
+    end
+
+    match 'notes/addPOIexec' => 'notes#create', :via => :post
+    match 'notes/closePOIexec' => 'notes#close', :via => :post
+    match 'notes/editPOIexec' => 'notes#comment', :via => :post
+    match 'notes/getGPX' => 'notes#index', :via => :get, :format => "gpx"
+    match 'notes/getRSSfeed' => 'notes#feed', :via => :get, :format => "rss"
+  end
 
   # Data browsing
   match '/browse/start' => 'browse#start', :via => :get
@@ -100,7 +106,7 @@ OpenStreetMap::Application.routes.draw do
   match '/browse/note/:id' => 'browse#note', :via => :get, :id => /\d+/
   match '/user/:display_name/edits' => 'changeset#list', :via => :get
   match '/user/:display_name/edits/feed' => 'changeset#feed', :via => :get, :format => :atom
-  match '/user/:display_name/notes' => 'note#mine', :via => :get
+  match '/user/:display_name/notes' => 'notes#mine', :via => :get
   match '/browse/friends' => 'changeset#list', :via => :get, :friends => true, :as => "friend_changesets"
   match '/browse/nearby' => 'changeset#list', :via => :get, :nearby => true, :as => "nearby_changesets"
   match '/browse/changesets' => 'changeset#list', :via => :get
index 04b690e..3e4c07d 100644 (file)
@@ -39,6 +39,10 @@ class BrowseControllerTest < ActionController::TestCase
       { :path => "/browse/changeset/1", :method => :get },
       { :controller => "browse", :action => "changeset", :id => "1" }
     )
+    assert_routing(
+      { :path => "/browse/note/1", :method => :get },
+      { :controller => "browse", :action => "note", :id => "1" }
+    )
   end
 
   def test_start
similarity index 53%
rename from test/functional/note_controller_test.rb
rename to test/functional/notes_controller_test.rb
index 033cef8..1c50ee8 100644 (file)
@@ -1,8 +1,122 @@
 require File.dirname(__FILE__) + '/../test_helper'
 
-class NoteControllerTest < ActionController::TestCase
+class NotesControllerTest < ActionController::TestCase
   fixtures :users, :notes, :note_comments
 
+  ##
+  # test all routes which lead to this controller
+  def test_routes
+    assert_routing(
+      { :path => "/api/0.6/notes", :method => :post },
+      { :controller => "notes", :action => "create", :format => "xml" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/1", :method => :get },
+      { :controller => "notes", :action => "show", :id => "1", :format => "xml" }
+    )
+    assert_recognizes(
+      { :controller => "notes", :action => "show", :id => "1", :format => "xml" },
+      { :path => "/api/0.6/notes/1.xml", :method => :get }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/1.rss", :method => :get },
+      { :controller => "notes", :action => "show", :id => "1", :format => "rss" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/1.json", :method => :get },
+      { :controller => "notes", :action => "show", :id => "1", :format => "json" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/1.gpx", :method => :get },
+      { :controller => "notes", :action => "show", :id => "1", :format => "gpx" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/1/comment", :method => :post },
+      { :controller => "notes", :action => "comment", :id => "1", :format => "xml" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/1/close", :method => :post },
+      { :controller => "notes", :action => "close", :id => "1", :format => "xml" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/1", :method => :delete },
+      { :controller => "notes", :action => "destroy", :id => "1", :format => "xml" }
+    )
+
+    assert_routing(
+      { :path => "/api/0.6/notes", :method => :get },
+      { :controller => "notes", :action => "index", :format => "xml" }
+    )
+    assert_recognizes(
+      { :controller => "notes", :action => "index", :format => "xml" },
+      { :path => "/api/0.6/notes.xml", :method => :get }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes.rss", :method => :get },
+      { :controller => "notes", :action => "index", :format => "rss" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes.json", :method => :get },
+      { :controller => "notes", :action => "index", :format => "json" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes.gpx", :method => :get },
+      { :controller => "notes", :action => "index", :format => "gpx" }
+    )
+
+    assert_routing(
+      { :path => "/api/0.6/notes/search", :method => :get },
+      { :controller => "notes", :action => "search", :format => "xml" }
+    )
+    assert_recognizes(
+      { :controller => "notes", :action => "search", :format => "xml" },
+      { :path => "/api/0.6/notes/search.xml", :method => :get }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/search.rss", :method => :get },
+      { :controller => "notes", :action => "search", :format => "rss" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/search.json", :method => :get },
+      { :controller => "notes", :action => "search", :format => "json" }
+    )
+    assert_routing(
+      { :path => "/api/0.6/notes/search.gpx", :method => :get },
+      { :controller => "notes", :action => "search", :format => "gpx" }
+    )
+
+    assert_routing(
+      { :path => "/api/0.6/notes/feed", :method => :get },
+      { :controller => "notes", :action => "feed", :format => "rss" }
+    )
+
+    assert_recognizes(
+      { :controller => "notes", :action => "create" },
+      { :path => "/api/0.6/notes/addPOIexec", :method => :post }
+    )
+    assert_recognizes(
+      { :controller => "notes", :action => "close" },
+      { :path => "/api/0.6/notes/closePOIexec", :method => :post }
+    )
+    assert_recognizes(
+      { :controller => "notes", :action => "comment" },
+      { :path => "/api/0.6/notes/editPOIexec", :method => :post }
+    )
+    assert_recognizes(
+      { :controller => "notes", :action => "index", :format => "gpx" },
+      { :path => "/api/0.6/notes/getGPX", :method => :get }
+    )
+    assert_recognizes(
+      { :controller => "notes", :action => "feed", :format => "rss" },
+      { :path => "/api/0.6/notes/getRSSfeed", :method => :get }
+    )
+
+    assert_routing(
+      { :path => "/user/username/notes", :method => :get },
+      { :controller => "notes", :action => "mine", :display_name => "username" }
+    )
+  end
+
   def test_note_create_success
     assert_difference('Note.count') do
       assert_difference('NoteComment.count') do
@@ -12,7 +126,7 @@ class NoteControllerTest < ActionController::TestCase
     assert_response :success
     id = @response.body.sub(/ok/,"").to_i
 
-    get :read, {:id => id, :format => 'json'}
+    get :show, {:id => id, :format => 'json'}
     assert_response :success
     js = ActiveSupport::JSON.decode(@response.body)
     assert_not_nil js
@@ -66,11 +180,11 @@ class NoteControllerTest < ActionController::TestCase
 
   def test_note_comment_create_success
     assert_difference('NoteComment.count') do
-      post :update, {:id => notes(:open_note_with_comment).id, :name => "new_tester2", :text => "This is an additional comment"}
+      post :comment, {:id => notes(:open_note_with_comment).id, :name => "new_tester2", :text => "This is an additional comment"}
     end
     assert_response :success
 
-    get :read, {:id => notes(:open_note_with_comment).id, :format => 'json'}
+    get :show, {:id => notes(:open_note_with_comment).id, :format => 'json'}
     assert_response :success
     js = ActiveSupport::JSON.decode(@response.body)
     assert_not_nil js
@@ -85,22 +199,22 @@ class NoteControllerTest < ActionController::TestCase
 
   def test_note_comment_create_fail
     assert_no_difference('NoteComment.count') do
-      post :update, {:name => "new_tester2", :text => "This is an additional comment"}
+      post :comment, {:name => "new_tester2", :text => "This is an additional comment"}
     end
     assert_response :bad_request
 
     assert_no_difference('NoteComment.count') do
-      post :update, {:id => notes(:open_note_with_comment).id, :name => "new_tester2"}
+      post :comment, {:id => notes(:open_note_with_comment).id, :name => "new_tester2"}
     end
     assert_response :bad_request
 
     assert_no_difference('NoteComment.count') do
-      post :update, {:id => 12345, :name => "new_tester2", :text => "This is an additional comment"}
+      post :comment, {:id => 12345, :name => "new_tester2", :text => "This is an additional comment"}
     end
     assert_response :not_found
 
     assert_no_difference('NoteComment.count') do
-      post :update, {:id => notes(:hidden_note_with_comment).id, :name => "new_tester2", :text => "This is an additional comment"}
+      post :comment, {:id => notes(:hidden_note_with_comment).id, :name => "new_tester2", :text => "This is an additional comment"}
     end
     assert_response :gone
   end
@@ -109,7 +223,7 @@ class NoteControllerTest < ActionController::TestCase
     post :close, {:id => notes(:open_note_with_comment).id}
     assert_response :success
 
-    get :read, {:id => notes(:open_note_with_comment).id, :format => 'json'}
+    get :show, {:id => notes(:open_note_with_comment).id, :format => 'json'}
     assert_response :success
     js = ActiveSupport::JSON.decode(@response.body)
     assert_not_nil js
@@ -134,29 +248,25 @@ class NoteControllerTest < ActionController::TestCase
   end
 
   def test_note_read_success
-#    get :read, {:id => notes(:open_note).id}
-#    assert_response :success      
-#    assert_equal "application/xml", @response.content_type
-
-    get :read, {:id => notes(:open_note).id, :format => "xml"}
+    get :show, {:id => notes(:open_note).id, :format => "xml"}
     assert_response :success
     assert_equal "application/xml", @response.content_type
 
-    get :read, {:id => notes(:open_note).id, :format => "rss"}
+    get :show, {:id => notes(:open_note).id, :format => "rss"}
     assert_response :success
     assert_equal "application/rss+xml", @response.content_type
 
-    get :read, {:id => notes(:open_note).id, :format => "json"}
+    get :show, {:id => notes(:open_note).id, :format => "json"}
     assert_response :success
     assert_equal "application/json", @response.content_type
 
-    get :read, {:id => notes(:open_note).id, :format => "gpx"}
+    get :show, {:id => notes(:open_note).id, :format => "gpx"}
     assert_response :success
     assert_equal "application/gpx+xml", @response.content_type
   end
 
   def test_note_read_hidden_comment
-    get :read, {:id => notes(:note_with_hidden_comment).id, :format => 'json'}
+    get :show, {:id => notes(:note_with_hidden_comment).id, :format => 'json'}
     assert_response :success
     js = ActiveSupport::JSON.decode(@response.body)
     assert_not_nil js
@@ -167,73 +277,73 @@ class NoteControllerTest < ActionController::TestCase
   end
 
   def test_note_read_fail
-    post :read
+    post :show
     assert_response :bad_request
 
-    get :read, {:id => 12345}
+    get :show, {:id => 12345}
     assert_response :not_found
 
-    get :read, {:id => notes(:hidden_note_with_comment).id}
+    get :show, {:id => notes(:hidden_note_with_comment).id}
     assert_response :gone
   end
 
   def test_note_delete_success
-    delete :delete, {:id => notes(:open_note_with_comment).id}
+    delete :destroy, {:id => notes(:open_note_with_comment).id}
     assert_response :success
 
-    get :read, {:id => notes(:open_note_with_comment).id, :format => 'json'}
+    get :show, {:id => notes(:open_note_with_comment).id, :format => 'json'}
     assert_response :gone
   end
 
   def test_note_delete_fail
-    delete :delete
+    delete :destroy
     assert_response :bad_request
 
-    delete :delete, {:id => 12345}
+    delete :destroy, {:id => 12345}
     assert_response :not_found
 
-    delete :delete, {:id => notes(:hidden_note_with_comment).id}
+    delete :destroy, {:id => notes(:hidden_note_with_comment).id}
     assert_response :gone
   end
 
   def test_get_notes_success
-#    get :list, {:bbox => '1,1,1.2,1.2'}
+#    get :index, {:bbox => '1,1,1.2,1.2'}
 #    assert_response :success
 #    assert_equal "text/javascript", @response.content_type
 
-    get :list, {:bbox => '1,1,1.2,1.2', :format => 'rss'}
+    get :index, {:bbox => '1,1,1.2,1.2', :format => 'rss'}
     assert_response :success
     assert_equal "application/rss+xml", @response.content_type
 
-    get :list, {:bbox => '1,1,1.2,1.2', :format => 'json'}
+    get :index, {:bbox => '1,1,1.2,1.2', :format => 'json'}
     assert_response :success
     assert_equal "application/json", @response.content_type
 
-    get :list, {:bbox => '1,1,1.2,1.2', :format => 'xml'}
+    get :index, {:bbox => '1,1,1.2,1.2', :format => 'xml'}
     assert_response :success
     assert_equal "application/xml", @response.content_type
 
-    get :list, {:bbox => '1,1,1.2,1.2', :format => 'gpx'}
+    get :index, {:bbox => '1,1,1.2,1.2', :format => 'gpx'}
     assert_response :success
     assert_equal "application/gpx+xml", @response.content_type
   end
 
   def test_get_notes_large_area
-#    get :list, {:bbox => '-2.5,-2.5,2.5,2.5'}
+#    get :index, {:bbox => '-2.5,-2.5,2.5,2.5'}
 #    assert_response :success
 
-#    get :list, {:l => '-2.5', :b => '-2.5', :r => '2.5', :t => '2.5'}
+#    get :index, {:l => '-2.5', :b => '-2.5', :r => '2.5', :t => '2.5'}
 #    assert_response :success
 
-    get :list, {:bbox => '-10,-10,12,12'}
+    get :index, {:bbox => '-10,-10,12,12'}
     assert_response :bad_request
 
-    get :list, {:l => '-10', :b => '-10', :r => '12', :t => '12'}
+    get :index, {:l => '-10', :b => '-10', :r => '12', :t => '12'}
     assert_response :bad_request
   end
 
   def test_get_notes_closed
-    get :list, {:bbox => '1,1,1.7,1.7', :closed => '7', :format => 'json'}
+    get :index, {:bbox => '1,1,1.7,1.7', :closed => '7', :format => 'json'}
     assert_response :success
     assert_equal "application/json", @response.content_type
     js = ActiveSupport::JSON.decode(@response.body)
@@ -241,7 +351,7 @@ class NoteControllerTest < ActionController::TestCase
     assert_equal "FeatureCollection", js["type"]
     assert_equal 4, js["features"].count
 
-    get :list, {:bbox => '1,1,1.7,1.7', :closed => '0', :format => 'json'}
+    get :index, {:bbox => '1,1,1.7,1.7', :closed => '0', :format => 'json'}
     assert_response :success
     assert_equal "application/json", @response.content_type
     js = ActiveSupport::JSON.decode(@response.body)
@@ -249,7 +359,7 @@ class NoteControllerTest < ActionController::TestCase
     assert_equal "FeatureCollection", js["type"]
     assert_equal 4, js["features"].count
 
-    get :list, {:bbox => '1,1,1.7,1.7', :closed => '-1', :format => 'json'}
+    get :index, {:bbox => '1,1,1.7,1.7', :closed => '-1', :format => 'json'}
     assert_response :success
     assert_equal "application/json", @response.content_type
     js = ActiveSupport::JSON.decode(@response.body)
@@ -259,30 +369,26 @@ class NoteControllerTest < ActionController::TestCase
   end
 
   def test_get_notes_bad_params
-    get :list, {:bbox => '-2.5,-2.5,2.5'}
+    get :index, {:bbox => '-2.5,-2.5,2.5'}
     assert_response :bad_request
 
-    get :list, {:bbox => '-2.5,-2.5,2.5,2.5,2.5'}
+    get :index, {:bbox => '-2.5,-2.5,2.5,2.5,2.5'}
     assert_response :bad_request
 
-    get :list, {:b => '-2.5', :r => '2.5', :t => '2.5'}
+    get :index, {:b => '-2.5', :r => '2.5', :t => '2.5'}
     assert_response :bad_request
 
-    get :list, {:l => '-2.5', :r => '2.5', :t => '2.5'}
+    get :index, {:l => '-2.5', :r => '2.5', :t => '2.5'}
     assert_response :bad_request
 
-    get :list, {:l => '-2.5', :b => '-2.5', :t => '2.5'}
+    get :index, {:l => '-2.5', :b => '-2.5', :t => '2.5'}
     assert_response :bad_request
 
-    get :list, {:l => '-2.5', :b => '-2.5', :r => '2.5'}
+    get :index, {:l => '-2.5', :b => '-2.5', :r => '2.5'}
     assert_response :bad_request
   end
 
   def test_search_success
-#    get :search, {:q => 'note 1'}
-#    assert_response :success
-#    assert_equal "text/javascript", @response.content_type
-
     get :search, {:q => 'note 1', :format => 'xml'}
     assert_response :success
     assert_equal "application/xml", @response.content_type
@@ -306,20 +412,20 @@ class NoteControllerTest < ActionController::TestCase
   end
 
   def test_rss_success
-#    get :rss
-#    assert_response :success
-#    assert_equal "application/rss+xml", @response.content_type
+    get :feed, {:format => 'rss'}
+    assert_response :success
+    assert_equal "application/rss+xml", @response.content_type
 
-#    get :rss, {:bbox=>'1,1,1.2,1.2'}
-#    assert_response :success  
-#    assert_equal "application/rss+xml", @response.content_type
+    get :feed, {:bbox=>'1,1,1.2,1.2', :format => 'rss'}
+    assert_response :success   
+    assert_equal "application/rss+xml", @response.content_type
   end
 
   def test_rss_fail
-    get :rss, {:bbox=>'1,1,1.2'}
+    get :feed, {:bbox=>'1,1,1.2'}
     assert_response :bad_request
 
-    get :rss, {:bbox=>'1,1,1.2,1.2,1.2'}
+    get :feed, {:bbox=>'1,1,1.2,1.2,1.2'}
     assert_response :bad_request
   end