comparison test/unit/changeset_test.rb @ 524:1248a47e81b3 feature_36

Merge from branch "luisf"
author luisf <luis.figueira@eecs.qmul.ac.uk>
date Mon, 25 Jul 2011 14:39:38 +0100
parents cbce1fd3b1b7
children cbb26bc654de
comparison
equal deleted inserted replaced
519:3be6bc3c2a17 524:1248a47e81b3
15 # 15 #
16 # You should have received a copy of the GNU General Public License 16 # You should have received a copy of the GNU General Public License
17 # along with this program; if not, write to the Free Software 17 # along with this program; if not, write to the Free Software
18 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 18 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 19
20 require File.dirname(__FILE__) + '/../test_helper' 20 require File.expand_path('../../test_helper', __FILE__)
21 21
22 class ChangesetTest < ActiveSupport::TestCase 22 class ChangesetTest < ActiveSupport::TestCase
23 fixtures :projects, :repositories, :issues, :issue_statuses, :changesets, :changes, :issue_categories, :enumerations, :custom_fields, :custom_values, :users, :members, :member_roles, :trackers 23 fixtures :projects, :repositories,
24 :issues, :issue_statuses, :issue_categories,
25 :changesets, :changes,
26 :enumerations,
27 :custom_fields, :custom_values,
28 :users, :members, :member_roles, :trackers,
29 :enabled_modules, :roles
24 30
25 def setup 31 def setup
26 end 32 end
27 33
28 def test_ref_keywords_any 34 def test_ref_keywords_any
29 ActionMailer::Base.deliveries.clear 35 ActionMailer::Base.deliveries.clear
30 Setting.commit_fix_status_id = IssueStatus.find(:first, :conditions => ["is_closed = ?", true]).id 36 Setting.commit_fix_status_id = IssueStatus.find(
37 :first, :conditions => ["is_closed = ?", true]).id
31 Setting.commit_fix_done_ratio = '90' 38 Setting.commit_fix_done_ratio = '90'
32 Setting.commit_ref_keywords = '*' 39 Setting.commit_ref_keywords = '*'
33 Setting.commit_fix_keywords = 'fixes , closes' 40 Setting.commit_fix_keywords = 'fixes , closes'
34 41
35 c = Changeset.new(:repository => Project.find(1).repository, 42 c = Changeset.new(:repository => Project.find(1).repository,
36 :committed_on => Time.now, 43 :committed_on => Time.now,
37 :comments => 'New commit (#2). Fixes #1') 44 :comments => 'New commit (#2). Fixes #1')
38 c.scan_comment_for_issue_ids 45 c.scan_comment_for_issue_ids
39 46
40 assert_equal [1, 2], c.issue_ids.sort 47 assert_equal [1, 2], c.issue_ids.sort
41 fixed = Issue.find(1) 48 fixed = Issue.find(1)
42 assert fixed.closed? 49 assert fixed.closed?
43 assert_equal 90, fixed.done_ratio 50 assert_equal 90, fixed.done_ratio
44 assert_equal 1, ActionMailer::Base.deliveries.size 51 assert_equal 1, ActionMailer::Base.deliveries.size
45 end 52 end
46 53
54 def test_ref_keywords
55 Setting.commit_ref_keywords = 'refs'
56 Setting.commit_fix_keywords = ''
57
58 c = Changeset.new(:repository => Project.find(1).repository,
59 :committed_on => Time.now,
60 :comments => 'Ignores #2. Refs #1')
61 c.scan_comment_for_issue_ids
62
63 assert_equal [1], c.issue_ids.sort
64 end
65
66 def test_ref_keywords_any_only
67 Setting.commit_ref_keywords = '*'
68 Setting.commit_fix_keywords = ''
69
70 c = Changeset.new(:repository => Project.find(1).repository,
71 :committed_on => Time.now,
72 :comments => 'Ignores #2. Refs #1')
73 c.scan_comment_for_issue_ids
74
75 assert_equal [1, 2], c.issue_ids.sort
76 end
77
78 def test_ref_keywords_any_with_timelog
79 Setting.commit_ref_keywords = '*'
80 Setting.commit_logtime_enabled = '1'
81
82 {
83 '2' => 2.0,
84 '2h' => 2.0,
85 '2hours' => 2.0,
86 '15m' => 0.25,
87 '15min' => 0.25,
88 '3h15' => 3.25,
89 '3h15m' => 3.25,
90 '3h15min' => 3.25,
91 '3:15' => 3.25,
92 '3.25' => 3.25,
93 '3.25h' => 3.25,
94 '3,25' => 3.25,
95 '3,25h' => 3.25,
96 }.each do |syntax, expected_hours|
97 c = Changeset.new(:repository => Project.find(1).repository,
98 :committed_on => 24.hours.ago,
99 :comments => "Worked on this issue #1 @#{syntax}",
100 :revision => '520',
101 :user => User.find(2))
102 assert_difference 'TimeEntry.count' do
103 c.scan_comment_for_issue_ids
104 end
105 assert_equal [1], c.issue_ids.sort
106
107 time = TimeEntry.first(:order => 'id desc')
108 assert_equal 1, time.issue_id
109 assert_equal 1, time.project_id
110 assert_equal 2, time.user_id
111 assert_equal expected_hours, time.hours,
112 "@#{syntax} should be logged as #{expected_hours} hours but was #{time.hours}"
113 assert_equal Date.yesterday, time.spent_on
114 assert time.activity.is_default?
115 assert time.comments.include?('r520'),
116 "r520 was expected in time_entry comments: #{time.comments}"
117 end
118 end
119
120 def test_ref_keywords_closing_with_timelog
121 Setting.commit_fix_status_id = IssueStatus.find(
122 :first, :conditions => ["is_closed = ?", true]).id
123 Setting.commit_ref_keywords = '*'
124 Setting.commit_fix_keywords = 'fixes , closes'
125 Setting.commit_logtime_enabled = '1'
126
127 c = Changeset.new(:repository => Project.find(1).repository,
128 :committed_on => Time.now,
129 :comments => 'This is a comment. Fixes #1 @4.5, #2 @1',
130 :user => User.find(2))
131 assert_difference 'TimeEntry.count', 2 do
132 c.scan_comment_for_issue_ids
133 end
134
135 assert_equal [1, 2], c.issue_ids.sort
136 assert Issue.find(1).closed?
137 assert Issue.find(2).closed?
138
139 times = TimeEntry.all(:order => 'id desc', :limit => 2)
140 assert_equal [1, 2], times.collect(&:issue_id).sort
141 end
142
47 def test_ref_keywords_any_line_start 143 def test_ref_keywords_any_line_start
48 Setting.commit_ref_keywords = '*' 144 Setting.commit_ref_keywords = '*'
49 145
50 c = Changeset.new(:repository => Project.find(1).repository, 146 c = Changeset.new(:repository => Project.find(1).repository,
51 :committed_on => Time.now, 147 :committed_on => Time.now,
52 :comments => '#1 is the reason of this commit') 148 :comments => '#1 is the reason of this commit')
53 c.scan_comment_for_issue_ids 149 c.scan_comment_for_issue_ids
54 150
55 assert_equal [1], c.issue_ids.sort 151 assert_equal [1], c.issue_ids.sort
56 end 152 end
57 153
58 def test_ref_keywords_allow_brackets_around_a_issue_number 154 def test_ref_keywords_allow_brackets_around_a_issue_number
59 Setting.commit_ref_keywords = '*' 155 Setting.commit_ref_keywords = '*'
60 156
61 c = Changeset.new(:repository => Project.find(1).repository, 157 c = Changeset.new(:repository => Project.find(1).repository,
62 :committed_on => Time.now, 158 :committed_on => Time.now,
63 :comments => '[#1] Worked on this issue') 159 :comments => '[#1] Worked on this issue')
64 c.scan_comment_for_issue_ids 160 c.scan_comment_for_issue_ids
65 161
66 assert_equal [1], c.issue_ids.sort 162 assert_equal [1], c.issue_ids.sort
67 end 163 end
68 164
69 def test_ref_keywords_allow_brackets_around_multiple_issue_numbers 165 def test_ref_keywords_allow_brackets_around_multiple_issue_numbers
70 Setting.commit_ref_keywords = '*' 166 Setting.commit_ref_keywords = '*'
71 167
72 c = Changeset.new(:repository => Project.find(1).repository, 168 c = Changeset.new(:repository => Project.find(1).repository,
73 :committed_on => Time.now, 169 :committed_on => Time.now,
74 :comments => '[#1 #2, #3] Worked on these') 170 :comments => '[#1 #2, #3] Worked on these')
75 c.scan_comment_for_issue_ids 171 c.scan_comment_for_issue_ids
76 172
77 assert_equal [1,2,3], c.issue_ids.sort 173 assert_equal [1,2,3], c.issue_ids.sort
78 end 174 end
79 175
80 def test_commit_referencing_a_subproject_issue 176 def test_commit_referencing_a_subproject_issue
81 c = Changeset.new(:repository => Project.find(1).repository, 177 c = Changeset.new(:repository => Project.find(1).repository,
82 :committed_on => Time.now, 178 :committed_on => Time.now,
83 :comments => 'refs #5, a subproject issue') 179 :comments => 'refs #5, a subproject issue')
84 c.scan_comment_for_issue_ids 180 c.scan_comment_for_issue_ids
85 181
86 assert_equal [5], c.issue_ids.sort 182 assert_equal [5], c.issue_ids.sort
87 assert c.issues.first.project != c.project 183 assert c.issues.first.project != c.project
88 end 184 end
89 185
90 def test_commit_referencing_a_parent_project_issue 186 def test_commit_referencing_a_parent_project_issue
91 # repository of child project 187 # repository of child project
92 r = Repository::Subversion.create!(:project => Project.find(3), :url => 'svn://localhost/test') 188 r = Repository::Subversion.create!(
93 189 :project => Project.find(3),
94 c = Changeset.new(:repository => r, 190 :url => 'svn://localhost/test')
95 :committed_on => Time.now, 191
96 :comments => 'refs #2, an issue of a parent project') 192 c = Changeset.new(:repository => r,
97 c.scan_comment_for_issue_ids 193 :committed_on => Time.now,
98 194 :comments => 'refs #2, an issue of a parent project')
195 c.scan_comment_for_issue_ids
196
99 assert_equal [2], c.issue_ids.sort 197 assert_equal [2], c.issue_ids.sort
100 assert c.issues.first.project != c.project 198 assert c.issues.first.project != c.project
199 end
200
201 def test_text_tag_revision
202 c = Changeset.new(:revision => '520')
203 assert_equal 'r520', c.text_tag
204 end
205
206 def test_text_tag_hash
207 c = Changeset.new(
208 :scmid => '7234cb2750b63f47bff735edc50a1c0a433c2518',
209 :revision => '7234cb2750b63f47bff735edc50a1c0a433c2518')
210 assert_equal 'commit:7234cb2750b63f47bff735edc50a1c0a433c2518', c.text_tag
211 end
212
213 def test_text_tag_hash_all_number
214 c = Changeset.new(:scmid => '0123456789', :revision => '0123456789')
215 assert_equal 'commit:0123456789', c.text_tag
101 end 216 end
102 217
103 def test_previous 218 def test_previous
104 changeset = Changeset.find_by_revision('3') 219 changeset = Changeset.find_by_revision('3')
105 assert_equal Changeset.find_by_revision('2'), changeset.previous 220 assert_equal Changeset.find_by_revision('2'), changeset.previous
117 232
118 def test_next_nil 233 def test_next_nil
119 changeset = Changeset.find_by_revision('10') 234 changeset = Changeset.find_by_revision('10')
120 assert_nil changeset.next 235 assert_nil changeset.next
121 end 236 end
122 237
123 def test_comments_should_be_converted_to_utf8 238 def test_comments_should_be_converted_to_utf8
124 with_settings :commit_logs_encoding => 'ISO-8859-1' do 239 proj = Project.find(3)
125 c = Changeset.new 240 # str = File.read("#{RAILS_ROOT}/test/fixtures/encoding/iso-8859-1.txt")
126 c.comments = File.read("#{RAILS_ROOT}/test/fixtures/encoding/iso-8859-1.txt") 241 str = "Texte encod\xe9 en ISO-8859-1."
127 assert_equal "Texte encodé en ISO-8859-1.", c.comments 242 str.force_encoding("ASCII-8BIT") if str.respond_to?(:force_encoding)
128 end 243 r = Repository::Bazaar.create!(
129 end 244 :project => proj,
130 245 :url => '/tmp/test/bazaar',
131 def test_invalid_utf8_sequences_in_comments_should_be_stripped 246 :log_encoding => 'ISO-8859-1' )
132 c = Changeset.new 247 assert r
133 c.comments = File.read("#{RAILS_ROOT}/test/fixtures/encoding/iso-8859-1.txt") 248 c = Changeset.new(:repository => r,
134 assert_equal "Texte encod en ISO-8859-1.", c.comments 249 :committed_on => Time.now,
250 :revision => '123',
251 :scmid => '12345',
252 :comments => str)
253 assert( c.save )
254 str_utf8 = "Texte encod\xc3\xa9 en ISO-8859-1."
255 str_utf8.force_encoding("UTF-8") if str_utf8.respond_to?(:force_encoding)
256 assert_equal str_utf8, c.comments
257 end
258
259 def test_invalid_utf8_sequences_in_comments_should_be_replaced_latin1
260 proj = Project.find(3)
261 # str = File.read("#{RAILS_ROOT}/test/fixtures/encoding/iso-8859-1.txt")
262 str1 = "Texte encod\xe9 en ISO-8859-1."
263 str2 = "\xe9a\xe9b\xe9c\xe9d\xe9e test"
264 str1.force_encoding("UTF-8") if str1.respond_to?(:force_encoding)
265 str2.force_encoding("ASCII-8BIT") if str2.respond_to?(:force_encoding)
266 r = Repository::Bazaar.create!(
267 :project => proj,
268 :url => '/tmp/test/bazaar',
269 :log_encoding => 'UTF-8' )
270 assert r
271 c = Changeset.new(:repository => r,
272 :committed_on => Time.now,
273 :revision => '123',
274 :scmid => '12345',
275 :comments => str1,
276 :committer => str2)
277 assert( c.save )
278 assert_equal "Texte encod? en ISO-8859-1.", c.comments
279 assert_equal "?a?b?c?d?e test", c.committer
280 end
281
282 def test_invalid_utf8_sequences_in_comments_should_be_replaced_ja_jis
283 proj = Project.find(3)
284 str = "test\xb5\xfetest\xb5\xfe"
285 if str.respond_to?(:force_encoding)
286 str.force_encoding('ASCII-8BIT')
287 end
288 r = Repository::Bazaar.create!(
289 :project => proj,
290 :url => '/tmp/test/bazaar',
291 :log_encoding => 'ISO-2022-JP' )
292 assert r
293 c = Changeset.new(:repository => r,
294 :committed_on => Time.now,
295 :revision => '123',
296 :scmid => '12345',
297 :comments => str)
298 assert( c.save )
299 assert_equal "test??test??", c.comments
300 end
301
302 def test_comments_should_be_converted_all_latin1_to_utf8
303 s1 = "\xC2\x80"
304 s2 = "\xc3\x82\xc2\x80"
305 s4 = s2.dup
306 if s1.respond_to?(:force_encoding)
307 s3 = s1.dup
308 s1.force_encoding('ASCII-8BIT')
309 s2.force_encoding('ASCII-8BIT')
310 s3.force_encoding('ISO-8859-1')
311 s4.force_encoding('UTF-8')
312 assert_equal s3.encode('UTF-8'), s4
313 end
314 proj = Project.find(3)
315 r = Repository::Bazaar.create!(
316 :project => proj,
317 :url => '/tmp/test/bazaar',
318 :log_encoding => 'ISO-8859-1' )
319 assert r
320 c = Changeset.new(:repository => r,
321 :committed_on => Time.now,
322 :revision => '123',
323 :scmid => '12345',
324 :comments => s1)
325 assert( c.save )
326 assert_equal s4, c.comments
327 end
328
329 def test_invalid_utf8_sequences_in_paths_should_be_replaced
330 proj = Project.find(3)
331 str1 = "Texte encod\xe9 en ISO-8859-1"
332 str2 = "\xe9a\xe9b\xe9c\xe9d\xe9e test"
333 str1.force_encoding("UTF-8") if str1.respond_to?(:force_encoding)
334 str2.force_encoding("ASCII-8BIT") if str2.respond_to?(:force_encoding)
335 r = Repository::Bazaar.create!(
336 :project => proj,
337 :url => '/tmp/test/bazaar',
338 :log_encoding => 'UTF-8' )
339 assert r
340 cs = Changeset.new(
341 :repository => r,
342 :committed_on => Time.now,
343 :revision => '123',
344 :scmid => '12345',
345 :comments => "test")
346 assert(cs.save)
347 ch = Change.new(
348 :changeset => cs,
349 :action => "A",
350 :path => str1,
351 :from_path => str2,
352 :from_revision => "345")
353 assert(ch.save)
354 assert_equal "Texte encod? en ISO-8859-1", ch.path
355 assert_equal "?a?b?c?d?e test", ch.from_path
356 end
357
358 def test_comments_nil
359 proj = Project.find(3)
360 r = Repository::Bazaar.create!(
361 :project => proj,
362 :url => '/tmp/test/bazaar',
363 :log_encoding => 'ISO-8859-1' )
364 assert r
365 c = Changeset.new(:repository => r,
366 :committed_on => Time.now,
367 :revision => '123',
368 :scmid => '12345',
369 :comments => nil,
370 :committer => nil)
371 assert( c.save )
372 assert_equal "", c.comments
373 assert_equal nil, c.committer
374 if c.comments.respond_to?(:force_encoding)
375 assert_equal "UTF-8", c.comments.encoding.to_s
376 end
377 end
378
379 def test_comments_empty
380 proj = Project.find(3)
381 r = Repository::Bazaar.create!(
382 :project => proj,
383 :url => '/tmp/test/bazaar',
384 :log_encoding => 'ISO-8859-1' )
385 assert r
386 c = Changeset.new(:repository => r,
387 :committed_on => Time.now,
388 :revision => '123',
389 :scmid => '12345',
390 :comments => "",
391 :committer => "")
392 assert( c.save )
393 assert_equal "", c.comments
394 assert_equal "", c.committer
395 if c.comments.respond_to?(:force_encoding)
396 assert_equal "UTF-8", c.comments.encoding.to_s
397 assert_equal "UTF-8", c.committer.encoding.to_s
398 end
399 end
400
401 def test_identifier
402 c = Changeset.find_by_revision('1')
403 assert_equal c.revision, c.identifier
135 end 404 end
136 end 405 end