]> git.openstreetmap.org Git - rails.git/blob - test/controllers/diary_comments_controller_test.rb
Disable Rails/BulkChangeTable cop
[rails.git] / test / controllers / diary_comments_controller_test.rb
1 require "test_helper"
2
3 class DiaryCommentsControllerTest < ActionDispatch::IntegrationTest
4   def setup
5     super
6     # Create the default language for diary entries
7     create(:language, :code => "en")
8   end
9
10   def test_routes
11     assert_routing(
12       { :path => "/user/username/diary/comments", :method => :get },
13       { :controller => "diary_comments", :action => "index", :display_name => "username" }
14     )
15     assert_routing(
16       { :path => "/user/username/diary/1/hidecomment/2", :method => :post },
17       { :controller => "diary_comments", :action => "hide", :display_name => "username", :id => "1", :comment => "2" }
18     )
19     assert_routing(
20       { :path => "/user/username/diary/1/unhidecomment/2", :method => :post },
21       { :controller => "diary_comments", :action => "unhide", :display_name => "username", :id => "1", :comment => "2" }
22     )
23
24     get "/user/username/diary/comments/1"
25     assert_redirected_to "/user/username/diary/comments"
26   end
27
28   def test_index
29     user = create(:user)
30     other_user = create(:user)
31     suspended_user = create(:user, :suspended)
32     deleted_user = create(:user, :deleted)
33
34     # Test a user with no comments
35     get diary_comments_path(:display_name => user.display_name)
36     assert_response :success
37     assert_template :index
38     assert_select "h4", :html => "No diary comments"
39
40     # Test a user with a comment
41     create(:diary_comment, :user => other_user)
42
43     get diary_comments_path(:display_name => other_user.display_name)
44     assert_response :success
45     assert_template :index
46     assert_dom "a[href='#{user_path(other_user)}']", :text => other_user.display_name
47     assert_select "table.table-striped tbody" do
48       assert_select "tr", :count => 1
49     end
50
51     # Test a suspended user
52     get diary_comments_path(:display_name => suspended_user.display_name)
53     assert_response :not_found
54
55     # Test a deleted user
56     get diary_comments_path(:display_name => deleted_user.display_name)
57     assert_response :not_found
58   end
59
60   def test_index_invalid_paged
61     user = create(:user)
62
63     %w[-1 0 fred].each do |id|
64       get diary_comments_path(:display_name => user.display_name, :before => id)
65       assert_redirected_to :controller => :errors, :action => :bad_request
66
67       get diary_comments_path(:display_name => user.display_name, :after => id)
68       assert_redirected_to :controller => :errors, :action => :bad_request
69     end
70   end
71
72   def test_hide
73     user = create(:user)
74     diary_entry = create(:diary_entry, :user => user)
75     diary_comment = create(:diary_comment, :diary_entry => diary_entry)
76
77     # Try without logging in
78     post hide_diary_comment_path(user, diary_entry, diary_comment)
79     assert_response :forbidden
80     assert DiaryComment.find(diary_comment.id).visible
81
82     # Now try as a normal user
83     session_for(user)
84     post hide_diary_comment_path(user, diary_entry, diary_comment)
85     assert_redirected_to :controller => :errors, :action => :forbidden
86     assert DiaryComment.find(diary_comment.id).visible
87
88     # Try as a moderator
89     session_for(create(:moderator_user))
90     post hide_diary_comment_path(user, diary_entry, diary_comment)
91     assert_redirected_to diary_entry_path(user, diary_entry)
92     assert_not DiaryComment.find(diary_comment.id).visible
93
94     # Reset
95     diary_comment.reload.update(:visible => true)
96
97     # Finally try as an administrator
98     session_for(create(:administrator_user))
99     post hide_diary_comment_path(user, diary_entry, diary_comment)
100     assert_redirected_to diary_entry_path(user, diary_entry)
101     assert_not DiaryComment.find(diary_comment.id).visible
102   end
103
104   def test_unhide
105     user = create(:user)
106     diary_entry = create(:diary_entry, :user => user)
107     diary_comment = create(:diary_comment, :diary_entry => diary_entry, :visible => false)
108
109     # Try without logging in
110     post unhide_diary_comment_path(user, diary_entry, diary_comment)
111     assert_response :forbidden
112     assert_not DiaryComment.find(diary_comment.id).visible
113
114     # Now try as a normal user
115     session_for(user)
116     post unhide_diary_comment_path(user, diary_entry, diary_comment)
117     assert_redirected_to :controller => :errors, :action => :forbidden
118     assert_not DiaryComment.find(diary_comment.id).visible
119
120     # Now try as a moderator
121     session_for(create(:moderator_user))
122     post unhide_diary_comment_path(user, diary_entry, diary_comment)
123     assert_redirected_to diary_entry_path(user, diary_entry)
124     assert DiaryComment.find(diary_comment.id).visible
125
126     # Reset
127     diary_comment.reload.update(:visible => true)
128
129     # Finally try as an administrator
130     session_for(create(:administrator_user))
131     post unhide_diary_comment_path(user, diary_entry, diary_comment)
132     assert_redirected_to diary_entry_path(user, diary_entry)
133     assert DiaryComment.find(diary_comment.id).visible
134   end
135 end