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