##// END OF EJS Templates
Rails3: scm: cvs: fix error of test_entry_at_given_revision at functional test...
Toshi MARUYAMA -
r7059:12a13fc80d2d
parent child
Show More
@@ -1,272 +1,274
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2011 Jean-Philippe Lang
3 3 #
4 4 # This program is free software; you can redistribute it and/or
5 5 # modify it under the terms of the GNU General Public License
6 6 # as published by the Free Software Foundation; either version 2
7 7 # of the License, or (at your option) any later version.
8 8 #
9 9 # This program is distributed in the hope that it will be useful,
10 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 12 # GNU General Public License for more details.
13 13 #
14 14 # You should have received a copy of the GNU General Public License
15 15 # along with this program; if not, write to the Free Software
16 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 18 require File.expand_path('../../test_helper', __FILE__)
19 19 require 'repositories_controller'
20 20
21 21 # Re-raise errors caught by the controller.
22 22 class RepositoriesController; def rescue_action(e) raise e end; end
23 23
24 24 class RepositoriesCvsControllerTest < ActionController::TestCase
25 25 fixtures :projects, :users, :roles, :members, :member_roles,
26 26 :repositories, :enabled_modules
27 27
28 28 REPOSITORY_PATH = Rails.root.join('tmp/test/cvs_repository').to_s
29 29 REPOSITORY_PATH.gsub!(/\//, "\\") if Redmine::Platform.mswin?
30 30 # CVS module
31 31 MODULE_NAME = 'test'
32 32 PRJ_ID = 3
33 33 NUM_REV = 7
34 34
35 35 def setup
36 36 @controller = RepositoriesController.new
37 37 @request = ActionController::TestRequest.new
38 38 @response = ActionController::TestResponse.new
39 39 Setting.default_language = 'en'
40 40 User.current = nil
41 41
42 42 @project = Project.find(PRJ_ID)
43 43 @repository = Repository::Cvs.create(:project => Project.find(PRJ_ID),
44 44 :root_url => REPOSITORY_PATH,
45 45 :url => MODULE_NAME,
46 46 :log_encoding => 'UTF-8')
47 47 assert @repository
48 48 end
49 49
50 50 if File.directory?(REPOSITORY_PATH)
51 51 def test_browse_root
52 52 assert_equal 0, @repository.changesets.count
53 53 @repository.fetch_changesets
54 54 @project.reload
55 55 assert_equal NUM_REV, @repository.changesets.count
56 56 get :show, :id => PRJ_ID
57 57 assert_response :success
58 58 assert_template 'show'
59 59 assert_not_nil assigns(:entries)
60 60 assert_equal 3, assigns(:entries).size
61 61
62 62 entry = assigns(:entries).detect {|e| e.name == 'images'}
63 63 assert_equal 'dir', entry.kind
64 64
65 65 entry = assigns(:entries).detect {|e| e.name == 'README'}
66 66 assert_equal 'file', entry.kind
67 67
68 68 assert_not_nil assigns(:changesets)
69 69 assert assigns(:changesets).size > 0
70 70 end
71 71
72 72 def test_browse_directory
73 73 assert_equal 0, @repository.changesets.count
74 74 @repository.fetch_changesets
75 75 @project.reload
76 76 assert_equal NUM_REV, @repository.changesets.count
77 77 get :show, :id => PRJ_ID, :path => ['images']
78 78 assert_response :success
79 79 assert_template 'show'
80 80 assert_not_nil assigns(:entries)
81 81 assert_equal ['add.png', 'delete.png', 'edit.png'], assigns(:entries).collect(&:name)
82 82 entry = assigns(:entries).detect {|e| e.name == 'edit.png'}
83 83 assert_not_nil entry
84 84 assert_equal 'file', entry.kind
85 85 assert_equal 'images/edit.png', entry.path
86 86 end
87 87
88 88 def test_browse_at_given_revision
89 89 assert_equal 0, @repository.changesets.count
90 90 @repository.fetch_changesets
91 91 @project.reload
92 92 assert_equal NUM_REV, @repository.changesets.count
93 93 get :show, :id => PRJ_ID, :path => ['images'], :rev => 1
94 94 assert_response :success
95 95 assert_template 'show'
96 96 assert_not_nil assigns(:entries)
97 97 assert_equal ['delete.png', 'edit.png'], assigns(:entries).collect(&:name)
98 98 end
99 99
100 100 def test_entry
101 101 assert_equal 0, @repository.changesets.count
102 102 @repository.fetch_changesets
103 103 @project.reload
104 104 assert_equal NUM_REV, @repository.changesets.count
105 105 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
106 106 assert_response :success
107 107 assert_template 'entry'
108 108 assert_no_tag :tag => 'td',
109 109 :attributes => { :class => /line-code/},
110 110 :content => /before_filter/
111 111 end
112 112
113 113 def test_entry_at_given_revision
114 114 # changesets must be loaded
115 assert_equal 0, @repository.changesets.count
115 116 @repository.fetch_changesets
116 @repository.reload
117 @project.reload
118 assert_equal NUM_REV, @repository.changesets.count
117 119 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb'], :rev => 2
118 120 assert_response :success
119 121 assert_template 'entry'
120 122 # this line was removed in r3
121 123 assert_tag :tag => 'td',
122 124 :attributes => { :class => /line-code/},
123 125 :content => /before_filter/
124 126 end
125 127
126 128 def test_entry_not_found
127 129 @repository.fetch_changesets
128 130 @repository.reload
129 131 get :entry, :id => PRJ_ID, :path => ['sources', 'zzz.c']
130 132 assert_tag :tag => 'p',
131 133 :attributes => { :id => /errorExplanation/ },
132 134 :content => /The entry or revision was not found in the repository/
133 135 end
134 136
135 137 def test_entry_download
136 138 @repository.fetch_changesets
137 139 @repository.reload
138 140 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb'],
139 141 :format => 'raw'
140 142 assert_response :success
141 143 end
142 144
143 145 def test_directory_entry
144 146 @repository.fetch_changesets
145 147 @repository.reload
146 148 get :entry, :id => PRJ_ID, :path => ['sources']
147 149 assert_response :success
148 150 assert_template 'show'
149 151 assert_not_nil assigns(:entry)
150 152 assert_equal 'sources', assigns(:entry).name
151 153 end
152 154
153 155 def test_diff
154 156 @repository.fetch_changesets
155 157 @repository.reload
156 158 ['inline', 'sbs'].each do |dt|
157 159 get :diff, :id => PRJ_ID, :rev => 3, :type => dt
158 160 assert_response :success
159 161 assert_template 'diff'
160 162 assert_tag :tag => 'td', :attributes => { :class => 'line-code diff_out' },
161 163 :content => /before_filter :require_login/
162 164 assert_tag :tag => 'td', :attributes => { :class => 'line-code diff_in' },
163 165 :content => /with one change/
164 166 end
165 167 end
166 168
167 169 def test_diff_new_files
168 170 assert_equal 0, @repository.changesets.count
169 171 @repository.fetch_changesets
170 172 @project.reload
171 173 assert_equal NUM_REV, @repository.changesets.count
172 174 ['inline', 'sbs'].each do |dt|
173 175 get :diff, :id => PRJ_ID, :rev => 1, :type => dt
174 176 assert_response :success
175 177 assert_template 'diff'
176 178 assert_tag :tag => 'td', :attributes => { :class => 'line-code diff_in' },
177 179 :content => /watched.remove_watcher/
178 180 assert_tag :tag => 'th', :attributes => { :class => 'filename' },
179 181 :content => /test\/README/
180 182 assert_tag :tag => 'th', :attributes => { :class => 'filename' },
181 183 :content => /test\/images\/delete.png /
182 184 assert_tag :tag => 'th', :attributes => { :class => 'filename' },
183 185 :content => /test\/images\/edit.png/
184 186 assert_tag :tag => 'th', :attributes => { :class => 'filename' },
185 187 :content => /test\/sources\/watchers_controller.rb/
186 188 end
187 189 end
188 190
189 191 def test_annotate
190 192 assert_equal 0, @repository.changesets.count
191 193 @repository.fetch_changesets
192 194 @project.reload
193 195 assert_equal NUM_REV, @repository.changesets.count
194 196 get :annotate, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
195 197 assert_response :success
196 198 assert_template 'annotate'
197 199 # 1.1 line
198 200 assert_tag :tag => 'th',
199 201 :attributes => { :class => 'line-num' },
200 202 :content => '18',
201 203 :sibling => {
202 204 :tag => 'td',
203 205 :attributes => { :class => 'revision' },
204 206 :content => /1.1/,
205 207 :sibling => {
206 208 :tag => 'td',
207 209 :attributes => { :class => 'author' },
208 210 :content => /LANG/
209 211 }
210 212 }
211 213 # 1.2 line
212 214 assert_tag :tag => 'th',
213 215 :attributes => { :class => 'line-num' },
214 216 :content => '32',
215 217 :sibling => {
216 218 :tag => 'td',
217 219 :attributes => { :class => 'revision' },
218 220 :content => /1.2/,
219 221 :sibling => {
220 222 :tag => 'td',
221 223 :attributes => { :class => 'author' },
222 224 :content => /LANG/
223 225 }
224 226 }
225 227 end
226 228
227 229 def test_destroy_valid_repository
228 230 @request.session[:user_id] = 1 # admin
229 231 assert_equal 0, @repository.changesets.count
230 232 @repository.fetch_changesets
231 233 @project.reload
232 234 assert_equal NUM_REV, @repository.changesets.count
233 235
234 236 get :destroy, :id => PRJ_ID
235 237 assert_response 302
236 238 @project.reload
237 239 assert_nil @project.repository
238 240 end
239 241
240 242 def test_destroy_invalid_repository
241 243 @request.session[:user_id] = 1 # admin
242 244 assert_equal 0, @repository.changesets.count
243 245 @repository.fetch_changesets
244 246 @project.reload
245 247 assert_equal NUM_REV, @repository.changesets.count
246 248
247 249 get :destroy, :id => PRJ_ID
248 250 assert_response 302
249 251 @project.reload
250 252 assert_nil @project.repository
251 253
252 254 @repository = Repository::Cvs.create(
253 255 :project => Project.find(PRJ_ID),
254 256 :root_url => "/invalid",
255 257 :url => MODULE_NAME,
256 258 :log_encoding => 'UTF-8'
257 259 )
258 260 assert @repository
259 261 @repository.fetch_changesets
260 262 @project.reload
261 263 assert_equal 0, @repository.changesets.count
262 264
263 265 get :destroy, :id => PRJ_ID
264 266 assert_response 302
265 267 @project.reload
266 268 assert_nil @project.repository
267 269 end
268 270 else
269 271 puts "CVS test repository NOT FOUND. Skipping functional tests !!!"
270 272 def test_fake; assert true end
271 273 end
272 274 end
General Comments 0
You need to be logged in to leave comments. Login now