annotate .svn/pristine/b4/b4b1f198c8e086edfc312f99671cb5c7dd8f466b.svn-base @ 1298:4f746d8966dd redmine_2.3_integration

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