annotate test/unit/repository_mercurial_test.rb @ 850:e9e53db0c93a bug_213

Close obsolete branch bug_213
author Chris Cannam
date Sat, 13 Aug 2011 14:51:48 +0100
parents 753f1380d6bc
children 5e80956cc792
rev   line source
Chris@441 1 # Redmine - project management software
Chris@441 2 # Copyright (C) 2006-2011 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@0 23 # No '..' in the repository path
Chris@0 24 REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/mercurial_repository'
Chris@245 25
Chris@441 26 CHAR_1_HEX = "\xc3\x9c"
Chris@245 27
Chris@441 28 if File.directory?(REPOSITORY_PATH)
Chris@441 29
Chris@441 30 def setup
Chris@441 31 klass = Repository::Mercurial
Chris@441 32 assert_equal "Mercurial", klass.scm_name
Chris@441 33 assert klass.scm_adapter_class
Chris@441 34 assert_not_equal "", klass.scm_command
Chris@441 35 assert_equal true, klass.scm_available
Chris@441 36
Chris@441 37 @project = Project.find(3)
Chris@441 38 @repository = Repository::Mercurial.create(
Chris@441 39 :project => @project,
Chris@441 40 :url => REPOSITORY_PATH,
Chris@441 41 :path_encoding => 'ISO-8859-1'
Chris@441 42 )
Chris@441 43 assert @repository
Chris@441 44 @char_1 = CHAR_1_HEX.dup
Chris@441 45 @tag_char_1 = "tag-#{CHAR_1_HEX}-00"
Chris@441 46 @branch_char_0 = "branch-#{CHAR_1_HEX}-00"
Chris@441 47 @branch_char_1 = "branch-#{CHAR_1_HEX}-01"
Chris@441 48 if @char_1.respond_to?(:force_encoding)
Chris@441 49 @char_1.force_encoding('UTF-8')
Chris@441 50 @tag_char_1.force_encoding('UTF-8')
Chris@441 51 @branch_char_0.force_encoding('UTF-8')
Chris@441 52 @branch_char_1.force_encoding('UTF-8')
Chris@441 53 end
Chris@441 54 end
Chris@441 55
Chris@0 56 def test_fetch_changesets_from_scratch
Chris@0 57 @repository.fetch_changesets
Chris@0 58 @repository.reload
Chris@441 59 assert_equal 29, @repository.changesets.count
Chris@441 60 assert_equal 37, @repository.changes.count
Chris@119 61 assert_equal "Initial import.\nThe repository contains 3 files.",
Chris@119 62 @repository.changesets.find_by_revision('0').comments
Chris@0 63 end
Chris@245 64
Chris@0 65 def test_fetch_changesets_incremental
Chris@0 66 @repository.fetch_changesets
Chris@0 67 # Remove changesets with revision > 2
Chris@0 68 @repository.changesets.find(:all).each {|c| c.destroy if c.revision.to_i > 2}
Chris@0 69 @repository.reload
Chris@0 70 assert_equal 3, @repository.changesets.count
Chris@441 71
Chris@0 72 @repository.fetch_changesets
Chris@441 73 assert_equal 29, @repository.changesets.count
Chris@0 74 end
Chris@0 75
Chris@119 76 def test_isodatesec
Chris@119 77 # Template keyword 'isodatesec' supported in Mercurial 1.0 and higher
Chris@119 78 if @repository.scm.class.client_version_above?([1, 0])
Chris@119 79 @repository.fetch_changesets
Chris@119 80 @repository.reload
Chris@119 81 rev0_committed_on = Time.gm(2007, 12, 14, 9, 22, 52)
Chris@119 82 assert_equal @repository.changesets.find_by_revision('0').committed_on, rev0_committed_on
Chris@119 83 end
Chris@0 84 end
Chris@0 85
Chris@119 86 def test_changeset_order_by_revision
Chris@119 87 @repository.fetch_changesets
Chris@119 88 @repository.reload
Chris@119 89
Chris@119 90 c0 = @repository.latest_changeset
Chris@119 91 c1 = @repository.changesets.find_by_revision('0')
Chris@119 92 # sorted by revision (id), not by date
Chris@119 93 assert c0.revision.to_i > c1.revision.to_i
Chris@119 94 assert c0.committed_on < c1.committed_on
Chris@119 95 end
Chris@119 96
Chris@119 97 def test_latest_changesets
Chris@119 98 @repository.fetch_changesets
Chris@119 99 @repository.reload
Chris@119 100
Chris@119 101 # with_limit
Chris@119 102 changesets = @repository.latest_changesets('', nil, 2)
Chris@441 103 assert_equal %w|28 27|, changesets.collect(&:revision)
Chris@119 104
Chris@119 105 # with_filepath
Chris@441 106 changesets = @repository.latest_changesets(
Chris@441 107 '/sql_escape/percent%dir/percent%file1.txt', nil)
Chris@119 108 assert_equal %w|11 10 9|, changesets.collect(&:revision)
Chris@119 109
Chris@441 110 changesets = @repository.latest_changesets(
Chris@441 111 '/sql_escape/underscore_dir/understrike_file.txt', nil)
Chris@119 112 assert_equal %w|12 9|, changesets.collect(&:revision)
Chris@441 113
Chris@441 114 changesets = @repository.latest_changesets('README', nil)
Chris@441 115 assert_equal %w|28 17 8 6 1 0|, changesets.collect(&:revision)
Chris@441 116
Chris@441 117 changesets = @repository.latest_changesets('README','8')
Chris@441 118 assert_equal %w|8 6 1 0|, changesets.collect(&:revision)
Chris@441 119
Chris@441 120 changesets = @repository.latest_changesets('README','8', 2)
Chris@441 121 assert_equal %w|8 6|, changesets.collect(&:revision)
Chris@441 122
Chris@441 123 # with_dirpath
Chris@441 124 changesets = @repository.latest_changesets('images', nil)
Chris@441 125 assert_equal %w|1 0|, changesets.collect(&:revision)
Chris@441 126
Chris@441 127 path = 'sql_escape/percent%dir'
Chris@441 128 changesets = @repository.latest_changesets(path, nil)
Chris@441 129 assert_equal %w|13 11 10 9|, changesets.collect(&:revision)
Chris@441 130
Chris@441 131 changesets = @repository.latest_changesets(path, '11')
Chris@441 132 assert_equal %w|11 10 9|, changesets.collect(&:revision)
Chris@441 133
Chris@441 134 changesets = @repository.latest_changesets(path, '11', 2)
Chris@441 135 assert_equal %w|11 10|, changesets.collect(&:revision)
Chris@441 136
Chris@441 137 path = 'sql_escape/underscore_dir'
Chris@441 138 changesets = @repository.latest_changesets(path, nil)
Chris@441 139 assert_equal %w|13 12 9|, changesets.collect(&:revision)
Chris@441 140
Chris@441 141 changesets = @repository.latest_changesets(path, '12')
Chris@441 142 assert_equal %w|12 9|, changesets.collect(&:revision)
Chris@441 143
Chris@441 144 changesets = @repository.latest_changesets(path, '12', 1)
Chris@441 145 assert_equal %w|12|, changesets.collect(&:revision)
Chris@441 146
Chris@441 147 # tag
Chris@441 148 changesets = @repository.latest_changesets('', 'tag_test.00')
Chris@441 149 assert_equal %w|5 4 3 2 1 0|, changesets.collect(&:revision)
Chris@441 150
Chris@441 151 changesets = @repository.latest_changesets('', 'tag_test.00', 2)
Chris@441 152 assert_equal %w|5 4|, changesets.collect(&:revision)
Chris@441 153
Chris@441 154 changesets = @repository.latest_changesets('sources', 'tag_test.00')
Chris@441 155 assert_equal %w|4 3 2 1 0|, changesets.collect(&:revision)
Chris@441 156
Chris@441 157 changesets = @repository.latest_changesets('sources', 'tag_test.00', 2)
Chris@441 158 assert_equal %w|4 3|, changesets.collect(&:revision)
Chris@441 159
Chris@441 160 # named branch
Chris@441 161 changesets = @repository.latest_changesets('', @branch_char_1)
Chris@441 162 assert_equal %w|27 26|, changesets.collect(&:revision)
Chris@441 163
Chris@441 164 changesets = @repository.latest_changesets("latin-1-dir/test-#{@char_1}-subdir", @branch_char_1)
Chris@441 165 assert_equal %w|27|, changesets.collect(&:revision)
Chris@119 166 end
Chris@119 167
Chris@119 168 def test_copied_files
Chris@119 169 @repository.fetch_changesets
Chris@119 170 @repository.reload
Chris@119 171
Chris@119 172 cs1 = @repository.changesets.find_by_revision('13')
Chris@119 173 assert_not_nil cs1
Chris@119 174 c1 = cs1.changes.sort_by(&:path)
Chris@119 175 assert_equal 2, c1.size
Chris@119 176
Chris@119 177 assert_equal 'A', c1[0].action
Chris@119 178 assert_equal '/sql_escape/percent%dir/percentfile1.txt', c1[0].path
Chris@119 179 assert_equal '/sql_escape/percent%dir/percent%file1.txt', c1[0].from_path
Chris@441 180 assert_equal '3a330eb32958', c1[0].from_revision
Chris@119 181
Chris@119 182 assert_equal 'A', c1[1].action
Chris@119 183 assert_equal '/sql_escape/underscore_dir/understrike-file.txt', c1[1].path
Chris@119 184 assert_equal '/sql_escape/underscore_dir/understrike_file.txt', c1[1].from_path
Chris@119 185
Chris@119 186 cs2 = @repository.changesets.find_by_revision('15')
Chris@119 187 c2 = cs2.changes
Chris@119 188 assert_equal 1, c2.size
Chris@119 189
Chris@119 190 assert_equal 'A', c2[0].action
Chris@119 191 assert_equal '/README (1)[2]&,%.-3_4', c2[0].path
Chris@119 192 assert_equal '/README', c2[0].from_path
Chris@441 193 assert_equal '933ca60293d7', c2[0].from_revision
Chris@441 194
Chris@441 195 cs3 = @repository.changesets.find_by_revision('19')
Chris@441 196 c3 = cs3.changes
Chris@441 197 assert_equal 1, c3.size
Chris@441 198 assert_equal 'A', c3[0].action
Chris@441 199 assert_equal "/latin-1-dir/test-#{@char_1}-1.txt", c3[0].path
Chris@441 200 assert_equal "/latin-1-dir/test-#{@char_1}.txt", c3[0].from_path
Chris@441 201 assert_equal '5d9891a1b425', c3[0].from_revision
Chris@119 202 end
Chris@119 203
Chris@119 204 def test_find_changeset_by_name
Chris@119 205 @repository.fetch_changesets
Chris@119 206 @repository.reload
Chris@119 207 %w|2 400bb8672109 400|.each do |r|
Chris@119 208 assert_equal '2', @repository.find_changeset_by_name(r).revision
Chris@119 209 end
Chris@119 210 end
Chris@119 211
Chris@119 212 def test_find_changeset_by_invalid_name
Chris@119 213 @repository.fetch_changesets
Chris@119 214 @repository.reload
Chris@119 215 assert_nil @repository.find_changeset_by_name('100000')
Chris@119 216 end
Chris@119 217
Chris@119 218 def test_identifier
Chris@119 219 @repository.fetch_changesets
Chris@119 220 @repository.reload
Chris@119 221 c = @repository.changesets.find_by_revision('2')
Chris@119 222 assert_equal c.scmid, c.identifier
Chris@119 223 end
Chris@119 224
Chris@119 225 def test_format_identifier
Chris@119 226 @repository.fetch_changesets
Chris@119 227 @repository.reload
Chris@119 228 c = @repository.changesets.find_by_revision('2')
Chris@119 229 assert_equal '2:400bb8672109', c.format_identifier
Chris@119 230 end
Chris@119 231
Chris@119 232 def test_find_changeset_by_empty_name
Chris@119 233 @repository.fetch_changesets
Chris@119 234 @repository.reload
Chris@119 235 ['', ' ', nil].each do |r|
Chris@119 236 assert_nil @repository.find_changeset_by_name(r)
Chris@119 237 end
Chris@119 238 end
Chris@119 239
Chris@119 240 def test_activities
Chris@119 241 c = Changeset.new(:repository => @repository,
Chris@119 242 :committed_on => Time.now,
Chris@119 243 :revision => '123',
Chris@119 244 :scmid => 'abc400bb8672',
Chris@119 245 :comments => 'test')
Chris@119 246 assert c.event_title.include?('123:abc400bb8672:')
Chris@119 247 assert_equal 'abc400bb8672', c.event_url[:rev]
Chris@119 248 end
Chris@245 249
Chris@441 250 def test_previous
Chris@245 251 @repository.fetch_changesets
Chris@245 252 @repository.reload
Chris@441 253 %w|28 3ae45e2d177d 3ae45|.each do |r1|
Chris@441 254 changeset = @repository.find_changeset_by_name(r1)
Chris@441 255 %w|27 7bbf4c738e71 7bbf|.each do |r2|
Chris@441 256 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
Chris@441 257 end
Chris@441 258 end
Chris@245 259 end
Chris@245 260
Chris@441 261 def test_previous_nil
Chris@245 262 @repository.fetch_changesets
Chris@245 263 @repository.reload
Chris@441 264 %w|0 0885933ad4f6 0885|.each do |r1|
Chris@441 265 changeset = @repository.find_changeset_by_name(r1)
Chris@441 266 assert_nil changeset.previous
Chris@441 267 end
Chris@245 268 end
Chris@245 269
Chris@441 270 def test_next
Chris@245 271 @repository.fetch_changesets
Chris@245 272 @repository.reload
Chris@441 273 %w|27 7bbf4c738e71 7bbf|.each do |r2|
Chris@441 274 changeset = @repository.find_changeset_by_name(r2)
Chris@441 275 %w|28 3ae45e2d177d 3ae45|.each do |r1|
Chris@441 276 assert_equal @repository.find_changeset_by_name(r1), changeset.next
Chris@441 277 end
Chris@441 278 end
Chris@441 279 end
Chris@245 280
Chris@441 281 def test_next_nil
Chris@441 282 @repository.fetch_changesets
Chris@441 283 @repository.reload
Chris@441 284 %w|28 3ae45e2d177d 3ae45|.each do |r1|
Chris@441 285 changeset = @repository.find_changeset_by_name(r1)
Chris@441 286 assert_nil changeset.next
Chris@441 287 end
Chris@245 288 end
Chris@0 289 else
Chris@0 290 puts "Mercurial test repository NOT FOUND. Skipping unit tests !!!"
Chris@0 291 def test_fake; assert true end
Chris@0 292 end
Chris@0 293 end