To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / test / unit / changeset_test.rb @ 441:cbce1fd3b1b7

History | View | Annotate | Download (13.8 KB)

1 0:513646585e45 Chris
# encoding: utf-8
2
#
3
# Redmine - project management software
4
# Copyright (C) 2006-2010  Jean-Philippe Lang
5
#
6
# This program is free software; you can redistribute it and/or
7
# modify it under the terms of the GNU General Public License
8
# as published by the Free Software Foundation; either version 2
9
# of the License, or (at your option) any later version.
10
#
11
# This program is distributed in the hope that it will be useful,
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
# GNU General Public License for more details.
15
#
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
18
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
19
20 119:8661b858af72 Chris
require File.expand_path('../../test_helper', __FILE__)
21 0:513646585e45 Chris
22
class ChangesetTest < ActiveSupport::TestCase
23 441:cbce1fd3b1b7 Chris
  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
30 0:513646585e45 Chris
31
  def setup
32
  end
33 441:cbce1fd3b1b7 Chris
34 0:513646585e45 Chris
  def test_ref_keywords_any
35
    ActionMailer::Base.deliveries.clear
36 441:cbce1fd3b1b7 Chris
    Setting.commit_fix_status_id = IssueStatus.find(
37
                                   :first, :conditions => ["is_closed = ?", true]).id
38 0:513646585e45 Chris
    Setting.commit_fix_done_ratio = '90'
39
    Setting.commit_ref_keywords = '*'
40
    Setting.commit_fix_keywords = 'fixes , closes'
41 441:cbce1fd3b1b7 Chris
42
    c = Changeset.new(:repository   => Project.find(1).repository,
43 0:513646585e45 Chris
                      :committed_on => Time.now,
44 441:cbce1fd3b1b7 Chris
                      :comments     => 'New commit (#2). Fixes #1')
45 0:513646585e45 Chris
    c.scan_comment_for_issue_ids
46 441:cbce1fd3b1b7 Chris
47 0:513646585e45 Chris
    assert_equal [1, 2], c.issue_ids.sort
48
    fixed = Issue.find(1)
49
    assert fixed.closed?
50
    assert_equal 90, fixed.done_ratio
51
    assert_equal 1, ActionMailer::Base.deliveries.size
52
  end
53 441:cbce1fd3b1b7 Chris
54 119:8661b858af72 Chris
  def test_ref_keywords
55
    Setting.commit_ref_keywords = 'refs'
56
    Setting.commit_fix_keywords = ''
57 441:cbce1fd3b1b7 Chris
58
    c = Changeset.new(:repository   => Project.find(1).repository,
59 119:8661b858af72 Chris
                      :committed_on => Time.now,
60 441:cbce1fd3b1b7 Chris
                      :comments     => 'Ignores #2. Refs #1')
61 119:8661b858af72 Chris
    c.scan_comment_for_issue_ids
62
63
    assert_equal [1], c.issue_ids.sort
64
  end
65 441:cbce1fd3b1b7 Chris
66 119:8661b858af72 Chris
  def test_ref_keywords_any_only
67
    Setting.commit_ref_keywords = '*'
68
    Setting.commit_fix_keywords = ''
69
70 441:cbce1fd3b1b7 Chris
    c = Changeset.new(:repository   => Project.find(1).repository,
71 119:8661b858af72 Chris
                      :committed_on => Time.now,
72 441:cbce1fd3b1b7 Chris
                      :comments     => 'Ignores #2. Refs #1')
73 119:8661b858af72 Chris
    c.scan_comment_for_issue_ids
74 441:cbce1fd3b1b7 Chris
75 119:8661b858af72 Chris
    assert_equal [1, 2], c.issue_ids.sort
76
  end
77 441:cbce1fd3b1b7 Chris
78 119:8661b858af72 Chris
  def test_ref_keywords_any_with_timelog
79
    Setting.commit_ref_keywords = '*'
80
    Setting.commit_logtime_enabled = '1'
