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