annotate test/unit/repository_mercurial_test.rb @ 1327:287f201c2802 redmine-2.2-integration

Add italic
author Chris Cannam <chris.cannam@soundsoftware.ac.uk>
date Wed, 19 Jun 2013 20:56:22 +0100
parents bb32da3bea34
children 4f746d8966dd fb9a13467253
rev   line source
Chris@441 1 # Redmine - project management software
Chris@1115 2 # Copyright (C) 2006-2012 Jean-Philippe Lang
Chris@0 3 #
Chris@0 4 # This program is free software; you can redistribute it and/or
Chris@0 5 # modify it under the terms of the GNU General Public License
Chris@0 6 # as published by the Free Software Foundation; either version 2
Chris@0 7 # of the License, or (at your option) any later version.
Chris@441 8 #
Chris@0 9 # This program is distributed in the hope that it will be useful,
Chris@0 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@0 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@0 12 # GNU General Public License for more details.
Chris@441 13 #
Chris@0 14 # You should have received a copy of the GNU General Public License
Chris@0 15 # along with this program; if not, write to the Free Software
Chris@0 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@0 17
Chris@119 18 require File.expand_path('../../test_helper', __FILE__)
Chris@0 19
Chris@0 20 class RepositoryMercurialTest < ActiveSupport::TestCase
Chris@0 21 fixtures :projects
Chris@441 22
Chris@1115 23 include Redmine::I18n
Chris@1115 24
Chris@909 25 REPOSITORY_PATH = Rails.root.join('tmp/test/mercurial_repository').to_s
Chris@909 26 NUM_REV = 32
Chris@441 27 CHAR_1_HEX = "\xc3\x9c"
Chris@245 28
Chris@1115 29 def setup
Chris@1115 30 @project = Project.find(3)
Chris@1115 31 @repository = Repository::Mercurial.create(
Chris@1115 32 :project => @project,
Chris@1115 33 :url => REPOSITORY_PATH,
Chris@1115 34 :path_encoding => 'ISO-8859-1'
Chris@1115 35 )
Chris@1115 36 assert @repository
Chris@1115 37 @char_1 = CHAR_1_HEX.dup
Chris@1115 38 @tag_char_1 = "tag-#{CHAR_1_HEX}-00"
Chris@1115 39 @branch_char_0 = "branch-#{CHAR_1_HEX}-00"
Chris@1115 40 @branch_char_1 = "branch-#{CHAR_1_HEX}-01"
Chris@1115 41 if @char_1.respond_to?(:force_encoding)
Chris@1115 42 @char_1.force_encoding('UTF-8')
Chris@1115 43 @tag_char_1.force_encoding('UTF-8')
Chris@1115 44 @branch_char_0.force_encoding('UTF-8')
Chris@1115 45 @branch_char_1.force_encoding('UTF-8')
Chris@1115 46 end
Chris@1115 47 end
Chris@1115 48
Chris@1115 49
Chris@1115 50 def test_blank_path_to_repository_error_message
Chris@1115 51 set_language_if_valid 'en'
Chris@1115 52 repo = Repository::Mercurial.new(
Chris@1115 53 :project => @project,
Chris@1115 54 :identifier => 'test'
Chris@1115 55 )
Chris@1115 56 assert !repo.save
Chris@1115 57 assert_include "Path to repository can't be blank",
Chris@1115 58 repo.errors.full_messages
Chris@1115 59 end
Chris@1115 60
Chris@1115 61 def test_blank_path_to_repository_error_message_fr
Chris@1115 62 set_language_if_valid 'fr'
Chris@1115 63 str = "Chemin du d\xc3\xa9p\xc3\xb4t doit \xc3\xaatre renseign\xc3\xa9(e)"
Chris@1115 64 str.force_encoding('UTF-8') if str.respond_to?(:force_encoding)
Chris@1115 65 repo = Repository::Mercurial.new(
Chris@1115 66 :project => @project,
Chris@1115 67 :url => "",
Chris@1115 68 :identifier => 'test',
Chris@1115 69 :path_encoding => ''
Chris@1115 70 )
Chris@1115 71 assert !repo.save
Chris@1115 72 assert_include str, repo.errors.full_messages
Chris@1115 73 end
Chris@1115 74
Chris@441 75 if File.directory?(REPOSITORY_PATH)
Chris@1115 76 def test_scm_available
Chris@441 77 klass = Repository::Mercurial
Chris@441 78 assert_equal "Mercurial", klass.scm_name
Chris@441 79 assert klass.scm_adapter_class
Chris@441 80 assert_not_equal "", klass.scm_command
Chris@441 81 assert_equal true, klass.scm_available
Chris@1115 82 end
Chris@441 83
Chris@1115 84 def test_entries
Chris@1115 85 entries = @repository.entries
Chris@1115 86 assert_kind_of Redmine::Scm::Adapters::Entries, entries
Chris@441 87 end
Chris@441 88
Chris@0 89 def test_fetch_changesets_from_scratch
Chris@909 90 assert_equal 0, @repository.changesets.count
Chris@0 91 @repository.fetch_changesets
Chris@909 92 @project.reload
Chris@909 93 assert_equal NUM_REV, @repository.changesets.count
Chris@1115 94 assert_equal 46, @repository.filechanges.count
Chris@119 95 assert_equal "Initial import.\nThe repository contains 3 files.",
Chris@119 96 @repository.changesets.find_by_revision('0').comments
Chris@0 97 end
Chris@245 98
Chris@0 99 def test_fetch_changesets_incremental
Chris@909 100 assert_equal 0, @repository.changesets.count
Chris@0 101 @repository.fetch_changesets
Chris@909 102 @project.reload
Chris@909 103 assert_equal NUM_REV, @repository.changesets.count
Chris@0 104 # Remove changesets with revision > 2
Chris@0 105 @repository.changesets.find(:all).each {|c| c.destroy if c.revision.to_i > 2}
Chris@909 106 @project.reload
Chris@0 107 assert_equal 3, @repository.changesets.count
Chris@441 108
Chris@0 109 @repository.fetch_changesets
Chris@909 110 @project.reload
Chris@909 111 assert_equal NUM_REV, @repository.changesets.count
Chris@0 112 end
Chris@0 113
Chris@119 114 def test_isodatesec
Chris@119 115 # Template keyword 'isodatesec' supported in Mercurial 1.0 and higher
Chris@119 116 if @repository.scm.class.client_version_above?([1, 0])
Chris@909 117 assert_equal 0, @repository.changesets.count
Chris@119 118 @repository.fetch_changesets
Chris@909 119 @project.reload
Chris@909 120 assert_equal NUM_REV, @repository.changesets.count
Chris@119 121 rev0_committed_on = Time.gm(2007, 12, 14, 9, 22, 52)
Chris@119 122 assert_equal @repository.changesets.find_by_revision('0').committed_on, rev0_committed_on
Chris@119 123 end
Chris@0 124 end
Chris@0 125
Chris@119 126 def test_changeset_order_by_revision
Chris@909 127 assert_equal 0, @repository.changesets.count
Chris@119 128 @repository.fetch_changesets
Chris@909 129 @project.reload
Chris@909 130 assert_equal NUM_REV, @repository.changesets.count
Chris@119 131
Chris@119 132 c0 = @repository.latest_changeset
Chris@119 133 c1 = @repository.changesets.find_by_revision('0')
Chris@119 134 # sorted by revision (id), not by date
Chris@119 135 assert c0.revision.to_i > c1.revision.to_i
Chris@119 136 assert c0.committed_on < c1.committed_on
Chris@119 137 end
Chris@119 138
Chris@119 139 def test_latest_changesets
Chris@909 140 assert_equal 0, @repository.changesets.count
Chris@119 141 @repository.fetch_changesets
Chris@909 142 @project.reload
Chris@909 143 assert_equal NUM_REV, @repository.changesets.count
Chris@119 144
Chris@119 145 # with_limit
Chris@119 146 changesets = @repository.latest_changesets('', nil, 2)
Chris@909 147 assert_equal %w|31 30|, changesets.collect(&:revision)
Chris@119 148
Chris@119 149 # with_filepath
Chris@441 150 changesets = @repository.latest_changesets(
Chris@441 151 '/sql_escape/percent%dir/percent%file1.txt', nil)
Chris@909 152 assert_equal %w|30 11 10 9|, changesets.collect(&:revision)
Chris@119 153
Chris@441 154 changesets = @repository.latest_changesets(
Chris@441 155 '/sql_escape/underscore_dir/understrike_file.txt', nil)
Chris@909 156 assert_equal %w|30 12 9|, changesets.collect(&:revision)
Chris@441 157
Chris@441 158 changesets = @repository.latest_changesets('README', nil)
Chris@909 159 assert_equal %w|31 30 28 17 8 6 1 0|, changesets.collect(&:revision)
Chris@441 160
Chris@441 161 changesets = @repository.latest_changesets('README','8')
Chris@441 162 assert_equal %w|8 6 1 0|, changesets.collect(&:revision)
Chris@441 163
Chris@441 164 changesets = @repository.latest_changesets('README','8', 2)
Chris@441 165 assert_equal %w|8 6|, changesets.collect(&:revision)
Chris@441 166
Chris@441 167 # with_dirpath
Chris@441 168 changesets = @repository.latest_changesets('images', nil)
Chris@441 169 assert_equal %w|1 0|, changesets.collect(&:revision)
Chris@441 170
Chris@441 171 path = 'sql_escape/percent%dir'
Chris@441 172 changesets = @repository.latest_changesets(path, nil)
Chris@909 173 assert_equal %w|30 13 11 10 9|, changesets.collect(&:revision)
Chris@441 174
Chris@441 175 changesets = @repository.latest_changesets(path, '11')
Chris@441 176 assert_equal %w|11 10 9|, changesets.collect(&:revision)
Chris@441 177
Chris@441 178 changesets = @repository.latest_changesets(path, '11', 2)
Chris@441 179 assert_equal %w|11 10|, changesets.collect(&:revision)
Chris@441 180
Chris@441 181 path = 'sql_escape/underscore_dir'
Chris@441 182 changesets = @repository.latest_changesets(path, nil)
Chris@909 183 assert_equal %w|30 13 12 9|, changesets.collect(&:revision)
Chris@441 184
Chris@441 185 changesets = @repository.latest_changesets(path, '12')
Chris@441 186 assert_equal %w|12 9|, changesets.collect(&:revision)
Chris@441 187
Chris@441 188 changesets = @repository.latest_changesets(path, '12', 1)
Chris@441 189 assert_equal %w|12|, changesets.collect(&:revision)
Chris@441 190
Chris@441 191 # tag
Chris@441 192 changesets = @repository.latest_changesets('', 'tag_test.00')
Chris@441 193 assert_equal %w|5 4 3 2 1 0|, changesets.collect(&:revision)
Chris@441 194
Chris@441 195 changesets = @repository.latest_changesets('', 'tag_test.00', 2)
Chris@441 196 assert_equal %w|5 4|, changesets.collect(&:revision)
Chris@441 197
Chris@441 198 changesets = @repository.latest_changesets('sources', 'tag_test.00')
Chris@441 199 assert_equal %w|4 3 2 1 0|, changesets.collect(&:revision)
Chris@441 200
Chris@441 201 changesets = @repository.latest_changesets('sources', 'tag_test.00', 2)
Chris@441 202 assert_equal %w|4 3|, changesets.collect(&:revision)
Chris@441 203
Chris@441 204 # named branch
Chris@909 205 if @repository.scm.class.client_version_above?([1, 6])
Chris@909 206 changesets = @repository.latest_changesets('', @branch_char_1)
Chris@909 207 assert_equal %w|27 26|, changesets.collect(&:revision)
Chris@909 208 end
Chris@441 209
Chris@441 210 changesets = @repository.latest_changesets("latin-1-dir/test-#{@char_1}-subdir", @branch_char_1)
Chris@441 211 assert_equal %w|27|, changesets.collect(&:revision)
Chris@119 212 end
Chris@119 213
Chris@119 214 def test_copied_files
Chris@909 215 assert_equal 0, @repository.changesets.count
Chris@119 216 @repository.fetch_changesets
Chris@909 217 @project.reload
Chris@909 218 assert_equal NUM_REV, @repository.changesets.count
Chris@119 219
Chris@119 220 cs1 = @repository.changesets.find_by_revision('13')
Chris@119 221 assert_not_nil cs1
Chris@1115 222 c1 = cs1.filechanges.sort_by(&:path)
Chris@119 223 assert_equal 2, c1.size
Chris@119 224
Chris@119 225 assert_equal 'A', c1[0].action
Chris@119 226 assert_equal '/sql_escape/percent%dir/percentfile1.txt', c1[0].path
Chris@119 227 assert_equal '/sql_escape/percent%dir/percent%file1.txt', c1[0].from_path
Chris@441 228 assert_equal '3a330eb32958', c1[0].from_revision
Chris@119 229
Chris@119 230 assert_equal 'A', c1[1].action
Chris@119 231 assert_equal '/sql_escape/underscore_dir/understrike-file.txt', c1[1].path
Chris@119 232 assert_equal '/sql_escape/underscore_dir/understrike_file.txt', c1[1].from_path
Chris@119 233
Chris@119 234 cs2 = @repository.changesets.find_by_revision('15')
Chris@1115 235 c2 = cs2.filechanges
Chris@119 236 assert_equal 1, c2.size
Chris@119 237
Chris@119 238 assert_equal 'A', c2[0].action
Chris@119 239 assert_equal '/README (1)[2]&,%.-3_4', c2[0].path
Chris@119 240 assert_equal '/README', c2[0].from_path
Chris@441 241 assert_equal '933ca60293d7', c2[0].from_revision
Chris@441 242
Chris@441 243 cs3 = @repository.changesets.find_by_revision('19')
Chris@1115 244 c3 = cs3.filechanges
Chris@441 245 assert_equal 1, c3.size
Chris@441 246 assert_equal 'A', c3[0].action
Chris@441 247 assert_equal "/latin-1-dir/test-#{@char_1}-1.txt", c3[0].path
Chris@441 248 assert_equal "/latin-1-dir/test-#{@char_1}.txt", c3[0].from_path
Chris@441 249 assert_equal '5d9891a1b425', c3[0].from_revision
Chris@119 250 end
Chris@119 251
Chris@119 252 def test_find_changeset_by_name
Chris@909 253 assert_equal 0, @repository.changesets.count
Chris@119 254 @repository.fetch_changesets
Chris@909 255 @project.reload
Chris@909 256 assert_equal NUM_REV, @repository.changesets.count
Chris@119 257 %w|2 400bb8672109 400|.each do |r|
Chris@119 258 assert_equal '2', @repository.find_changeset_by_name(r).revision
Chris@119 259 end
Chris@119 260 end
Chris@119 261
Chris@119 262 def test_find_changeset_by_invalid_name
Chris@909 263 assert_equal 0, @repository.changesets.count
Chris@119 264 @repository.fetch_changesets
Chris@909 265 @project.reload
Chris@909 266 assert_equal NUM_REV, @repository.changesets.count
Chris@119 267 assert_nil @repository.find_changeset_by_name('100000')
Chris@119 268 end
Chris@119 269
Chris@119 270 def test_identifier
Chris@909 271 assert_equal 0, @repository.changesets.count
Chris@119 272 @repository.fetch_changesets
Chris@909 273 @project.reload
Chris@909 274 assert_equal NUM_REV, @repository.changesets.count
Chris@119 275 c = @repository.changesets.find_by_revision('2')
Chris@119 276 assert_equal c.scmid, c.identifier
Chris@119 277 end
Chris@119 278
Chris@119 279 def test_format_identifier
Chris@909 280 assert_equal 0, @repository.changesets.count
Chris@119 281 @repository.fetch_changesets
Chris@909 282 @project.reload
Chris@909 283 assert_equal NUM_REV, @repository.changesets.count
Chris@119 284 c = @repository.changesets.find_by_revision('2')
Chris@119 285 assert_equal '2:400bb8672109', c.format_identifier
Chris@119 286 end
Chris@119 287
Chris@119 288 def test_find_changeset_by_empty_name
Chris@909 289 assert_equal 0, @repository.changesets.count
Chris@119 290 @repository.fetch_changesets
Chris@909 291 @project.reload
Chris@909 292 assert_equal NUM_REV, @repository.changesets.count
Chris@119 293 ['', ' ', nil].each do |r|
Chris@119 294 assert_nil @repository.find_changeset_by_name(r)
Chris@119 295 end
Chris@119 296 end
Chris@119 297
Chris@909 298 def test_parents
Chris@909 299 assert_equal 0, @repository.changesets.count
Chris@909 300 @repository.fetch_changesets
Chris@909 301 @project.reload
Chris@909 302 assert_equal NUM_REV, @repository.changesets.count
Chris@909 303 r1 = @repository.changesets.find_by_revision('0')
Chris@909 304 assert_equal [], r1.parents
Chris@909 305 r2 = @repository.changesets.find_by_revision('1')
Chris@909 306 assert_equal 1, r2.parents.length
Chris@909 307 assert_equal "0885933ad4f6",
Chris@909 308 r2.parents[0].identifier
Chris@909 309 r3 = @repository.changesets.find_by_revision('30')
Chris@909 310 assert_equal 2, r3.parents.length
Chris@909 311 r4 = [r3.parents[0].identifier, r3.parents[1].identifier].sort
Chris@909 312 assert_equal "3a330eb32958", r4[0]
Chris@909 313 assert_equal "a94b0528f24f", r4[1]
Chris@909 314 end
Chris@909 315
Chris@119 316 def test_activities
Chris@119 317 c = Changeset.new(:repository => @repository,
Chris@119 318 :committed_on => Time.now,
Chris@119 319 :revision => '123',
Chris@119 320 :scmid => 'abc400bb8672',
Chris@119 321 :comments => 'test')
Chris@119 322 assert c.event_title.include?('123:abc400bb8672:')
Chris@119 323 assert_equal 'abc400bb8672', c.event_url[:rev]
Chris@119 324 end
Chris@245 325
Chris@441 326 def test_previous
Chris@909 327 assert_equal 0, @repository.changesets.count
Chris@245 328 @repository.fetch_changesets
Chris@909 329 @project.reload
Chris@909 330 assert_equal NUM_REV, @repository.changesets.count
Chris@441 331 %w|28 3ae45e2d177d 3ae45|.each do |r1|
Chris@441 332 changeset = @repository.find_changeset_by_name(r1)
Chris@441 333 %w|27 7bbf4c738e71 7bbf|.each do |r2|
Chris@441 334 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
Chris@441 335 end
Chris@441 336 end
Chris@245 337 end
Chris@245 338
Chris@441 339 def test_previous_nil
Chris@909 340 assert_equal 0, @repository.changesets.count
Chris@245 341 @repository.fetch_changesets
Chris@909 342 @project.reload
Chris@909 343 assert_equal NUM_REV, @repository.changesets.count
Chris@441 344 %w|0 0885933ad4f6 0885|.each do |r1|
Chris@441 345 changeset = @repository.find_changeset_by_name(r1)
Chris@441 346 assert_nil changeset.previous
Chris@441 347 end
Chris@245 348 end
Chris@245 349
Chris@441 350 def test_next
Chris@909 351 assert_equal 0, @repository.changesets.count
Chris@245 352 @repository.fetch_changesets
Chris@909 353 @project.reload
Chris@909 354 assert_equal NUM_REV, @repository.changesets.count
Chris@441 355 %w|27 7bbf4c738e71 7bbf|.each do |r2|
Chris@441 356 changeset = @repository.find_changeset_by_name(r2)
Chris@441 357 %w|28 3ae45e2d177d 3ae45|.each do |r1|
Chris@441 358 assert_equal @repository.find_changeset_by_name(r1), changeset.next
Chris@441 359 end
Chris@441 360 end
Chris@441 361 end
Chris@245 362
Chris@441 363 def test_next_nil
Chris@909 364 assert_equal 0, @repository.changesets.count
Chris@441 365 @repository.fetch_changesets
Chris@909 366 @project.reload
Chris@909 367 assert_equal NUM_REV, @repository.changesets.count
Chris@909 368 %w|31 31eeee7395c8 31eee|.each do |r1|
Chris@441 369 changeset = @repository.find_changeset_by_name(r1)
Chris@441 370 assert_nil changeset.next
Chris@441 371 end
Chris@245 372 end
Chris@0 373 else
Chris@0 374 puts "Mercurial test repository NOT FOUND. Skipping unit tests !!!"
Chris@0 375 def test_fake; assert true end
Chris@0 376 end
Chris@0 377 end