81
82 245:051f544170fe Chris
    {
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 441:cbce1fd3b1b7 Chris
      c = Changeset.new(:repository   => Project.find(1).repository,
98 245:051f544170fe Chris
                        :committed_on => 24.hours.ago,
99 441:cbce1fd3b1b7 Chris
                        :comments     => "Worked on this issue #1 @#{syntax}",
100
                        :revision     => '520',
101
                        :user         => User.find(2))
102 245:051f544170fe Chris
      assert_difference 'TimeEntry.count' do
103
        c.scan_comment_for_issue_ids
104
      end
105
      assert_equal [1], c.issue_ids.sort
106 441:cbce1fd3b1b7 Chris
107 245:051f544170fe Chris
      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 441:cbce1fd3b1b7 Chris
      assert_equal expected_hours, time.hours,
112
          "@#{syntax} should be logged as #{expected_hours} hours but was #{time.hours}"
113 245:051f544170fe Chris
      assert_equal Date.yesterday, time.spent_on
114
      assert time.activity.is_default?
115 441:cbce1fd3b1b7 Chris
      assert time.comments.include?('r520'),
116
            "r520 was expected in time_entry comments: #{time.comments}"
117 119:8661b858af72 Chris
    end
118
  end
119 441:cbce1fd3b1b7 Chris
120 119:8661b858af72 Chris
  def test_ref_keywords_closing_with_timelog
121 441:cbce1fd3b1b7 Chris
    Setting.commit_fix_status_id = IssueStatus.find(
122
                                    :first, :conditions => ["is_closed = ?", true]).id
123 119:8661b858af72 Chris
    Setting.commit_ref_keywords = '*'
124
    Setting.commit_fix_keywords = 'fixes , closes'
125
    Setting.commit_logtime_enabled = '1'
126
127 441:cbce1fd3b1b7 Chris
    c = Changeset.new(:repository   => Project.find(1).repository,
128 119:8661b858af72 Chris
                      :committed_on => Time.now,
129 441:cbce1fd3b1b7 Chris
                      :comments     => 'This is a comment. Fixes #1 @4.5, #2 @1',
130
                      :user         => User.find(2))
131 119:8661b858af72 Chris
    assert_difference 'TimeEntry.count', 2 do
132
      c.scan_comment_for_issue_ids
133
    end
134 441:cbce1fd3b1b7 Chris
135 119:8661b858af72 Chris
    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 441:cbce1fd3b1b7 Chris
143 0:513646585e45 Chris
  def test_ref_keywords_any_line_start
144
    Setting.commit_ref_keywords = '*'
145
146 441:cbce1fd3b1b7 Chris
    c = Changeset.new(:repository   => Project.find(1).repository,
147 0:513646585e45 Chris
                      :committed_on => Time.now,
148 441:cbce1fd3b1b7 Chris
                      :comments     => '#1 is the reason of this commit')
149 0:513646585e45 Chris
    c.scan_comment_for_issue_ids
150
151
    assert_equal [1], c.issue_ids.sort
152
  end
153
154
  def test_ref_keywords_allow_brackets_around_a_issue_number
155
    Setting.commit_ref_keywords = '*'
156
157 441:cbce1fd3b1b7 Chris
    c = Changeset.new(:repository   => Project.find(1).repository,
158 0:513646585e45 Chris
                      :committed_on => Time.now,
159 441:cbce1fd3b1b7 Chris
                      :comments     => '[#1] Worked on this issue')
160 0:513646585e45 Chris
    c.scan_comment_for_issue_ids
161
162
    assert_equal [1], c.issue_ids.sort
163
  end
164
165
  def test_ref_keywords_allow_brackets_around_multiple_issue_numbers
166
    Setting.commit_ref_keywords = '*'
167
168 441:cbce1fd3b1b7 Chris
    c = Changeset.new(:repository   => Project.find(1).repository,
169 0:513646585e45 Chris
                      :committed_on => Time.now,
170 441:cbce1fd3b1b7 Chris
                      :comments     => '[#1 #2, #3] Worked on these')
171 0:513646585e45 Chris
    c.scan_comment_for_issue_ids
172
173
    assert_equal [1,2,3], c.issue_ids.sort
174
  end
175 441:cbce1fd3b1b7 Chris
176 0:513646585e45 Chris
  def test_commit_referencing_a_subproject_issue
177 441:cbce1fd3b1b7 Chris
    c = Changeset.new(:repository   => Project.find(1).repository,
178 0:513646585e45 Chris
                      :committed_on => Time.now,
179 441:cbce1fd3b1b7 Chris
                      :comments     => 'refs #5, a subproject issue')
180 0:513646585e45 Chris
    c.scan_comment_for_issue_ids
181 441:cbce1fd3b1b7 Chris
182 0:513646585e45 Chris
    assert_equal [5], c.issue_ids.sort
183
    assert c.issues.first.project != c.project
184
  end
185
186
  def test_commit_referencing_a_parent_project_issue
187
    # repository of child project
188 441:cbce1fd3b1b7 Chris
    r = Repository::Subversion.create!(
189
          :project => Project.find(3),
190
          :url     => 'svn://localhost/test')
191
192
    c = Changeset.new(:repository   => r,
193 0:513646585e45 Chris
                      :committed_on => Time.now,
194 441:cbce1fd3b1b7 Chris
                      :comments     => 'refs #2, an issue of a parent project')
195 0:513646585e45 Chris
    c.scan_comment_for_issue_ids
196 441:cbce1fd3b1b7 Chris
197 0:513646585e45 Chris
    assert_equal [2], c.issue_ids.sort
198
    assert c.issues.first.project != c.project
199
  end
200 245:051f544170fe Chris
201 119:8661b858af72 Chris
  def test_text_tag_revision
202
    c = Changeset.new(:revision => '520')
203
    assert_equal 'r520', c.text_tag
204
  end
205 245:051f544170fe Chris
206 119:8661b858af72 Chris
  def test_text_tag_hash
207 441:cbce1fd3b1b7 Chris
    c = Changeset.new(
208
          :scmid    => '7234cb2750b63f47bff735edc50a1c0a433c2518',
209
          :revision => '7234cb2750b63f47bff735edc50a1c0a433c2518')
210 119:8661b858af72 Chris
    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
216
  end
217 0:513646585e45 Chris
218
  def test_previous
219
    changeset = Changeset.find_by_revision('3')
220
    assert_equal Changeset.find_by_revision('2'), changeset.previous
221
  end
222
223
  def test_previous_nil
224
    changeset = Changeset.find_by_revision('1')
225
    assert_nil changeset.previous
226
  end
227
228
  def test_next
229
    changeset = Changeset.find_by_revision('2')
230
    assert_equal Changeset.find_by_revision('3'), changeset.next
231
  end
232
233
  def test_next_nil
234
    changeset = Changeset.find_by_revision('10')
235
    assert_nil changeset.next
236
  end
237 245:051f544170fe Chris
238 0:513646585e45 Chris
  def test_comments_should_be_converted_to_utf8
239 441:cbce1fd3b1b7 Chris
    proj = Project.find(3)
240
    # str = File.read("#{RAILS_ROOT}/test/fixtures/encoding/iso-8859-1.txt")
241
    str = "Texte encod\xe9 en ISO-8859-1."
242
    str.force_encoding("ASCII-8BIT") if str.respond_to?(:force_encoding)
243
    r = Repository::Bazaar.create!(
244
            :project      => proj,
245
            :url          => '/tmp/test/bazaar',
246 245:051f544170fe Chris
            :log_encoding => 'ISO-8859-1' )
247 441:cbce1fd3b1b7 Chris
    assert r
248
    c = Changeset.new(:repository   => r,
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 0:513646585e45 Chris
  end
258 245:051f544170fe Chris
259 441:cbce1fd3b1b7 Chris
  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 245:051f544170fe Chris
            :log_encoding => 'UTF-8' )
270 441:cbce1fd3b1b7 Chris
    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 245:051f544170fe Chris
  end
301
302
  def test_comments_should_be_converted_all_latin1_to_utf8
303 441:cbce1fd3b1b7 Chris
    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 245:051f544170fe Chris
            :log_encoding => 'ISO-8859-1' )
319 441:cbce1fd3b1b7 Chris
    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 0:513646585e45 Chris
  end
400 119:8661b858af72 Chris
401
  def test_identifier
402
    c = Changeset.find_by_revision('1')
403
    assert_equal c.revision, c.identifier
404
  end
405 0:513646585e45 Chris
end