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