##// END OF EJS Templates
Merged r12951....
Jean-Philippe Lang -
r12677:91a161fadba7
parent child
Show More
@@ -1,264 +1,263
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2014 Jean-Philippe Lang
2 # Copyright (C) 2006-2014 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.expand_path('../base', __FILE__)
18 require File.expand_path('../base', __FILE__)
19
19
20 class Redmine::UiTest::IssuesTest < Redmine::UiTest::Base
20 class Redmine::UiTest::IssuesTest < Redmine::UiTest::Base
21 fixtures :projects, :users, :roles, :members, :member_roles,
21 fixtures :projects, :users, :roles, :members, :member_roles,
22 :trackers, :projects_trackers, :enabled_modules, :issue_statuses, :issues,
22 :trackers, :projects_trackers, :enabled_modules, :issue_statuses, :issues,
23 :enumerations, :custom_fields, :custom_values, :custom_fields_trackers,
23 :enumerations, :custom_fields, :custom_values, :custom_fields_trackers,
24 :watchers
24 :watchers
25
25
26 def test_create_issue
26 def test_create_issue
27 log_user('jsmith', 'jsmith')
27 log_user('jsmith', 'jsmith')
28 visit '/projects/ecookbook/issues/new'
28 visit '/projects/ecookbook/issues/new'
29 within('form#issue-form') do
29 within('form#issue-form') do
30 select 'Bug', :from => 'Tracker'
30 select 'Bug', :from => 'Tracker'
31 select 'Low', :from => 'Priority'
31 select 'Low', :from => 'Priority'
32 fill_in 'Subject', :with => 'new test issue'
32 fill_in 'Subject', :with => 'new test issue'
33 fill_in 'Description', :with => 'new issue'
33 fill_in 'Description', :with => 'new issue'
34 select '0 %', :from => 'Done'
34 select '0 %', :from => 'Done'
35 fill_in 'Due date', :with => ''
35 fill_in 'Due date', :with => ''
36 fill_in 'Searchable field', :with => 'Value for field 2'
36 fill_in 'Searchable field', :with => 'Value for field 2'
37 # click_button 'Create' would match both 'Create' and 'Create and continue' buttons
37 # click_button 'Create' would match both 'Create' and 'Create and continue' buttons
38 find('input[name=commit]').click
38 find('input[name=commit]').click
39 end
39 end
40
40
41 # find created issue
41 # find created issue
42 issue = Issue.find_by_subject("new test issue")
42 issue = Issue.find_by_subject("new test issue")
43 assert_kind_of Issue, issue
43 assert_kind_of Issue, issue
44
44
45 # check redirection
45 # check redirection
46 find 'div#flash_notice', :visible => true, :text => "Issue \##{issue.id} created."
46 find 'div#flash_notice', :visible => true, :text => "Issue \##{issue.id} created."
47 assert_equal issue_path(:id => issue), current_path
47 assert_equal issue_path(:id => issue), current_path
48
48
49 # check issue attributes
49 # check issue attributes
50 assert_equal 'jsmith', issue.author.login
50 assert_equal 'jsmith', issue.author.login
51 assert_equal 1, issue.project.id
51 assert_equal 1, issue.project.id
52 assert_equal IssueStatus.find_by_name('New'), issue.status
52 assert_equal IssueStatus.find_by_name('New'), issue.status
53 assert_equal Tracker.find_by_name('Bug'), issue.tracker
53 assert_equal Tracker.find_by_name('Bug'), issue.tracker
54 assert_equal IssuePriority.find_by_name('Low'), issue.priority
54 assert_equal IssuePriority.find_by_name('Low'), issue.priority
55 assert_equal 'Value for field 2', issue.custom_field_value(CustomField.find_by_name('Searchable field'))
55 assert_equal 'Value for field 2', issue.custom_field_value(CustomField.find_by_name('Searchable field'))
56 end
56 end
57
57
58 def test_create_issue_with_form_update
58 def test_create_issue_with_form_update
59 field1 = IssueCustomField.create!(
59 field1 = IssueCustomField.create!(
60 :field_format => 'string',
60 :field_format => 'string',
61 :name => 'Field1',
61 :name => 'Field1',
62 :is_for_all => true,
62 :is_for_all => true,
63 :trackers => Tracker.find_all_by_id([1, 2])
63 :trackers => Tracker.find_all_by_id([1, 2])
64 )
64 )
65 field2 = IssueCustomField.create!(
65 field2 = IssueCustomField.create!(
66 :field_format => 'string',
66 :field_format => 'string',
67 :name => 'Field2',
67 :name => 'Field2',
68 :is_for_all => true,
68 :is_for_all => true,
69 :trackers => Tracker.find_all_by_id(2)
69 :trackers => Tracker.find_all_by_id(2)
70 )
70 )
71
71
72 Role.non_member.add_permission! :add_issues
72 Role.non_member.add_permission! :add_issues
73 Role.non_member.remove_permission! :edit_issues, :add_issue_notes
73 Role.non_member.remove_permission! :edit_issues, :add_issue_notes
74
74
75 log_user('someone', 'foo')
75 log_user('someone', 'foo')
76 visit '/projects/ecookbook/issues/new'
76 visit '/projects/ecookbook/issues/new'
77 assert page.has_no_content?(field2.name)
77 assert page.has_no_content?(field2.name)
78 assert page.has_content?(field1.name)
78 assert page.has_content?(field1.name)
79
79
80 fill_in 'Subject', :with => 'New test issue'
80 fill_in 'Subject', :with => 'New test issue'
81 fill_in 'Description', :with => 'New test issue description'
81 fill_in 'Description', :with => 'New test issue description'
82 fill_in field1.name, :with => 'CF1 value'
82 fill_in field1.name, :with => 'CF1 value'
83 select 'Low', :from => 'Priority'
83 select 'Low', :from => 'Priority'
84
84
85 # field2 should show up when changing tracker
85 # field2 should show up when changing tracker
86 select 'Feature request', :from => 'Tracker'
86 select 'Feature request', :from => 'Tracker'
87 assert page.has_content?(field2.name)
87 assert page.has_content?(field2.name)
88 assert page.has_content?(field1.name)
88 assert page.has_content?(field1.name)
89
89
90 fill_in field2.name, :with => 'CF2 value'
90 fill_in field2.name, :with => 'CF2 value'
91 assert_difference 'Issue.count' do
91 assert_difference 'Issue.count' do
92 page.first(:button, 'Create').click
92 page.first(:button, 'Create').click
93 end
93 end
94
94
95 issue = Issue.order('id desc').first
95 issue = Issue.order('id desc').first
96 assert_equal 'New test issue', issue.subject
96 assert_equal 'New test issue', issue.subject
97 assert_equal 'New test issue description', issue.description
97 assert_equal 'New test issue description', issue.description
98 assert_equal 'Low', issue.priority.name
98 assert_equal 'Low', issue.priority.name
99 assert_equal 'CF1 value', issue.custom_field_value(field1)
99 assert_equal 'CF1 value', issue.custom_field_value(field1)
100 assert_equal 'CF2 value', issue.custom_field_value(field2)
100 assert_equal 'CF2 value', issue.custom_field_value(field2)
101 end
101 end
102
102
103 def test_create_issue_with_watchers
103 def test_create_issue_with_watchers
104 user = User.generate!(:firstname => 'Some', :lastname => 'Watcher')
104 user = User.generate!(:firstname => 'Some', :lastname => 'Watcher')
105 assert_equal 'Some Watcher', user.name
105 assert_equal 'Some Watcher', user.name
106 log_user('jsmith', 'jsmith')
106 log_user('jsmith', 'jsmith')
107 visit '/projects/ecookbook/issues/new'
107 visit '/projects/ecookbook/issues/new'
108 fill_in 'Subject', :with => 'Issue with watchers'
108 fill_in 'Subject', :with => 'Issue with watchers'
109 # Add a project member as watcher
109 # Add a project member as watcher
110 check 'Dave Lopper'
110 check 'Dave Lopper'
111 # Search for another user
111 # Search for another user
112 assert page.has_no_css?('form#new-watcher-form')
112 assert page.has_no_css?('form#new-watcher-form')
113 assert page.has_no_content?('Some Watcher')
113 assert page.has_no_content?('Some Watcher')
114 click_link 'Search for watchers to add'
114 click_link 'Search for watchers to add'
115 within('form#new-watcher-form') do
115 within('form#new-watcher-form') do
116 assert page.has_content?('Some One')
117 fill_in 'user_search', :with => 'watch'
116 fill_in 'user_search', :with => 'watch'
118 assert page.has_no_content?('Some One')
117 assert page.has_content?('Some Watcher')
119 check 'Some Watcher'
118 check 'Some Watcher'
120 click_button 'Add'
119 click_button 'Add'
121 end
120 end
122 assert page.has_css?('form#issue-form')
121 assert page.has_css?('form#issue-form')
123 assert page.has_css?('p#watchers_form')
122 assert page.has_css?('p#watchers_form')
124 using_wait_time(30) do
123 using_wait_time(30) do
125 within('span#watchers_inputs') do
124 within('span#watchers_inputs') do
126 within("label#issue_watcher_user_ids_#{user.id}") do
125 within("label#issue_watcher_user_ids_#{user.id}") do
127 assert has_content?('Some Watcher'), "No watcher content"
126 assert has_content?('Some Watcher'), "No watcher content"
128 end
127 end
129 end
128 end
130 end
129 end
131 assert_difference 'Issue.count' do
130 assert_difference 'Issue.count' do
132 find('input[name=commit]').click
131 find('input[name=commit]').click
133 end
132 end
134
133
135 issue = Issue.order('id desc').first
134 issue = Issue.order('id desc').first
136 assert_equal ['Dave Lopper', 'Some Watcher'], issue.watcher_users.map(&:name).sort
135 assert_equal ['Dave Lopper', 'Some Watcher'], issue.watcher_users.map(&:name).sort
137 end
136 end
138
137
139 def test_create_issue_start_due_date
138 def test_create_issue_start_due_date
140 with_settings :default_issue_start_date_to_creation_date => 0 do
139 with_settings :default_issue_start_date_to_creation_date => 0 do
141 log_user('jsmith', 'jsmith')
140 log_user('jsmith', 'jsmith')
142 visit '/projects/ecookbook/issues/new'
141 visit '/projects/ecookbook/issues/new'
143 assert_equal "", page.find('input#issue_start_date').value
142 assert_equal "", page.find('input#issue_start_date').value
144 assert_equal "", page.find('input#issue_due_date').value
143 assert_equal "", page.find('input#issue_due_date').value
145 page.first('p#start_date_area img').click
144 page.first('p#start_date_area img').click
146 page.first("td.ui-datepicker-days-cell-over a").click
145 page.first("td.ui-datepicker-days-cell-over a").click
147 assert_equal Date.today.to_s, page.find('input#issue_start_date').value
146 assert_equal Date.today.to_s, page.find('input#issue_start_date').value
148 page.first('p#due_date_area img').click
147 page.first('p#due_date_area img').click
149 page.first("td.ui-datepicker-days-cell-over a").click
148 page.first("td.ui-datepicker-days-cell-over a").click
150 assert_equal Date.today.to_s, page.find('input#issue_due_date').value
149 assert_equal Date.today.to_s, page.find('input#issue_due_date').value
151 end
150 end
152 end
151 end
153
152
154 def test_create_issue_start_due_date_default
153 def test_create_issue_start_due_date_default
155 log_user('jsmith', 'jsmith')
154 log_user('jsmith', 'jsmith')
156 visit '/projects/ecookbook/issues/new'
155 visit '/projects/ecookbook/issues/new'
157 fill_in 'Start date', :with => '2012-04-01'
156 fill_in 'Start date', :with => '2012-04-01'
158 fill_in 'Due date', :with => ''
157 fill_in 'Due date', :with => ''
159 page.first('p#due_date_area img').click
158 page.first('p#due_date_area img').click
160 page.first("td.ui-datepicker-days-cell-over a").click
159 page.first("td.ui-datepicker-days-cell-over a").click
161 assert_equal '2012-04-01', page.find('input#issue_due_date').value
160 assert_equal '2012-04-01', page.find('input#issue_due_date').value
162
161
163 fill_in 'Start date', :with => ''
162 fill_in 'Start date', :with => ''
164 fill_in 'Due date', :with => '2012-04-01'
163 fill_in 'Due date', :with => '2012-04-01'
165 page.first('p#start_date_area img').click
164 page.first('p#start_date_area img').click
166 page.first("td.ui-datepicker-days-cell-over a").click
165 page.first("td.ui-datepicker-days-cell-over a").click
167 assert_equal '2012-04-01', page.find('input#issue_start_date').value
166 assert_equal '2012-04-01', page.find('input#issue_start_date').value
168 end
167 end
169
168
170 def test_preview_issue_description
169 def test_preview_issue_description
171 log_user('jsmith', 'jsmith')
170 log_user('jsmith', 'jsmith')
172 visit '/projects/ecookbook/issues/new'
171 visit '/projects/ecookbook/issues/new'
173 within('form#issue-form') do
172 within('form#issue-form') do
174 fill_in 'Subject', :with => 'new issue subject'
173 fill_in 'Subject', :with => 'new issue subject'
175 fill_in 'Description', :with => 'new issue description'
174 fill_in 'Description', :with => 'new issue description'
176 click_link 'Preview'
175 click_link 'Preview'
177 end
176 end
178 find 'div#preview fieldset', :visible => true, :text => 'new issue description'
177 find 'div#preview fieldset', :visible => true, :text => 'new issue description'
179 assert_difference 'Issue.count' do
178 assert_difference 'Issue.count' do
180 find('input[name=commit]').click
179 find('input[name=commit]').click
181 end
180 end
182
181
183 issue = Issue.order('id desc').first
182 issue = Issue.order('id desc').first
184 assert_equal 'new issue description', issue.description
183 assert_equal 'new issue description', issue.description
185 end
184 end
186
185
187 def test_update_issue_with_form_update
186 def test_update_issue_with_form_update
188 field = IssueCustomField.create!(
187 field = IssueCustomField.create!(
189 :field_format => 'string',
188 :field_format => 'string',
190 :name => 'Form update CF',
189 :name => 'Form update CF',
191 :is_for_all => true,
190 :is_for_all => true,
192 :trackers => Tracker.find_all_by_name('Feature request')
191 :trackers => Tracker.find_all_by_name('Feature request')
193 )
192 )
194
193
195 Role.non_member.add_permission! :edit_issues
194 Role.non_member.add_permission! :edit_issues
196 Role.non_member.remove_permission! :add_issues, :add_issue_notes
195 Role.non_member.remove_permission! :add_issues, :add_issue_notes
197
196
198 log_user('someone', 'foo')
197 log_user('someone', 'foo')
199 visit '/issues/1'
198 visit '/issues/1'
200 assert page.has_no_content?('Form update CF')
199 assert page.has_no_content?('Form update CF')
201
200
202 page.first(:link, 'Edit').click
201 page.first(:link, 'Edit').click
203 # the custom field should show up when changing tracker
202 # the custom field should show up when changing tracker
204 select 'Feature request', :from => 'Tracker'
203 select 'Feature request', :from => 'Tracker'
205 assert page.has_content?('Form update CF')
204 assert page.has_content?('Form update CF')
206
205
207 fill_in 'Form update', :with => 'CF value'
206 fill_in 'Form update', :with => 'CF value'
208 assert_no_difference 'Issue.count' do
207 assert_no_difference 'Issue.count' do
209 page.first(:button, 'Submit').click
208 page.first(:button, 'Submit').click
210 end
209 end
211
210
212 issue = Issue.find(1)
211 issue = Issue.find(1)
213 assert_equal 'CF value', issue.custom_field_value(field)
212 assert_equal 'CF value', issue.custom_field_value(field)
214 end
213 end
215
214
216 def test_remove_issue_watcher_from_sidebar
215 def test_remove_issue_watcher_from_sidebar
217 user = User.find(3)
216 user = User.find(3)
218 Watcher.create!(:watchable => Issue.find(1), :user => user)
217 Watcher.create!(:watchable => Issue.find(1), :user => user)
219
218
220 log_user('jsmith', 'jsmith')
219 log_user('jsmith', 'jsmith')
221 visit '/issues/1'
220 visit '/issues/1'
222 assert page.first('#sidebar').has_content?('Watchers (1)')
221 assert page.first('#sidebar').has_content?('Watchers (1)')
223 assert page.first('#sidebar').has_content?(user.name)
222 assert page.first('#sidebar').has_content?(user.name)
224 assert_difference 'Watcher.count', -1 do
223 assert_difference 'Watcher.count', -1 do
225 page.first('ul.watchers .user-3 a.delete').click
224 page.first('ul.watchers .user-3 a.delete').click
226 assert page.first('#sidebar').has_content?('Watchers (0)')
225 assert page.first('#sidebar').has_content?('Watchers (0)')
227 end
226 end
228 assert page.first('#sidebar').has_no_content?(user.name)
227 assert page.first('#sidebar').has_no_content?(user.name)
229 end
228 end
230
229
231 def test_watch_issue_via_context_menu
230 def test_watch_issue_via_context_menu
232 log_user('jsmith', 'jsmith')
231 log_user('jsmith', 'jsmith')
233 visit '/issues'
232 visit '/issues'
234 assert page.has_css?('tr#issue-1')
233 assert page.has_css?('tr#issue-1')
235 find('tr#issue-1 td.updated_on').click
234 find('tr#issue-1 td.updated_on').click
236 page.execute_script "$('tr#issue-1 td.updated_on').trigger('contextmenu');"
235 page.execute_script "$('tr#issue-1 td.updated_on').trigger('contextmenu');"
237 assert_difference 'Watcher.count' do
236 assert_difference 'Watcher.count' do
238 within('#context-menu') do
237 within('#context-menu') do
239 click_link 'Watch'
238 click_link 'Watch'
240 end
239 end
241 assert page.has_css?('tr#issue-1')
240 assert page.has_css?('tr#issue-1')
242 end
241 end
243 assert Issue.find(1).watched_by?(User.find_by_login('jsmith'))
242 assert Issue.find(1).watched_by?(User.find_by_login('jsmith'))
244 end
243 end
245
244
246 def test_bulk_watch_issues_via_context_menu
245 def test_bulk_watch_issues_via_context_menu
247 log_user('jsmith', 'jsmith')
246 log_user('jsmith', 'jsmith')
248 visit '/issues'
247 visit '/issues'
249 assert page.has_css?('tr#issue-1')
248 assert page.has_css?('tr#issue-1')
250 assert page.has_css?('tr#issue-4')
249 assert page.has_css?('tr#issue-4')
251 find('tr#issue-1 input[type=checkbox]').click
250 find('tr#issue-1 input[type=checkbox]').click
252 find('tr#issue-4 input[type=checkbox]').click
251 find('tr#issue-4 input[type=checkbox]').click
253 page.execute_script "$('tr#issue-1 td.updated_on').trigger('contextmenu');"
252 page.execute_script "$('tr#issue-1 td.updated_on').trigger('contextmenu');"
254 assert_difference 'Watcher.count', 2 do
253 assert_difference 'Watcher.count', 2 do
255 within('#context-menu') do
254 within('#context-menu') do
256 click_link 'Watch'
255 click_link 'Watch'
257 end
256 end
258 assert page.has_css?('tr#issue-1')
257 assert page.has_css?('tr#issue-1')
259 assert page.has_css?('tr#issue-4')
258 assert page.has_css?('tr#issue-4')
260 end
259 end
261 assert Issue.find(1).watched_by?(User.find_by_login('jsmith'))
260 assert Issue.find(1).watched_by?(User.find_by_login('jsmith'))
262 assert Issue.find(4).watched_by?(User.find_by_login('jsmith'))
261 assert Issue.find(4).watched_by?(User.find_by_login('jsmith'))
263 end
262 end
264 end
263 end
General Comments 0
You need to be logged in to leave comments. Login now