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