##// END OF EJS Templates
scm: git: run both "inline" and "side by side" diff in functional test_diff test....
Toshi MARUYAMA -
r5852:ab75fb1c8289
parent child
Show More
@@ -1,339 +1,344
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2011 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('../../test_helper', __FILE__)
19 19 require 'repositories_controller'
20 20
21 21 # Re-raise errors caught by the controller.
22 22 class RepositoriesController; def rescue_action(e) raise e end; end
23 23
24 24 class RepositoriesGitControllerTest < ActionController::TestCase
25 25 fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :enabled_modules
26 26
27 27 # No '..' in the repository path
28 28 REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/git_repository'
29 29 REPOSITORY_PATH.gsub!(/\//, "\\") if Redmine::Platform.mswin?
30 30 PRJ_ID = 3
31 31 CHAR_1_HEX = "\xc3\x9c"
32 32
33 33 def setup
34 34 @ruby19_non_utf8_pass =
35 35 (RUBY_VERSION >= '1.9' && Encoding.default_external.to_s != 'UTF-8')
36 36
37 37 @controller = RepositoriesController.new
38 38 @request = ActionController::TestRequest.new
39 39 @response = ActionController::TestResponse.new
40 40 User.current = nil
41 41 @repository = Repository::Git.create(
42 42 :project => Project.find(3),
43 43 :url => REPOSITORY_PATH,
44 44 :path_encoding => 'ISO-8859-1'
45 45 )
46 46 assert @repository
47 47 @char_1 = CHAR_1_HEX.dup
48 48 if @char_1.respond_to?(:force_encoding)
49 49 @char_1.force_encoding('UTF-8')
50 50 end
51 51 end
52 52
53 53 if File.directory?(REPOSITORY_PATH)
54 54 def test_browse_root
55 55 @repository.fetch_changesets
56 56 @repository.reload
57 57 get :show, :id => PRJ_ID
58 58 assert_response :success
59 59 assert_template 'show'
60 60 assert_not_nil assigns(:entries)
61 61 assert_equal 9, assigns(:entries).size
62 62 assert assigns(:entries).detect {|e| e.name == 'images' && e.kind == 'dir'}
63 63 assert assigns(:entries).detect {|e| e.name == 'this_is_a_really_long_and_verbose_directory_name' && e.kind == 'dir'}
64 64 assert assigns(:entries).detect {|e| e.name == 'sources' && e.kind == 'dir'}
65 65 assert assigns(:entries).detect {|e| e.name == 'README' && e.kind == 'file'}
66 66 assert assigns(:entries).detect {|e| e.name == 'copied_README' && e.kind == 'file'}
67 67 assert assigns(:entries).detect {|e| e.name == 'new_file.txt' && e.kind == 'file'}
68 68 assert assigns(:entries).detect {|e| e.name == 'renamed_test.txt' && e.kind == 'file'}
69 69 assert assigns(:entries).detect {|e| e.name == 'filemane with spaces.txt' && e.kind == 'file'}
70 70 assert assigns(:entries).detect {|e| e.name == ' filename with a leading space.txt ' && e.kind == 'file'}
71 71 assert_not_nil assigns(:changesets)
72 72 assigns(:changesets).size > 0
73 73 end
74 74
75 75 def test_browse_branch
76 76 @repository.fetch_changesets
77 77 @repository.reload
78 78 get :show, :id => PRJ_ID, :rev => 'test_branch'
79 79 assert_response :success
80 80 assert_template 'show'
81 81 assert_not_nil assigns(:entries)
82 82 assert_equal 4, assigns(:entries).size
83 83 assert assigns(:entries).detect {|e| e.name == 'images' && e.kind == 'dir'}
84 84 assert assigns(:entries).detect {|e| e.name == 'sources' && e.kind == 'dir'}
85 85 assert assigns(:entries).detect {|e| e.name == 'README' && e.kind == 'file'}
86 86 assert assigns(:entries).detect {|e| e.name == 'test.txt' && e.kind == 'file'}
87 87 assert_not_nil assigns(:changesets)
88 88 assigns(:changesets).size > 0
89 89 end
90 90
91 91 def test_browse_tag
92 92 @repository.fetch_changesets
93 93 @repository.reload
94 94 [
95 95 "tag00.lightweight",
96 96 "tag01.annotated",
97 97 ].each do |t1|
98 98 get :show, :id => PRJ_ID, :rev => t1
99 99 assert_response :success
100 100 assert_template 'show'
101 101 assert_not_nil assigns(:entries)
102 102 assigns(:entries).size > 0
103 103 assert_not_nil assigns(:changesets)
104 104 assigns(:changesets).size > 0
105 105 end
106 106 end
107 107
108 108 def test_browse_directory
109 109 @repository.fetch_changesets
110 110 @repository.reload
111 111 get :show, :id => PRJ_ID, :path => ['images']
112 112 assert_response :success
113 113 assert_template 'show'
114 114 assert_not_nil assigns(:entries)
115 115 assert_equal ['edit.png'], assigns(:entries).collect(&:name)
116 116 entry = assigns(:entries).detect {|e| e.name == 'edit.png'}
117 117 assert_not_nil entry
118 118 assert_equal 'file', entry.kind
119 119 assert_equal 'images/edit.png', entry.path
120 120 assert_not_nil assigns(:changesets)
121 121 assigns(:changesets).size > 0
122 122 end
123 123
124 124 def test_browse_at_given_revision
125 125 @repository.fetch_changesets
126 126 @repository.reload
127 127 get :show, :id => PRJ_ID, :path => ['images'],
128 128 :rev => '7234cb2750b63f47bff735edc50a1c0a433c2518'
129 129 assert_response :success
130 130 assert_template 'show'
131 131 assert_not_nil assigns(:entries)
132 132 assert_equal ['delete.png'], assigns(:entries).collect(&:name)
133 133 assert_not_nil assigns(:changesets)
134 134 assigns(:changesets).size > 0
135 135 end
136 136
137 137 def test_changes
138 138 get :changes, :id => PRJ_ID, :path => ['images', 'edit.png']
139 139 assert_response :success
140 140 assert_template 'changes'
141 141 assert_tag :tag => 'h2', :content => 'edit.png'
142 142 end
143 143
144 144 def test_entry_show
145 145 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
146 146 assert_response :success
147 147 assert_template 'entry'
148 148 # Line 19
149 149 assert_tag :tag => 'th',
150 150 :content => '11',
151 151 :attributes => { :class => 'line-num' },
152 152 :sibling => { :tag => 'td', :content => /WITHOUT ANY WARRANTY/ }
153 153 end
154 154
155 155 def test_entry_show_latin_1
156 156 if @ruby19_non_utf8_pass
157 157 puts_ruby19_non_utf8_pass()
158 158 else
159 159 with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do
160 160 ['57ca437c', '57ca437c0acbbcb749821fdf3726a1367056d364'].each do |r1|
161 161 get :entry, :id => PRJ_ID,
162 162 :path => ['latin-1-dir', "test-#{@char_1}.txt"], :rev => r1
163 163 assert_response :success
164 164 assert_template 'entry'
165 165 assert_tag :tag => 'th',
166 166 :content => '1',
167 167 :attributes => { :class => 'line-num' },
168 168 :sibling => { :tag => 'td',
169 169 :content => /test-#{@char_1}.txt/ }
170 170 end
171 171 end
172 172 end
173 173 end
174 174
175 175 def test_entry_download
176 176 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb'],
177 177 :format => 'raw'
178 178 assert_response :success
179 179 # File content
180 180 assert @response.body.include?('WITHOUT ANY WARRANTY')
181 181 end
182 182
183 183 def test_directory_entry
184 184 get :entry, :id => PRJ_ID, :path => ['sources']
185 185 assert_response :success
186 186 assert_template 'show'
187 187 assert_not_nil assigns(:entry)
188 188 assert_equal 'sources', assigns(:entry).name
189 189 end
190 190
191 191 def test_diff
192 192 @repository.fetch_changesets
193 193 @repository.reload
194 194 # Full diff of changeset 2f9c0091
195 get :diff, :id => PRJ_ID, :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7'
196 assert_response :success
197 assert_template 'diff'
198 # Line 22 removed
199 assert_tag :tag => 'th',
200 :content => /22/,
201 :sibling => { :tag => 'td',
202 :attributes => { :class => /diff_out/ },
203 :content => /def remove/ }
204 assert_tag :tag => 'h2', :content => /2f9c0091/
195 ['inline', 'sbs'].each do |dt|
196 get :diff,
197 :id => PRJ_ID,
198 :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7',
199 :type => dt
200 assert_response :success
201 assert_template 'diff'
202 # Line 22 removed
203 assert_tag :tag => 'th',
204 :content => /22/,
205 :sibling => { :tag => 'td',
206 :attributes => { :class => /diff_out/ },
207 :content => /def remove/ }
208 assert_tag :tag => 'h2', :content => /2f9c0091/
209 end
205 210 end
206 211
207 212 def test_diff_two_revs
208 213 @repository.fetch_changesets
209 214 @repository.reload
210 215 get :diff, :id => PRJ_ID,
211 216 :rev => '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
212 217 :rev_to => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7'
213 218 assert_response :success
214 219 assert_template 'diff'
215 220 diff = assigns(:diff)
216 221 assert_not_nil diff
217 222 assert_tag :tag => 'h2', :content => /2f9c0091:61b685fb/
218 223 end
219 224
220 225 def test_diff_latin_1
221 226 if @ruby19_non_utf8_pass
222 227 puts_ruby19_non_utf8_pass()
223 228 else
224 229 with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do
225 230 ['57ca437c', '57ca437c0acbbcb749821fdf3726a1367056d364'].each do |r1|
226 231 get :diff, :id => PRJ_ID, :rev => r1
227 232 assert_response :success
228 233 assert_template 'diff'
229 234 assert_tag :tag => 'thead',
230 235 :descendant => {
231 236 :tag => 'th',
232 237 :attributes => { :class => 'filename' } ,
233 238 :content => /latin-1-dir\/test-#{@char_1}.txt/ ,
234 239 },
235 240 :sibling => {
236 241 :tag => 'tbody',
237 242 :descendant => {
238 243 :tag => 'td',
239 244 :attributes => { :class => /diff_in/ },
240 245 :content => /test-#{@char_1}.txt/
241 246 }
242 247 }
243 248 end
244 249 end
245 250 end
246 251 end
247 252
248 253 def test_annotate
249 254 get :annotate, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
250 255 assert_response :success
251 256 assert_template 'annotate'
252 257 # Line 24, changeset 2f9c0091
253 258 assert_tag :tag => 'th', :content => '24',
254 259 :sibling => {
255 260 :tag => 'td',
256 261 :child => {
257 262 :tag => 'a',
258 263 :content => /2f9c0091c754a91af7a9c478e36556b4bde8dcf7/
259 264 }
260 265 },
261 266 :sibling => { :tag => 'td', :content => /jsmith/ }
262 267 assert_tag :tag => 'th', :content => '24',
263 268 :sibling => {
264 269 :tag => 'td',
265 270 :child => {
266 271 :tag => 'a',
267 272 :content => /2f9c0091c754a91af7a9c478e36556b4bde8dcf7/
268 273 }
269 274 },
270 275 :sibling => { :tag => 'td', :content => /watcher =/ }
271 276 end
272 277
273 278 def test_annotate_at_given_revision
274 279 @repository.fetch_changesets
275 280 @repository.reload
276 281 get :annotate, :id => PRJ_ID, :rev => 'deff7',
277 282 :path => ['sources', 'watchers_controller.rb']
278 283 assert_response :success
279 284 assert_template 'annotate'
280 285 assert_tag :tag => 'h2', :content => /@ deff712f/
281 286 end
282 287
283 288 def test_annotate_binary_file
284 289 get :annotate, :id => PRJ_ID, :path => ['images', 'edit.png']
285 290 assert_response 500
286 291 assert_tag :tag => 'p', :attributes => { :id => /errorExplanation/ },
287 292 :content => /cannot be annotated/
288 293 end
289 294
290 295 def test_annotate_latin_1
291 296 if @ruby19_non_utf8_pass
292 297 puts_ruby19_non_utf8_pass()
293 298 else
294 299 with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do
295 300 ['57ca437c', '57ca437c0acbbcb749821fdf3726a1367056d364'].each do |r1|
296 301 get :annotate, :id => PRJ_ID,
297 302 :path => ['latin-1-dir', "test-#{@char_1}.txt"], :rev => r1
298 303 assert_tag :tag => 'th',
299 304 :content => '1',
300 305 :attributes => { :class => 'line-num' },
301 306 :sibling => { :tag => 'td',
302 307 :content => /test-#{@char_1}.txt/ }
303 308 end
304 309 end
305 310 end
306 311 end
307 312
308 313 def test_revision
309 314 @repository.fetch_changesets
310 315 @repository.reload
311 316 ['61b685fbe55ab05b5ac68402d5720c1a6ac973d1', '61b685f'].each do |r|
312 317 get :revision, :id => PRJ_ID, :rev => r
313 318 assert_response :success
314 319 assert_template 'revision'
315 320 end
316 321 end
317 322
318 323 def test_empty_revision
319 324 @repository.fetch_changesets
320 325 @repository.reload
321 326 ['', ' ', nil].each do |r|
322 327 get :revision, :id => PRJ_ID, :rev => r
323 328 assert_response 404
324 329 assert_error_tag :content => /was not found/
325 330 end
326 331 end
327 332
328 333 private
329 334
330 335 def puts_ruby19_non_utf8_pass
331 336 puts "TODO: This test fails in Ruby 1.9 " +
332 337 "and Encoding.default_external is not UTF-8. " +
333 338 "Current value is '#{Encoding.default_external.to_s}'"
334 339 end
335 340 else
336 341 puts "Git test repository NOT FOUND. Skipping functional tests !!!"
337 342 def test_fake; assert true end
338 343 end
339 344 end
General Comments 0
You need to be logged in to leave comments. Login now