##// END OF EJS Templates
Make sure that fields filled before tracker change are preserved....
Jean-Philippe Lang -
r11180:9dd8988638cf
parent child
Show More
@@ -1,186 +1,202
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2013 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 select '', :from => 'Assignee'
37 37 fill_in 'Searchable field', :with => 'Value for field 2'
38 38 # click_button 'Create' would match both 'Create' and 'Create and continue' buttons
39 39 find('input[name=commit]').click
40 40 end
41 41
42 42 # find created issue
43 43 issue = Issue.find_by_subject("new test issue")
44 44 assert_kind_of Issue, issue
45 45
46 46 # check redirection
47 47 find 'div#flash_notice', :visible => true, :text => "Issue \##{issue.id} created."
48 48 assert_equal issue_path(:id => issue), current_path
49 49
50 50 # check issue attributes
51 51 assert_equal 'jsmith', issue.author.login
52 52 assert_equal 1, issue.project.id
53 53 assert_equal IssueStatus.find_by_name('New'), issue.status
54 54 assert_equal Tracker.find_by_name('Bug'), issue.tracker
55 55 assert_equal IssuePriority.find_by_name('Low'), issue.priority
56 56 assert_equal 'Value for field 2', issue.custom_field_value(CustomField.find_by_name('Searchable field'))
57 57 end
58 58
59 59 def test_create_issue_with_form_update
60 field = IssueCustomField.create!(
60 field1 = IssueCustomField.create!(
61 61 :field_format => 'string',
62 :name => 'Form update CF',
62 :name => 'Field1',
63 63 :is_for_all => true,
64 :trackers => Tracker.find_all_by_name('Feature request')
64 :trackers => Tracker.find_all_by_id([1, 2])
65 )
66 field2 = IssueCustomField.create!(
67 :field_format => 'string',
68 :name => 'Field2',
69 :is_for_all => true,
70 :trackers => Tracker.find_all_by_id(2)
65 71 )
66 72
67 73 Role.non_member.add_permission! :add_issues
68 74 Role.non_member.remove_permission! :edit_issues, :add_issue_notes
69 75
70 76 log_user('someone', 'foo')
71 77 visit '/projects/ecookbook/issues/new'
72 assert page.has_no_content?('Form update CF')
78 assert page.has_no_content?(field2.name)
79 assert page.has_content?(field1.name)
73 80
74 fill_in 'Subject', :with => 'new test issue'
75 # the custom field should show up when changing tracker
81 fill_in 'Subject', :with => 'New test issue'
82 fill_in 'Description', :with => 'New test issue description'
83 fill_in field1.name, :with => 'CF1 value'
84 select 'Low', :from => 'Priority'
85
86 # field2 should show up when changing tracker
76 87 select 'Feature request', :from => 'Tracker'
77 assert page.has_content?('Form update CF')
88 assert page.has_content?(field2.name)
89 assert page.has_content?(field1.name)
78 90
79 fill_in 'Form update', :with => 'CF value'
91 fill_in field2.name, :with => 'CF2 value'
80 92 assert_difference 'Issue.count' do
81 find('input[name=commit]').click
93 page.first(:button, 'Create').click
82 94 end
83 95
84 96 issue = Issue.order('id desc').first
85 assert_equal 'CF value', issue.custom_field_value(field)
97 assert_equal 'New test issue', issue.subject
98 assert_equal 'New test issue description', issue.description
99 assert_equal 'Low', issue.priority.name
100 assert_equal 'CF1 value', issue.custom_field_value(field1)
101 assert_equal 'CF2 value', issue.custom_field_value(field2)
86 102 end
87 103
88 104 def test_create_issue_with_watchers
89 105 User.generate!(:firstname => 'Some', :lastname => 'Watcher')
90 106
91 107 log_user('jsmith', 'jsmith')
92 108 visit '/projects/ecookbook/issues/new'
93 109 fill_in 'Subject', :with => 'Issue with watchers'
94 110 # Add a project member as watcher
95 111 check 'Dave Lopper'
96 112 # Search for another user
97 113 click_link 'Search for watchers to add'
98 114 within('form#new-watcher-form') do
99 115 assert page.has_content?('Some One')
100 116 fill_in 'user_search', :with => 'watch'
101 117 assert page.has_no_content?('Some One')
102 118 check 'Some Watcher'
103 119 click_button 'Add'
104 120 end
105 121 assert_difference 'Issue.count' do
106 122 find('input[name=commit]').click
107 123 end
108 124
109 125 issue = Issue.order('id desc').first
110 126 assert_equal ['Dave Lopper', 'Some Watcher'], issue.watcher_users.map(&:name).sort
111 127 end
112 128
113 129 def test_preview_issue_description
114 130 log_user('jsmith', 'jsmith')
115 131 visit '/projects/ecookbook/issues/new'
116 132 within('form#issue-form') do
117 133 fill_in 'Subject', :with => 'new issue subject'
118 134 fill_in 'Description', :with => 'new issue description'
119 135 click_link 'Preview'
120 136 end
121 137 find 'div#preview fieldset', :visible => true, :text => 'new issue description'
122 138 assert_difference 'Issue.count' do
123 139 find('input[name=commit]').click
124 140 end
125 141
126 142 issue = Issue.order('id desc').first
127 143 assert_equal 'new issue description', issue.description
128 144 end
129 145
130 146 def test_update_issue_with_form_update
131 147 field = IssueCustomField.create!(
132 148 :field_format => 'string',
133 149 :name => 'Form update CF',
134 150 :is_for_all => true,
135 151 :trackers => Tracker.find_all_by_name('Feature request')
136 152 )
137 153
138 154 Role.non_member.add_permission! :edit_issues
139 155 Role.non_member.remove_permission! :add_issues, :add_issue_notes
140 156
141 157 log_user('someone', 'foo')
142 158 visit '/issues/1'
143 159 assert page.has_no_content?('Form update CF')
144 160
145 161 page.first(:link, 'Update').click
146 162 # the custom field should show up when changing tracker
147 163 select 'Feature request', :from => 'Tracker'
148 164 assert page.has_content?('Form update CF')
149 165
150 166 fill_in 'Form update', :with => 'CF value'
151 167 assert_no_difference 'Issue.count' do
152 168 page.first(:button, 'Submit').click
153 169 end
154 170
155 171 issue = Issue.find(1)
156 172 assert_equal 'CF value', issue.custom_field_value(field)
157 173 end
158 174
159 175 def test_watch_issue_via_context_menu
160 176 log_user('jsmith', 'jsmith')
161 177 visit '/issues'
162 178 find('tr#issue-1 td.updated_on').click
163 179 page.execute_script "$('tr#issue-1 td.updated_on').trigger('contextmenu');"
164 180 assert_difference 'Watcher.count' do
165 181 within('#context-menu') do
166 182 click_link 'Watch'
167 183 end
168 184 end
169 185 assert Issue.find(1).watched_by?(User.find_by_login('jsmith'))
170 186 end
171 187
172 188 def test_bulk_watch_issues_via_context_menu
173 189 log_user('jsmith', 'jsmith')
174 190 visit '/issues'
175 191 find('tr#issue-1 input[type=checkbox]').click
176 192 find('tr#issue-4 input[type=checkbox]').click
177 193 page.execute_script "$('tr#issue-1 td.updated_on').trigger('contextmenu');"
178 194 assert_difference 'Watcher.count', 2 do
179 195 within('#context-menu') do
180 196 click_link 'Watch'
181 197 end
182 198 end
183 199 assert Issue.find(1).watched_by?(User.find_by_login('jsmith'))
184 200 assert Issue.find(4).watched_by?(User.find_by_login('jsmith'))
185 201 end
186 202 end
General Comments 0
You need to be logged in to leave comments. Login now