comparison test/functional/journals_controller_test.rb @ 511:107d36338b70 live

Merge from branch "cannam"
author Chris Cannam
date Thu, 14 Jul 2011 10:43:07 +0100
parents cbce1fd3b1b7
children 433d4f72a19b
comparison
equal deleted inserted replaced
451:a9f6345cb43d 511:107d36338b70
1 # redMine - project management software 1 # Redmine - project management software
2 # Copyright (C) 2006-2008 Jean-Philippe Lang 2 # Copyright (C) 2006-2011 Jean-Philippe Lang
3 # 3 #
4 # This program is free software; you can redistribute it and/or 4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License 5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2 6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version. 7 # of the License, or (at your option) any later version.
8 # 8 #
9 # This program is distributed in the hope that it will be useful, 9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details. 12 # GNU General Public License for more details.
13 # 13 #
14 # You should have received a copy of the GNU General Public License 14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software 15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 require File.dirname(__FILE__) + '/../test_helper' 18 require File.expand_path('../../test_helper', __FILE__)
19 require 'journals_controller' 19 require 'journals_controller'
20 20
21 # Re-raise errors caught by the controller. 21 # Re-raise errors caught by the controller.
22 class JournalsController; def rescue_action(e) raise e end; end 22 class JournalsController; def rescue_action(e) raise e end; end
23 23
24 class JournalsControllerTest < ActionController::TestCase 24 class JournalsControllerTest < ActionController::TestCase
25 fixtures :projects, :users, :members, :member_roles, :roles, :issues, :journals, :journal_details, :enabled_modules 25 fixtures :projects, :users, :members, :member_roles, :roles, :issues, :journals, :journal_details, :enabled_modules,
26 26 :trackers, :issue_statuses, :enumerations, :custom_fields, :custom_values, :custom_fields_projects
27
27 def setup 28 def setup
28 @controller = JournalsController.new 29 @controller = JournalsController.new
29 @request = ActionController::TestRequest.new 30 @request = ActionController::TestRequest.new
30 @response = ActionController::TestResponse.new 31 @response = ActionController::TestResponse.new
31 User.current = nil 32 User.current = nil
32 end 33 end
33 34
34 def test_index 35 def test_index
35 get :index, :project_id => 1 36 get :index, :project_id => 1
36 assert_response :success 37 assert_response :success
37 assert_not_nil assigns(:journals) 38 assert_not_nil assigns(:journals)
38 assert_equal 'application/atom+xml', @response.content_type 39 assert_equal 'application/atom+xml', @response.content_type
39 end 40 end
40 41
42 def test_diff
43 get :diff, :id => 3, :detail_id => 4
44 assert_response :success
45 assert_template 'diff'
46
47 assert_tag 'span',
48 :attributes => {:class => 'diff_out'},
49 :content => /removed/
50 assert_tag 'span',
51 :attributes => {:class => 'diff_in'},
52 :content => /added/
53 end
54
41 def test_reply_to_issue 55 def test_reply_to_issue
42 @request.session[:user_id] = 2 56 @request.session[:user_id] = 2
43 get :new, :id => 1 57 get :new, :id => 6
44 assert_response :success 58 assert_response :success
45 assert_select_rjs :show, "update" 59 assert_select_rjs :show, "update"
46 end 60 end
47 61
62 def test_reply_to_issue_without_permission
63 @request.session[:user_id] = 7
64 get :new, :id => 6
65 assert_response 403
66 end
67
48 def test_reply_to_note 68 def test_reply_to_note
49 @request.session[:user_id] = 2 69 @request.session[:user_id] = 2
50 get :new, :id => 1, :journal_id => 2 70 get :new, :id => 6, :journal_id => 4
51 assert_response :success 71 assert_response :success
52 assert_select_rjs :show, "update" 72 assert_select_rjs :show, "update"
53 end 73 end
54 74
55 def test_get_edit 75 def test_get_edit
59 assert_select_rjs :insert, :after, 'journal-2-notes' do 79 assert_select_rjs :insert, :after, 'journal-2-notes' do
60 assert_select 'form[id=journal-2-form]' 80 assert_select 'form[id=journal-2-form]'
61 assert_select 'textarea' 81 assert_select 'textarea'
62 end 82 end
63 end 83 end
64 84
65 def test_post_edit 85 def test_post_edit
66 @request.session[:user_id] = 1 86 @request.session[:user_id] = 1
67 xhr :post, :edit, :id => 2, :notes => 'Updated notes' 87 xhr :post, :edit, :id => 2, :notes => 'Updated notes'
68 assert_response :success 88 assert_response :success
69 assert_select_rjs :replace, 'journal-2-notes' 89 assert_select_rjs :replace, 'journal-2-notes'
70 assert_equal 'Updated notes', Journal.find(2).notes 90 assert_equal 'Updated notes', Journal.find(2).notes
71 end 91 end
72 92
73 def test_post_edit_with_empty_notes 93 def test_post_edit_with_empty_notes
74 @request.session[:user_id] = 1 94 @request.session[:user_id] = 1
75 xhr :post, :edit, :id => 2, :notes => '' 95 xhr :post, :edit, :id => 2, :notes => ''
76 assert_response :success 96 assert_response :success
77 assert_select_rjs :remove, 'change-2' 97 assert_select_rjs :remove, 'change-2'