diff --git a/app/controllers/comments_controller.rb b/app/controllers/comments_controller.rb new file mode 100644 index 00000000..c0d524a2 --- /dev/null +++ b/app/controllers/comments_controller.rb @@ -0,0 +1,30 @@ +class CommentsController < ApplicationController + default_search_scope :news + model_object News + before_filter :find_model_object + before_filter :find_project_from_association + before_filter :authorize + + verify :method => :post, :only => :create, :render => {:nothing => true, :status => :method_not_allowed } + def create + @comment = Comment.new(params[:comment]) + @comment.author = User.current + if @news.comments << @comment + flash[:notice] = l(:label_comment_added) + end + + redirect_to :controller => 'news', :action => 'show', :id => @news + end + + private + + # ApplicationController's find_model_object sets it based on the controller + # name so it needs to be overriden and set to @news instead + def find_model_object + super + @news = @object + @comment = nil + @news + end + +end diff --git a/app/controllers/news_controller.rb b/app/controllers/news_controller.rb index 5a1d36e0..d15ae329 100644 --- a/app/controllers/news_controller.rb +++ b/app/controllers/news_controller.rb @@ -73,18 +73,6 @@ class NewsController < ApplicationController end end - def add_comment - @comment = Comment.new(params[:comment]) - @comment.author = User.current - if @news.comments << @comment - flash[:notice] = l(:label_comment_added) - redirect_to :action => 'show', :id => @news - else - show - render :action => 'show' - end - end - def destroy_comment @news.comments.find(params[:comment_id]).destroy redirect_to :action => 'show', :id => @news diff --git a/app/views/news/show.rhtml b/app/views/news/show.rhtml index 851ef3f7..9b8f2510 100644 --- a/app/views/news/show.rhtml +++ b/app/views/news/show.rhtml @@ -47,9 +47,9 @@ <% end if @comments.any? %> -<% if authorize_for 'news', 'add_comment' %> +<% if authorize_for 'comments', 'create' %>

<%= toggle_link l(:label_comment_add), "add_comment_form", :focus => "comment_comments" %>

-<% form_tag({:action => 'add_comment', :id => @news}, :id => "add_comment_form", :style => "display:none;") do %> +<% form_tag({:controller => 'comments', :action => 'create', :id => @news}, :id => "add_comment_form", :style => "display:none;") do %>
<%= text_area 'comment', 'comments', :cols => 80, :rows => 15, :class => 'wiki-edit' %> <%= wikitoolbar_for 'comment_comments' %> diff --git a/config/routes.rb b/config/routes.rb index 2950cba2..6c765dab 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -152,6 +152,8 @@ ActionController::Routing::Routes.draw do |map| news_actions.connect 'news/:id/destroy', :action => 'destroy' end news_routes.connect 'news/:id/edit', :action => 'update', :conditions => {:method => :put} + + news_routes.connect 'news/:id/comments', :controller => 'comments', :action => 'create', :conditions => {:method => :post} end map.connect 'projects/:id/members/new', :controller => 'members', :action => 'new' diff --git a/lib/redmine.rb b/lib/redmine.rb index a7417df8..198d3730 100644 --- a/lib/redmine.rb +++ b/lib/redmine.rb @@ -93,7 +93,7 @@ Redmine::AccessControl.map do |map| map.project_module :news do |map| map.permission :manage_news, {:news => [:new, :create, :edit, :update, :destroy, :destroy_comment]}, :require => :member map.permission :view_news, {:news => [:index, :show]}, :public => true - map.permission :comment_news, {:news => :add_comment} + map.permission :comment_news, {:comments => :create} end map.project_module :documents do |map| diff --git a/test/functional/comments_controller_test.rb b/test/functional/comments_controller_test.rb new file mode 100644 index 00000000..1a9d628d --- /dev/null +++ b/test/functional/comments_controller_test.rb @@ -0,0 +1,46 @@ +# redMine - project management software +# Copyright (C) 2006-2007 Jean-Philippe Lang +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + +require File.dirname(__FILE__) + '/../test_helper' + +class CommentsControllerTest < ActionController::TestCase + fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules, :news, :comments + + def setup + User.current = nil + end + + def test_add_comment + @request.session[:user_id] = 2 + post :create, :id => 1, :comment => { :comments => 'This is a test comment' } + assert_redirected_to 'news/1' + + comment = News.find(1).comments.find(:first, :order => 'created_on DESC') + assert_not_nil comment + assert_equal 'This is a test comment', comment.comments + assert_equal User.find(2), comment.author + end + + def test_empty_comment_should_not_be_added + @request.session[:user_id] = 2 + assert_no_difference 'Comment.count' do + post :create, :id => 1, :comment => { :comments => '' } + assert_response :redirect + assert_redirected_to 'news/1' + end + end +end diff --git a/test/functional/news_controller_test.rb b/test/functional/news_controller_test.rb index 5f00fd91..ddc8b0c2 100644 --- a/test/functional/news_controller_test.rb +++ b/test/functional/news_controller_test.rb @@ -111,26 +111,6 @@ class NewsControllerTest < ActionController::TestCase :content => /1 error/ end - def test_add_comment - @request.session[:user_id] = 2 - post :add_comment, :id => 1, :comment => { :comments => 'This is a NewsControllerTest comment' } - assert_redirected_to 'news/1' - - comment = News.find(1).comments.find(:first, :order => 'created_on DESC') - assert_not_nil comment - assert_equal 'This is a NewsControllerTest comment', comment.comments - assert_equal User.find(2), comment.author - end - - def test_empty_comment_should_not_be_added - @request.session[:user_id] = 2 - assert_no_difference 'Comment.count' do - post :add_comment, :id => 1, :comment => { :comments => '' } - assert_response :success - assert_template 'show' - end - end - def test_destroy_comment comments_count = News.find(1).comments.size @request.session[:user_id] = 2 diff --git a/test/integration/routing_test.rb b/test/integration/routing_test.rb index 0daaad6d..4ce8fe4a 100644 --- a/test/integration/routing_test.rb +++ b/test/integration/routing_test.rb @@ -160,7 +160,8 @@ class RoutingTest < ActionController::IntegrationTest should_route :post, "/projects/567/news", :controller => 'news', :action => 'create', :project_id => '567' should_route :post, "/news/567/destroy", :controller => 'news', :action => 'destroy', :id => '567' - + should_route :post, "/news/567/comments", :controller => 'comments', :action => 'create', :id => '567' + should_route :put, "/news/567/edit", :controller => 'news', :action => 'update', :id => '567' end