##// END OF EJS Templates
scm: mercurial: use constant for project id in functional test....
Toshi MARUYAMA -
r5081:d5ee82cea91e
parent child
Show More
@@ -1,366 +1,366
1 1 # redMine - project management software
2 2 # Copyright (C) 2006-2008 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 RepositoriesMercurialControllerTest < 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/mercurial_repository'
29 29 CHAR_1_HEX = "\xc3\x9c"
30
30 PRJ_ID = 3
31
31 32 ruby19_non_utf8_pass = (RUBY_VERSION >= '1.9' && Encoding.default_external.to_s != 'UTF-8')
32 33
33 34 def setup
34 35 @controller = RepositoriesController.new
35 36 @request = ActionController::TestRequest.new
36 37 @response = ActionController::TestResponse.new
37 38 User.current = nil
38 39 @repository = Repository::Mercurial.create(
39 :project => Project.find(3),
40 :project => Project.find(PRJ_ID),
40 41 :url => REPOSITORY_PATH,
41 42 :path_encoding => 'ISO-8859-1'
42 43 )
43 44 assert @repository
44 45 @diff_c_support = true
45 46 @char_1 = CHAR_1_HEX.dup
46 47 @tag_char_1 = "tag-#{CHAR_1_HEX}-00"
47 48 @branch_char_0 = "branch-#{CHAR_1_HEX}-00"
48 49 @branch_char_1 = "branch-#{CHAR_1_HEX}-01"
49 50 if @char_1.respond_to?(:force_encoding)
50 51 @char_1.force_encoding('UTF-8')
51 52 @tag_char_1.force_encoding('UTF-8')
52 53 @branch_char_0.force_encoding('UTF-8')
53 54 @branch_char_1.force_encoding('UTF-8')
54 55 end
55 56 end
56 57
57 58 if ruby19_non_utf8_pass
58 59 puts "TODO: Mercurial functional test fails in Ruby 1.9 " +
59 60 "and Encoding.default_external is not UTF-8. " +
60 61 "Current value is '#{Encoding.default_external.to_s}'"
61 62 def test_fake; assert true end
62 63 elsif File.directory?(REPOSITORY_PATH)
63 64 def test_show_root
64 65 @repository.fetch_changesets
65 66 @repository.reload
66 get :show, :id => 3
67 get :show, :id => PRJ_ID
67 68 assert_response :success
68 69 assert_template 'show'
69 70 assert_not_nil assigns(:entries)
70 71 assert_equal 4, assigns(:entries).size
71 72 assert assigns(:entries).detect {|e| e.name == 'images' && e.kind == 'dir'}
72 73 assert assigns(:entries).detect {|e| e.name == 'sources' && e.kind == 'dir'}
73 74 assert assigns(:entries).detect {|e| e.name == 'README' && e.kind == 'file'}
74 75 assert_not_nil assigns(:changesets)
75 76 assigns(:changesets).size > 0
76 77 end
77 78
78 79 def test_show_directory
79 80 @repository.fetch_changesets
80 81 @repository.reload
81 get :show, :id => 3, :path => ['images']
82 get :show, :id => PRJ_ID, :path => ['images']
82 83 assert_response :success
83 84 assert_template 'show'
84 85 assert_not_nil assigns(:entries)
85 86 assert_equal ['delete.png', 'edit.png'], assigns(:entries).collect(&:name)
86 87 entry = assigns(:entries).detect {|e| e.name == 'edit.png'}
87 88 assert_not_nil entry
88 89 assert_equal 'file', entry.kind
89 90 assert_equal 'images/edit.png', entry.path
90 91 assert_not_nil assigns(:changesets)
91 92 assigns(:changesets).size > 0
92 93 end
93 94
94 95 def test_show_at_given_revision
95 96 @repository.fetch_changesets
96 97 @repository.reload
97 98 [0, '0', '0885933ad4f6'].each do |r1|
98 get :show, :id => 3, :path => ['images'], :rev => r1
99 get :show, :id => PRJ_ID, :path => ['images'], :rev => r1
99 100 assert_response :success
100 101 assert_template 'show'
101 102 assert_not_nil assigns(:entries)
102 103 assert_equal ['delete.png'], assigns(:entries).collect(&:name)
103 104 assert_not_nil assigns(:changesets)
104 105 assigns(:changesets).size > 0
105 106 end
106 107 end
107 108
108 109 def test_show_directory_sql_escape_percent
109 110 @repository.fetch_changesets
110 111 @repository.reload
111 112 [13, '13', '3a330eb32958'].each do |r1|
112 get :show, :id => 3, :path => ['sql_escape', 'percent%dir'], :rev => r1
113 get :show, :id => PRJ_ID, :path => ['sql_escape', 'percent%dir'], :rev => r1
113 114 assert_response :success
114 115 assert_template 'show'
115 116
116 117 assert_not_nil assigns(:entries)
117 118 assert_equal ['percent%file1.txt', 'percentfile1.txt'], assigns(:entries).collect(&:name)
118 119 changesets = assigns(:changesets)
119 120 assert_not_nil changesets
120 121 assigns(:changesets).size > 0
121 122 assert_equal %w(13 11 10 9), changesets.collect(&:revision)
122 123 end
123 124 end
124 125
125 126 def test_show_directory_latin_1
126 127 @repository.fetch_changesets
127 128 @repository.reload
128 129 [21, '21', 'adf805632193'].each do |r1|
129 get :show, :id => 3, :path => ['latin-1-dir'], :rev => r1
130 get :show, :id => PRJ_ID, :path => ['latin-1-dir'], :rev => r1
130 131 assert_response :success
131 132 assert_template 'show'
132 133
133 134 assert_not_nil assigns(:entries)
134 135 assert_equal ["make-latin-1-file.rb",
135 136 "test-#{@char_1}-1.txt",
136 137 "test-#{@char_1}-2.txt",
137 138 "test-#{@char_1}.txt"], assigns(:entries).collect(&:name)
138 139 changesets = assigns(:changesets)
139 140 assert_not_nil changesets
140 141 assert_equal %w(21 20 19 18 17), changesets.collect(&:revision)
141 142 end
142 143 end
143 144
144 145 def test_show_branch
145 146 @repository.fetch_changesets
146 147 @repository.reload
147 148 [
148 149 'default',
149 150 @branch_char_1,
150 151 'branch (1)[2]&,%.-3_4',
151 152 @branch_char_0,
152 153 'test_branch.latin-1',
153 154 'test-branch-00',
154 155 ].each do |bra|
155 get :show, :id => 3, :rev => bra
156 get :show, :id => PRJ_ID, :rev => bra
156 157 assert_response :success
157 158 assert_template 'show'
158 159 assert_not_nil assigns(:entries)
159 160 assert assigns(:entries).size > 0
160 161 assert_not_nil assigns(:changesets)
161 162 assigns(:changesets).size > 0
162 163 end
163 164 end
164 165
165 166 def test_show_tag
166 167 @repository.fetch_changesets
167 168 @repository.reload
168 169 [
169 170 @tag_char_1,
170 171 'tag_test.00',
171 172 'tag-init-revision'
172 173 ].each do |tag|
173 get :show, :id => 3, :rev => tag
174 get :show, :id => PRJ_ID, :rev => tag
174 175 assert_response :success
175 176 assert_template 'show'
176 177 assert_not_nil assigns(:entries)
177 178 assert assigns(:entries).size > 0
178 179 assert_not_nil assigns(:changesets)
179 180 assigns(:changesets).size > 0
180 181 end
181 182 end
182 183
183 184 def test_changes
184 get :changes, :id => 3, :path => ['images', 'edit.png']
185 get :changes, :id => PRJ_ID, :path => ['images', 'edit.png']
185 186 assert_response :success
186 187 assert_template 'changes'
187 188 assert_tag :tag => 'h2', :content => 'edit.png'
188 189 end
189 190
190 191 def test_entry_show
191 get :entry, :id => 3, :path => ['sources', 'watchers_controller.rb']
192 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
192 193 assert_response :success
193 194 assert_template 'entry'
194 195 # Line 10
195 196 assert_tag :tag => 'th',
196 197 :content => '10',
197 198 :attributes => { :class => 'line-num' },
198 199 :sibling => { :tag => 'td', :content => /WITHOUT ANY WARRANTY/ }
199 200 end
200 201
201 202 def test_entry_show_latin_1
202 203 [21, '21', 'adf805632193'].each do |r1|
203 get :entry, :id => 3, :path => ['latin-1-dir', "test-#{@char_1}-2.txt"], :rev => r1
204 get :entry, :id => PRJ_ID, :path => ['latin-1-dir', "test-#{@char_1}-2.txt"], :rev => r1
204 205 assert_response :success
205 206 assert_template 'entry'
206 207 assert_tag :tag => 'th',
207 208 :content => '1',
208 209 :attributes => { :class => 'line-num' },
209 :sibling => { :tag => 'td', :content => /Mercurial is a distributed version control system/ }
210 :sibling => { :tag => 'td',
211 :content => /Mercurial is a distributed version control system/ }
210 212 end
211 213 end
212 214
213 215 def test_entry_download
214 get :entry, :id => 3, :path => ['sources', 'watchers_controller.rb'], :format => 'raw'
216 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb'], :format => 'raw'
215 217 assert_response :success
216 218 # File content
217 219 assert @response.body.include?('WITHOUT ANY WARRANTY')
218 220 end
219 221
220 222 def test_directory_entry
221 get :entry, :id => 3, :path => ['sources']
223 get :entry, :id => PRJ_ID, :path => ['sources']
222 224 assert_response :success
223 225 assert_template 'show'
224 226 assert_not_nil assigns(:entry)
225 227 assert_equal 'sources', assigns(:entry).name
226 228 end
227 229
228 230 def test_diff
229 231 @repository.fetch_changesets
230 232 @repository.reload
231
232 233 [4, '4', 'def6d2f1254a'].each do |r1|
233 234 # Full diff of changeset 4
234 get :diff, :id => 3, :rev => r1
235 get :diff, :id => PRJ_ID, :rev => r1
235 236 assert_response :success
236 237 assert_template 'diff'
237
238 238 if @diff_c_support
239 239 # Line 22 removed
240 240 assert_tag :tag => 'th',
241 241 :content => '22',
242 242 :sibling => { :tag => 'td',
243 243 :attributes => { :class => /diff_out/ },
244 244 :content => /def remove/ }
245 245 assert_tag :tag => 'h2', :content => /4:def6d2f1254a/
246 246 end
247 247 end
248 248 end
249 249
250 250 def test_diff_two_revs
251 251 @repository.fetch_changesets
252 252 @repository.reload
253
254 253 [2, '400bb8672109', '400', 400].each do |r1|
255 254 [4, 'def6d2f1254a'].each do |r2|
256 get :diff, :id => 3, :rev => r1,
257 :rev_to => r2
255 get :diff, :id => PRJ_ID, :rev => r1,
256 :rev_to => r2
258 257 assert_response :success
259 258 assert_template 'diff'
260 259
261 260 diff = assigns(:diff)
262 261 assert_not_nil diff
263 262 assert_tag :tag => 'h2', :content => /4:def6d2f1254a 2:400bb8672109/
264 263 end
265 264 end
266 265 end
267 266
268 267 def test_diff_latin_1
269 268 [21, 'adf805632193'].each do |r1|
270 get :diff, :id => 3, :rev => r1
269 get :diff, :id => PRJ_ID, :rev => r1
271 270 assert_response :success
272 271 assert_template 'diff'
273 272 assert_tag :tag => 'th',
274 273 :content => '2',
275 274 :sibling => { :tag => 'td',
276 275 :attributes => { :class => /diff_in/ },
277 276 :content => /It is written in Python/ }
278 277 end
279 278 end
280 279
281 280 def test_annotate
282 get :annotate, :id => 3, :path => ['sources', 'watchers_controller.rb']
281 get :annotate, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
283 282 assert_response :success
284 283 assert_template 'annotate'
285 284 # Line 23, revision 4:def6d2f1254a
286 285 assert_tag :tag => 'th',
287 286 :content => '23',
288 287 :attributes => { :class => 'line-num' },
289 288 :sibling =>
290 289 {
291 290 :tag => 'td',
292 291 :attributes => { :class => 'revision' },
293 292 :child => { :tag => 'a', :content => '4:def6d2f1254a' }
294 293 }
295 294 assert_tag :tag => 'th',
296 295 :content => '23',
297 296 :attributes => { :class => 'line-num' },
298 297 :sibling =>
299 298 {
300 299 :tag => 'td' ,
301 300 :content => 'jsmith' ,
302 301 :attributes => { :class => 'author' },
303 302 }
304 303 assert_tag :tag => 'th',
305 304 :content => '23',
306 305 :attributes => { :class => 'line-num' },
307 306 :sibling => { :tag => 'td', :content => /watcher =/ }
308 307 end
309 308
310 309 def test_annotate_at_given_revision
311 310 @repository.fetch_changesets
312 311 @repository.reload
313 312 [2, '400bb8672109', '400', 400].each do |r1|
314 get :annotate, :id => 3, :rev => r1, :path => ['sources', 'watchers_controller.rb']
313 get :annotate, :id => PRJ_ID, :rev => r1, :path => ['sources', 'watchers_controller.rb']
315 314 assert_response :success
316 315 assert_template 'annotate'
317 316 assert_tag :tag => 'h2', :content => /@ 2:400bb8672109/
318 317 end
319 318 end
320 319
321 320 def test_annotate_latin_1
322 321 [21, '21', 'adf805632193'].each do |r1|
323 get :annotate, :id => 3, :path => ['latin-1-dir', "test-#{@char_1}-2.txt"], :rev => r1
322 get :annotate, :id => PRJ_ID, :path => ['latin-1-dir', "test-#{@char_1}-2.txt"], :rev => r1
324 323 assert_response :success
325 324 assert_template 'annotate'
326 325 assert_tag :tag => 'th',
327 326 :content => '1',
328 327 :attributes => { :class => 'line-num' },
329 328 :sibling =>
330 329 {
331 330 :tag => 'td',
332 331 :attributes => { :class => 'revision' },
333 332 :child => { :tag => 'a', :content => '20:709858aafd1b' }
334 333 }
335 334 assert_tag :tag => 'th',
336 335 :content => '1',
337 336 :attributes => { :class => 'line-num' },
338 337 :sibling =>
339 338 {
340 339 :tag => 'td' ,
341 340 :content => 'jsmith' ,
342 341 :attributes => { :class => 'author' },
343 342
344 343 }
345 344 assert_tag :tag => 'th',
346 345 :content => '1',
347 346 :attributes => { :class => 'line-num' },
348 :sibling => { :tag => 'td', :content => /Mercurial is a distributed version control system/ }
347 :sibling => { :tag => 'td',
348 :content => /Mercurial is a distributed version control system/ }
349 349
350 350 end
351 351 end
352 352
353 353 def test_empty_revision
354 354 @repository.fetch_changesets
355 355 @repository.reload
356 356 ['', ' ', nil].each do |r|
357 get :revision, :id => 3, :rev => r
357 get :revision, :id => PRJ_ID, :rev => r
358 358 assert_response 404
359 359 assert_error_tag :content => /was not found/
360 360 end
361 361 end
362 362 else
363 363 puts "Mercurial test repository NOT FOUND. Skipping functional tests !!!"
364 364 def test_fake; assert true end
365 365 end
366 366 end
General Comments 0
You need to be logged in to leave comments. Login now