765f7abc60
Patch supplied by commits from Gerrit Kaiser on Github. Existing routes will still work (backwards compatible) but any new urls will be generated using the new routing rules. Changes listed below: * made the URLs for some project tabs and project settings follow the new rails RESTful conventions of /collection/:id/subcollection/:sub_id * prettier URL for project roadmap * more nice project URLs * use GET for filtering form * prettified URLs used on issues tab * custom route for activity atom feeds * prettier repository urls * fixed broken route definition * fixed failing tests for issuecontroller that were hardcoding the url string * more RESTful routes for boards and messages * RESTful routes for wiki pages * RESTful routes for documents * moved old routes that are retained for compatibility to the bottom and grouped them together * added RESTful URIs for issues * RESTfulness for the news section * fixed route order * changed hardcoded URLs in tests * fixed badly written tests * fixed forgotten parameter in routes * changed hardcoded URLS to new scheme * changed project add url to the standard POST to collection * create new issue by POSTing to collection * changed hardcoded URLs in integrations tests * made project add form work again * restful routes for project deletion * prettier routes for project (un)archival * made routes table more readable * fixed note quoting * user routing * fixed bug * always sort by GET * Fixed: cross-project issue list should not show issues of projects for which the issue tracking module was disabled. * prettified URLs used on issues tab * urls for time log * fixed reply routing * eliminate revision query paremeter for diff and entry actions * fixed test failures with hard-coded urls * ensure ajax links always use get * refactored ajax link generation into separate method #1901 git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2317 e93f8b46-1217-0410-a6f0-8f06a7374b81
212 lines
6.7 KiB
Ruby
212 lines
6.7 KiB
Ruby
# 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'
|
|
require 'news_controller'
|
|
|
|
# Re-raise errors caught by the controller.
|
|
class NewsController; def rescue_action(e) raise e end; end
|
|
|
|
class NewsControllerTest < Test::Unit::TestCase
|
|
fixtures :projects, :users, :roles, :members, :enabled_modules, :news, :comments
|
|
|
|
def setup
|
|
@controller = NewsController.new
|
|
@request = ActionController::TestRequest.new
|
|
@response = ActionController::TestResponse.new
|
|
User.current = nil
|
|
end
|
|
|
|
def test_index_routing
|
|
assert_routing(
|
|
{:method => :get, :path => '/news'},
|
|
:controller => 'news', :action => 'index'
|
|
)
|
|
end
|
|
|
|
def test_index_routing_formatted
|
|
assert_routing(
|
|
{:method => :get, :path => '/news.atom'},
|
|
:controller => 'news', :action => 'index', :format => 'atom'
|
|
)
|
|
end
|
|
|
|
def test_index
|
|
get :index
|
|
assert_response :success
|
|
assert_template 'index'
|
|
assert_not_nil assigns(:newss)
|
|
assert_nil assigns(:project)
|
|
end
|
|
|
|
def test_index_with_project_routing
|
|
assert_routing(
|
|
{:method => :get, :path => '/projects/567/news'},
|
|
:controller => 'news', :action => 'index', :project_id => '567'
|
|
)
|
|
end
|
|
|
|
def test_index_with_project_routing_formatted
|
|
assert_routing(
|
|
{:method => :get, :path => '/projects/567/news.atom'},
|
|
:controller => 'news', :action => 'index', :project_id => '567', :format => 'atom'
|
|
)
|
|
end
|
|
|
|
def test_index_with_project
|
|
get :index, :project_id => 1
|
|
assert_response :success
|
|
assert_template 'index'
|
|
assert_not_nil assigns(:newss)
|
|
end
|
|
|
|
def test_show_routing
|
|
assert_routing(
|
|
{:method => :get, :path => '/news/2'},
|
|
:controller => 'news', :action => 'show', :id => '2'
|
|
)
|
|
end
|
|
|
|
def test_show
|
|
get :show, :id => 1
|
|
assert_response :success
|
|
assert_template 'show'
|
|
assert_tag :tag => 'h2', :content => /eCookbook first release/
|
|
end
|
|
|
|
def test_show_not_found
|
|
get :show, :id => 999
|
|
assert_response 404
|
|
end
|
|
|
|
def test_new_routing
|
|
assert_routing(
|
|
{:method => :get, :path => '/projects/567/news/new'},
|
|
:controller => 'news', :action => 'new', :project_id => '567'
|
|
)
|
|
assert_recognizes(
|
|
{:controller => 'news', :action => 'new', :project_id => '567'},
|
|
{:method => :post, :path => '/projects/567/news'}
|
|
)
|
|
end
|
|
|
|
def test_get_new
|
|
@request.session[:user_id] = 2
|
|
get :new, :project_id => 1
|
|
assert_response :success
|
|
assert_template 'new'
|
|
end
|
|
|
|
def test_post_new
|
|
@request.session[:user_id] = 2
|
|
post :new, :project_id => 1, :news => { :title => 'NewsControllerTest',
|
|
:description => 'This is the description',
|
|
:summary => '' }
|
|
assert_redirected_to 'projects/ecookbook/news'
|
|
|
|
news = News.find_by_title('NewsControllerTest')
|
|
assert_not_nil news
|
|
assert_equal 'This is the description', news.description
|
|
assert_equal User.find(2), news.author
|
|
assert_equal Project.find(1), news.project
|
|
end
|
|
|
|
def test_edit_routing
|
|
assert_routing(
|
|
{:method => :get, :path => '/news/234'},
|
|
:controller => 'news', :action => 'show', :id => '234'
|
|
)
|
|
assert_recognizes(#TODO: PUT to news URI instead, need to modify form
|
|
{:controller => 'news', :action => 'edit', :id => '567'},
|
|
{:method => :post, :path => '/news/567/edit'}
|
|
)
|
|
end
|
|
|
|
def test_get_edit
|
|
@request.session[:user_id] = 2
|
|
get :edit, :id => 1
|
|
assert_response :success
|
|
assert_template 'edit'
|
|
end
|
|
|
|
def test_post_edit
|
|
@request.session[:user_id] = 2
|
|
post :edit, :id => 1, :news => { :description => 'Description changed by test_post_edit' }
|
|
assert_redirected_to 'news/show/1'
|
|
news = News.find(1)
|
|
assert_equal 'Description changed by test_post_edit', news.description
|
|
end
|
|
|
|
def test_post_new_with_validation_failure
|
|
@request.session[:user_id] = 2
|
|
post :new, :project_id => 1, :news => { :title => '',
|
|
:description => 'This is the description',
|
|
:summary => '' }
|
|
assert_response :success
|
|
assert_template 'new'
|
|
assert_not_nil assigns(:news)
|
|
assert assigns(:news).new_record?
|
|
assert_tag :tag => 'div', :attributes => { :id => 'errorExplanation' },
|
|
: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/show/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_destroy_comment
|
|
comments_count = News.find(1).comments.size
|
|
@request.session[:user_id] = 2
|
|
post :destroy_comment, :id => 1, :comment_id => 2
|
|
assert_redirected_to 'news/show/1'
|
|
assert_nil Comment.find_by_id(2)
|
|
assert_equal comments_count - 1, News.find(1).comments.size
|
|
end
|
|
|
|
def test_destroy_routing
|
|
assert_recognizes(#TODO: should use DELETE to news URI, need to change form
|
|
{:controller => 'news', :action => 'destroy', :id => '567'},
|
|
{:method => :post, :path => '/news/567/destroy'}
|
|
)
|
|
end
|
|
|
|
def test_destroy
|
|
@request.session[:user_id] = 2
|
|
post :destroy, :id => 1
|
|
assert_redirected_to 'projects/ecookbook/news'
|
|
assert_nil News.find_by_id(1)
|
|
end
|
|
|
|
def test_preview
|
|
get :preview, :project_id => 1,
|
|
:news => {:title => '',
|
|
:description => 'News description',
|
|
:summary => ''}
|
|
assert_response :success
|
|
assert_template 'common/_preview'
|
|
assert_tag :tag => 'fieldset', :attributes => { :class => 'preview' },
|
|
:content => /News description/
|
|
end
|
|
end
|