annotate test/unit/repository_git_test.rb @ 1452:d6b9fd02bb89 feature_36_js_refactoring

Deprecated develoment branch.
author luisf <luis.figueira@eecs.qmul.ac.uk>
date Fri, 11 Oct 2013 17:01:24 +0100
parents cbce1fd3b1b7
children cbb26bc654de
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 RepositoryGitTest < ActiveSupport::TestCase
Chris@245 21 fixtures :projects, :repositories, :enabled_modules, :users, :roles
Chris@245 22
Chris@0 23 # No '..' in the repository path
Chris@0 24 REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/git_repository'
Chris@0 25 REPOSITORY_PATH.gsub!(/\//, "\\") if Redmine::Platform.mswin?
Chris@245 26
Chris@245 27 FELIX_HEX = "Felix Sch\xC3\xA4fer"
Chris@441 28 CHAR_1_HEX = "\xc3\x9c"
Chris@245 29
Chris@441 30 ## Ruby uses ANSI api to fork a process on Windows.
Chris@441 31 ## Japanese Shift_JIS and Traditional Chinese Big5 have 0x5c(backslash) problem
Chris@441 32 ## and these are incompatible with ASCII.
Chris@441 33 # WINDOWS_PASS = Redmine::Platform.mswin?
Chris@441 34 WINDOWS_PASS = false
Chris@245 35
Chris@441 36 if File.directory?(REPOSITORY_PATH)
Chris@441 37 def setup
Chris@441 38 klass = Repository::Git
Chris@441 39 assert_equal "Git", klass.scm_name
Chris@441 40 assert klass.scm_adapter_class
Chris@441 41 assert_not_equal "", klass.scm_command
Chris@441 42 assert_equal true, klass.scm_available
Chris@441 43
Chris@441 44 @project = Project.find(3)
Chris@441 45 @repository = Repository::Git.create(
Chris@441 46 :project => @project,
Chris@441 47 :url => REPOSITORY_PATH,
Chris@441 48 :path_encoding => 'ISO-8859-1'
Chris@441 49 )
Chris@441 50 assert @repository
Chris@441 51 @char_1 = CHAR_1_HEX.dup
Chris@441 52 if @char_1.respond_to?(:force_encoding)
Chris@441 53 @char_1.force_encoding('UTF-8')
Chris@441 54 end
Chris@441 55 end
Chris@441 56
Chris@0 57 def test_fetch_changesets_from_scratch
Chris@441 58 assert_nil @repository.extra_info
Chris@441 59
Chris@0 60 @repository.fetch_changesets
Chris@0 61 @repository.reload
Chris@245 62
Chris@441 63 assert_equal 21, @repository.changesets.count
Chris@441 64 assert_equal 33, @repository.changes.count
Chris@245 65
Chris@0 66 commit = @repository.changesets.find(:first, :order => 'committed_on ASC')
Chris@0 67 assert_equal "Initial import.\nThe repository contains 3 files.", commit.comments
Chris@0 68 assert_equal "jsmith <jsmith@foo.bar>", commit.committer
Chris@0 69 assert_equal User.find_by_login('jsmith'), commit.user
Chris@0 70 # TODO: add a commit with commit time <> author time to the test repository
Chris@0 71 assert_equal "2007-12-14 09:22:52".to_time, commit.committed_on
Chris@0 72 assert_equal "2007-12-14".to_date, commit.commit_date
Chris@0 73 assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", commit.revision
Chris@0 74 assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", commit.scmid
Chris@0 75 assert_equal 3, commit.changes.count
Chris@0 76 change = commit.changes.sort_by(&:path).first
Chris@0 77 assert_equal "README", change.path
Chris@0 78 assert_equal "A", change.action
Chris@441 79
Chris@441 80 assert_equal 4, @repository.extra_info["branches"].size
Chris@0 81 end
Chris@441 82
Chris@0 83 def test_fetch_changesets_incremental
Chris@0 84 @repository.fetch_changesets
Chris@441 85 @repository.reload
Chris@441 86 assert_equal 21, @repository.changesets.count
Chris@441 87 assert_equal 33, @repository.changes.count
Chris@441 88 extra_info_db = @repository.extra_info["branches"]
Chris@441 89 assert_equal 4, extra_info_db.size
Chris@441 90 assert_equal "1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127",
Chris@441 91 extra_info_db["latin-1-path-encoding"]["last_scmid"]
Chris@441 92 assert_equal "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
Chris@441 93 extra_info_db["master"]["last_scmid"]
Chris@441 94
Chris@441 95 del_revs = [
Chris@441 96 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
Chris@441 97 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
Chris@441 98 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
Chris@441 99 "deff712f05a90d96edbd70facc47d944be5897e3",
Chris@441 100 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
Chris@441 101 "7e61ac704deecde634b51e59daa8110435dcb3da",
Chris@441 102 ]
Chris@441 103 @repository.changesets.each do |rev|
Chris@441 104 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
Chris@441 105 end
Chris@0 106 @repository.reload
Chris@245 107 cs1 = @repository.changesets
Chris@441 108 assert_equal 15, cs1.count
Chris@441 109 h = @repository.extra_info.dup
Chris@441 110 h["branches"]["master"]["last_scmid"] =
Chris@441 111 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
Chris@441 112 @repository.merge_extra_info(h)
Chris@441 113 @repository.save
Chris@441 114 @repository.reload
Chris@441 115 extra_info_db_1 = @repository.extra_info["branches"]
Chris@441 116 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
Chris@441 117 extra_info_db_1["master"]["last_scmid"]
Chris@245 118
Chris@0 119 @repository.fetch_changesets
Chris@441 120 assert_equal 21, @repository.changesets.count
Chris@441 121 end
Chris@441 122
Chris@441 123 def test_fetch_changesets_invalid_rev
Chris@441 124 @repository.fetch_changesets
Chris@441 125 @repository.reload
Chris@441 126 assert_equal 21, @repository.changesets.count
Chris@441 127 assert_equal 33, @repository.changes.count
Chris@441 128 extra_info_db = @repository.extra_info["branches"]
Chris@441 129 assert_equal 4, extra_info_db.size
Chris@441 130 assert_equal "1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127",
Chris@441 131 extra_info_db["latin-1-path-encoding"]["last_scmid"]
Chris@441 132 assert_equal "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
Chris@441 133 extra_info_db["master"]["last_scmid"]
Chris@441 134
Chris@441 135 del_revs = [
Chris@441 136 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
Chris@441 137 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
Chris@441 138 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
Chris@441 139 "deff712f05a90d96edbd70facc47d944be5897e3",
Chris@441 140 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
Chris@441 141 "7e61ac704deecde634b51e59daa8110435dcb3da",
Chris@441 142 ]
Chris@441 143 @repository.changesets.each do |rev|
Chris@441 144 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
Chris@441 145 end
Chris@441 146 @repository.reload
Chris@441 147 cs1 = @repository.changesets
Chris@441 148 assert_equal 15, cs1.count
Chris@441 149 h = @repository.extra_info.dup
Chris@441 150 h["branches"]["master"]["last_scmid"] =
Chris@441 151 "abcd1234efgh"
Chris@441 152 @repository.merge_extra_info(h)
Chris@441 153 @repository.save
Chris@441 154 @repository.reload
Chris@441 155 extra_info_db_1 = @repository.extra_info["branches"]
Chris@441 156 assert_equal "abcd1234efgh",
Chris@441 157 extra_info_db_1["master"]["last_scmid"]
Chris@441 158
Chris@441 159 @repository.fetch_changesets
Chris@441 160 assert_equal 15, @repository.changesets.count
Chris@441 161 end
Chris@441 162
Chris@441 163 def test_db_consistent_ordering_init
Chris@441 164 assert_nil @repository.extra_info
Chris@441 165 @repository.fetch_changesets
Chris@441 166 @repository.reload
Chris@441 167 assert_equal 1, @repository.extra_info["db_consistent"]["ordering"]
Chris@441 168 end
Chris@441 169
Chris@441 170 def test_db_consistent_ordering_before_1_2
Chris@441 171 assert_nil @repository.extra_info
Chris@441 172 @repository.fetch_changesets
Chris@441 173 @repository.reload
Chris@441 174 assert_equal 21, @repository.changesets.count
Chris@441 175 assert_not_nil @repository.extra_info
Chris@441 176 @repository.write_attribute(:extra_info, nil)
Chris@441 177 @repository.save
Chris@441 178 assert_nil @repository.extra_info
Chris@441 179 assert_equal 21, @repository.changesets.count
Chris@441 180 @repository.fetch_changesets
Chris@441 181 @repository.reload
Chris@441 182 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
Chris@441 183
Chris@441 184 del_revs = [
Chris@441 185 "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c",
Chris@441 186 "ed5bb786bbda2dee66a2d50faf51429dbc043a7b",
Chris@441 187 "4f26664364207fa8b1af9f8722647ab2d4ac5d43",
Chris@441 188 "deff712f05a90d96edbd70facc47d944be5897e3",
Chris@441 189 "32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf",
Chris@441 190 "7e61ac704deecde634b51e59daa8110435dcb3da",
Chris@441 191 ]
Chris@441 192 @repository.changesets.each do |rev|
Chris@441 193 rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s }
Chris@441 194 end
Chris@441 195 @repository.reload
Chris@441 196 cs1 = @repository.changesets
Chris@441 197 assert_equal 15, cs1.count
Chris@441 198 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
Chris@441 199 h = @repository.extra_info.dup
Chris@441 200 h["branches"]["master"]["last_scmid"] =
Chris@441 201 "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8"
Chris@441 202 @repository.merge_extra_info(h)
Chris@441 203 @repository.save
Chris@441 204 @repository.reload
Chris@441 205 extra_info_db_1 = @repository.extra_info["branches"]
Chris@441 206 assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8",
Chris@441 207 extra_info_db_1["master"]["last_scmid"]
Chris@441 208
Chris@441 209 @repository.fetch_changesets
Chris@441 210 assert_equal 21, @repository.changesets.count
Chris@441 211 assert_equal 0, @repository.extra_info["db_consistent"]["ordering"]
Chris@441 212 end
Chris@441 213
Chris@441 214 def test_latest_changesets
Chris@441 215 @repository.fetch_changesets
Chris@441 216 @repository.reload
Chris@441 217 # with limit
Chris@441 218 changesets = @repository.latest_changesets('', nil, 2)
Chris@441 219 assert_equal 2, changesets.size
Chris@441 220
Chris@441 221 # with path
Chris@441 222 changesets = @repository.latest_changesets('images', nil)
Chris@441 223 assert_equal [
Chris@441 224 'deff712f05a90d96edbd70facc47d944be5897e3',
Chris@441 225 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 226 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 227 ], changesets.collect(&:revision)
Chris@441 228
Chris@441 229 changesets = @repository.latest_changesets('README', nil)
Chris@441 230 assert_equal [
Chris@441 231 '32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf',
Chris@441 232 '4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8',
Chris@441 233 '713f4944648826f558cf548222f813dabe7cbb04',
Chris@441 234 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
Chris@441 235 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 236 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 237 ], changesets.collect(&:revision)
Chris@441 238
Chris@441 239 # with path, revision and limit
Chris@441 240 changesets = @repository.latest_changesets('images', '899a15dba')
Chris@441 241 assert_equal [
Chris@441 242 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 243 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 244 ], changesets.collect(&:revision)
Chris@441 245
Chris@441 246 changesets = @repository.latest_changesets('images', '899a15dba', 1)
Chris@441 247 assert_equal [
Chris@441 248 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 249 ], changesets.collect(&:revision)
Chris@441 250
Chris@441 251 changesets = @repository.latest_changesets('README', '899a15dba')
Chris@441 252 assert_equal [
Chris@441 253 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 254 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 255 ], changesets.collect(&:revision)
Chris@441 256
Chris@441 257 changesets = @repository.latest_changesets('README', '899a15dba', 1)
Chris@441 258 assert_equal [
Chris@441 259 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 260 ], changesets.collect(&:revision)
Chris@441 261
Chris@441 262 # with path, tag and limit
Chris@441 263 changesets = @repository.latest_changesets('images', 'tag01.annotated')
Chris@441 264 assert_equal [
Chris@441 265 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 266 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 267 ], changesets.collect(&:revision)
Chris@441 268
Chris@441 269 changesets = @repository.latest_changesets('images', 'tag01.annotated', 1)
Chris@441 270 assert_equal [
Chris@441 271 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 272 ], changesets.collect(&:revision)
Chris@441 273
Chris@441 274 changesets = @repository.latest_changesets('README', 'tag01.annotated')
Chris@441 275 assert_equal [
Chris@441 276 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 277 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 278 ], changesets.collect(&:revision)
Chris@441 279
Chris@441 280 changesets = @repository.latest_changesets('README', 'tag01.annotated', 1)
Chris@441 281 assert_equal [
Chris@441 282 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 283 ], changesets.collect(&:revision)
Chris@441 284
Chris@441 285 # with path, branch and limit
Chris@441 286 changesets = @repository.latest_changesets('images', 'test_branch')
Chris@441 287 assert_equal [
Chris@441 288 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 289 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 290 ], changesets.collect(&:revision)
Chris@441 291
Chris@441 292 changesets = @repository.latest_changesets('images', 'test_branch', 1)
Chris@441 293 assert_equal [
Chris@441 294 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 295 ], changesets.collect(&:revision)
Chris@441 296
Chris@441 297 changesets = @repository.latest_changesets('README', 'test_branch')
Chris@441 298 assert_equal [
Chris@441 299 '713f4944648826f558cf548222f813dabe7cbb04',
Chris@441 300 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
Chris@441 301 '899a15dba03a3b350b89c3f537e4bbe02a03cdc9',
Chris@441 302 '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@441 303 ], changesets.collect(&:revision)
Chris@441 304
Chris@441 305 changesets = @repository.latest_changesets('README', 'test_branch', 2)
Chris@441 306 assert_equal [
Chris@441 307 '713f4944648826f558cf548222f813dabe7cbb04',
Chris@441 308 '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
Chris@441 309 ], changesets.collect(&:revision)
Chris@441 310
Chris@441 311 # latin-1 encoding path
Chris@441 312 changesets = @repository.latest_changesets(
Chris@441 313 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89')
Chris@441 314 assert_equal [
Chris@441 315 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
Chris@441 316 '4fc55c43bf3d3dc2efb66145365ddc17639ce81e',
Chris@441 317 ], changesets.collect(&:revision)
Chris@441 318
Chris@441 319 changesets = @repository.latest_changesets(
Chris@441 320 "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89', 1)
Chris@441 321 assert_equal [
Chris@441 322 '64f1f3e89ad1cb57976ff0ad99a107012ba3481d',
Chris@441 323 ], changesets.collect(&:revision)
Chris@441 324 end
Chris@441 325
Chris@441 326 def test_latest_changesets_latin_1_dir
Chris@441 327 if WINDOWS_PASS
Chris@441 328 #
Chris@441 329 else
Chris@441 330 @repository.fetch_changesets
Chris@441 331 @repository.reload
Chris@441 332 changesets = @repository.latest_changesets(
Chris@441 333 "latin-1-dir/test-#{@char_1}-subdir", '1ca7f5ed')
Chris@441 334 assert_equal [
Chris@441 335 '1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127',
Chris@441 336 ], changesets.collect(&:revision)
Chris@441 337 end
Chris@0 338 end
Chris@119 339
Chris@119 340 def test_find_changeset_by_name
Chris@119 341 @repository.fetch_changesets
Chris@119 342 @repository.reload
Chris@119 343 ['7234cb2750b63f47bff735edc50a1c0a433c2518', '7234cb2750b'].each do |r|
Chris@119 344 assert_equal '7234cb2750b63f47bff735edc50a1c0a433c2518',
Chris@119 345 @repository.find_changeset_by_name(r).revision
Chris@119 346 end
Chris@119 347 end
Chris@119 348
Chris@119 349 def test_find_changeset_by_empty_name
Chris@119 350 @repository.fetch_changesets
Chris@119 351 @repository.reload
Chris@119 352 ['', ' ', nil].each do |r|
Chris@119 353 assert_nil @repository.find_changeset_by_name(r)
Chris@119 354 end
Chris@119 355 end
Chris@119 356
Chris@119 357 def test_identifier
Chris@119 358 @repository.fetch_changesets
Chris@119 359 @repository.reload
Chris@441 360 c = @repository.changesets.find_by_revision(
Chris@441 361 '7234cb2750b63f47bff735edc50a1c0a433c2518')
Chris@119 362 assert_equal c.scmid, c.identifier
Chris@119 363 end
Chris@119 364
Chris@119 365 def test_format_identifier
Chris@119 366 @repository.fetch_changesets
Chris@119 367 @repository.reload
Chris@441 368 c = @repository.changesets.find_by_revision(
Chris@441 369 '7234cb2750b63f47bff735edc50a1c0a433c2518')
Chris@119 370 assert_equal '7234cb27', c.format_identifier
Chris@119 371 end
Chris@119 372
Chris@119 373 def test_activities
Chris@119 374 c = Changeset.new(:repository => @repository,
Chris@119 375 :committed_on => Time.now,
Chris@119 376 :revision => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
Chris@119 377 :scmid => 'abc7234cb2750b63f47bff735edc50a1c0a433c2',
Chris@119 378 :comments => 'test')
Chris@119 379 assert c.event_title.include?('abc7234c:')
Chris@119 380 assert_equal 'abc7234cb2750b63f47bff735edc50a1c0a433c2', c.event_url[:rev]
Chris@119 381 end
Chris@245 382
Chris@245 383 def test_log_utf8
Chris@245 384 @repository.fetch_changesets
Chris@245 385 @repository.reload
Chris@441 386 str_felix_hex = FELIX_HEX.dup
Chris@245 387 if str_felix_hex.respond_to?(:force_encoding)
Chris@245 388 str_felix_hex.force_encoding('UTF-8')
Chris@245 389 end
Chris@441 390 c = @repository.changesets.find_by_revision(
Chris@441 391 'ed5bb786bbda2dee66a2d50faf51429dbc043a7b')
Chris@245 392 assert_equal "#{str_felix_hex} <felix@fachschaften.org>", c.committer
Chris@245 393 end
Chris@441 394
Chris@441 395 def test_previous
Chris@441 396 @repository.fetch_changesets
Chris@441 397 @repository.reload
Chris@441 398 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
Chris@441 399 changeset = @repository.find_changeset_by_name(r1)
Chris@441 400 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
Chris@441 401 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
Chris@441 402 end
Chris@441 403 end
Chris@441 404 end
Chris@441 405
Chris@441 406 def test_previous_nil
Chris@441 407 @repository.fetch_changesets
Chris@441 408 @repository.reload
Chris@441 409 %w|7234cb2750b63f47bff735edc50a1c0a433c2518 7234cb2|.each do |r1|
Chris@441 410 changeset = @repository.find_changeset_by_name(r1)
Chris@441 411 assert_nil changeset.previous
Chris@441 412 end
Chris@441 413 end
Chris@441 414
Chris@441 415 def test_next
Chris@441 416 @repository.fetch_changesets
Chris@441 417 @repository.reload
Chris@441 418 %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2|
Chris@441 419 changeset = @repository.find_changeset_by_name(r2)
Chris@441 420 %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1|
Chris@441 421 assert_equal @repository.find_changeset_by_name(r1), changeset.next
Chris@441 422 end
Chris@441 423 end
Chris@441 424 end
Chris@441 425
Chris@441 426 def test_next_nil
Chris@441 427 @repository.fetch_changesets
Chris@441 428 @repository.reload
Chris@441 429 %w|67e7792ce20ccae2e4bb73eed09bb397819c8834 67e7792ce20cca|.each do |r1|
Chris@441 430 changeset = @repository.find_changeset_by_name(r1)
Chris@441 431 assert_nil changeset.next
Chris@441 432 end
Chris@441 433 end
Chris@0 434 else
Chris@0 435 puts "Git test repository NOT FOUND. Skipping unit tests !!!"
Chris@0 436 def test_fake; assert true end
Chris@0 437 end
Chris@0 438 end