repository_git_test.rb
526 lines
| 20.1 KiB
| text/x-ruby
|
RubyLexer
|
r5580 | # Redmine - project management software | ||
# Copyright (C) 2006-2011 Jean-Philippe Lang | ||||
|
r1222 | # | ||
# This program is free software; you can redistribute it and/or | ||||
# modify it under the terms of the GNU General Public License | ||||
# as published by the Free Software Foundation; either version 2 | ||||
# of the License, or (at your option) any later version. | ||||
|
r5580 | # | ||
|
r1222 | # This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
|
r5580 | # | ||
|
r1222 | # You should have received a copy of the GNU General Public License | ||
# along with this program; if not, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||||
|
r4395 | require File.expand_path('../../test_helper', __FILE__) | ||
|
r1222 | |||
|
r2773 | class RepositoryGitTest < ActiveSupport::TestCase | ||
|
r4730 | fixtures :projects, :repositories, :enabled_modules, :users, :roles | ||
|
r5924 | REPOSITORY_PATH = Rails.root.join('tmp/test/git_repository').to_s | ||
|
r1752 | REPOSITORY_PATH.gsub!(/\//, "\\") if Redmine::Platform.mswin? | ||
|
r4730 | |||
|
r8700 | NUM_REV = 28 | ||
|
r8735 | NUM_HEAD = 6 | ||
|
r6943 | |||
|
r4836 | FELIX_HEX = "Felix Sch\xC3\xA4fer" | ||
|
r4937 | CHAR_1_HEX = "\xc3\x9c" | ||
|
r4836 | |||
|
r4955 | ## Ruby uses ANSI api to fork a process on Windows. | ||
## Japanese Shift_JIS and Traditional Chinese Big5 have 0x5c(backslash) problem | ||||
## and these are incompatible with ASCII. | ||||
# WINDOWS_PASS = Redmine::Platform.mswin? | ||||
WINDOWS_PASS = false | ||||
|
r4952 | |||
|
r5885 | ## Git, Mercurial and CVS path encodings are binary. | ||
## Subversion supports URL encoding for path. | ||||
## Redmine Mercurial adapter and extension use URL encoding. | ||||
## Git accepts only binary path in command line parameter. | ||||
## So, there is no way to use binary command line parameter in JRuby. | ||||
JRUBY_SKIP = (RUBY_PLATFORM == 'java') | ||||
JRUBY_SKIP_STR = "TODO: This test fails in JRuby" | ||||
|
r4952 | if File.directory?(REPOSITORY_PATH) | ||
|
r5297 | def setup | ||
klass = Repository::Git | ||||
assert_equal "Git", klass.scm_name | ||||
assert klass.scm_adapter_class | ||||
assert_not_equal "", klass.scm_command | ||||
assert_equal true, klass.scm_available | ||||
|
r5580 | |||
|
r5297 | @project = Project.find(3) | ||
@repository = Repository::Git.create( | ||||
:project => @project, | ||||
:url => REPOSITORY_PATH, | ||||
:path_encoding => 'ISO-8859-1' | ||||
) | ||||
assert @repository | ||||
@char_1 = CHAR_1_HEX.dup | ||||
if @char_1.respond_to?(:force_encoding) | ||||
@char_1.force_encoding('UTF-8') | ||||
end | ||||
end | ||||
|
r5580 | |||
|
r1222 | def test_fetch_changesets_from_scratch | ||
|
r5668 | assert_nil @repository.extra_info | ||
|
r6942 | assert_equal 0, @repository.changesets.count | ||
|
r1222 | @repository.fetch_changesets | ||
|
r6942 | @project.reload | ||
|
r4730 | |||
|
r6944 | assert_equal NUM_REV, @repository.changesets.count | ||
|
r8700 | assert_equal 39, @repository.changes.count | ||
|
r4730 | |||
|
r8778 | commit = @repository.changesets.find_by_revision("7234cb2750b63f47bff735edc50a1c0a433c2518") | ||
assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", commit.scmid | ||||
|
r1997 | assert_equal "Initial import.\nThe repository contains 3 files.", commit.comments | ||
assert_equal "jsmith <jsmith@foo.bar>", commit.committer | ||||
|
r2004 | assert_equal User.find_by_login('jsmith'), commit.user | ||
|
r1997 | # TODO: add a commit with commit time <> author time to the test repository | ||
assert_equal "2007-12-14 09:22:52".to_time, commit.committed_on | ||||
assert_equal "2007-12-14".to_date, commit.commit_date | ||||
assert_equal 3, commit.changes.count | ||||
change = commit.changes.sort_by(&:path).first | ||||
assert_equal "README", change.path | ||||
assert_equal "A", change.action | ||||
|
r5668 | |||
|
r8735 | assert_equal NUM_HEAD, @repository.extra_info["heads"].size | ||
|
r1222 | end | ||
|
r5580 | |||
|
r1222 | def test_fetch_changesets_incremental | ||
|
r6945 | assert_equal 0, @repository.changesets.count | ||
|
r1222 | @repository.fetch_changesets | ||
|
r6945 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r8719 | extra_info_heads = @repository.extra_info["heads"].dup | ||
|
r8735 | assert_equal NUM_HEAD, extra_info_heads.size | ||
|
r8719 | extra_info_heads.delete_if { |x| x == "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c" } | ||
assert_equal 4, extra_info_heads.size | ||||
|
r5668 | |||
del_revs = [ | ||||
"83ca5fd546063a3c7dc2e568ba3355661a9e2b2c", | ||||
"ed5bb786bbda2dee66a2d50faf51429dbc043a7b", | ||||
"4f26664364207fa8b1af9f8722647ab2d4ac5d43", | ||||
"deff712f05a90d96edbd70facc47d944be5897e3", | ||||
"32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf", | ||||
"7e61ac704deecde634b51e59daa8110435dcb3da", | ||||
] | ||||
@repository.changesets.each do |rev| | ||||
rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s } | ||||
end | ||||
|
r6945 | @project.reload | ||
|
r4866 | cs1 = @repository.changesets | ||
|
r8719 | assert_equal NUM_REV - 6, cs1.count | ||
extra_info_heads << "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8" | ||||
h = {} | ||||
h["heads"] = extra_info_heads | ||||
|
r5668 | @repository.merge_extra_info(h) | ||
@repository.save | ||||
|
r6945 | @project.reload | ||
|
r8719 | assert @repository.extra_info["heads"].index("4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8") | ||
|
r1222 | @repository.fetch_changesets | ||
|
r6945 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r8735 | assert_equal NUM_HEAD, @repository.extra_info["heads"].size | ||
|
r8719 | assert @repository.extra_info["heads"].index("83ca5fd546063a3c7dc2e568ba3355661a9e2b2c") | ||
|
r1222 | end | ||
|
r4493 | |||
|
r8712 | def test_fetch_changesets_history_editing | ||
|
r6950 | assert_equal 0, @repository.changesets.count | ||
|
r5669 | @repository.fetch_changesets | ||
|
r6950 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r8719 | extra_info_heads = @repository.extra_info["heads"].dup | ||
|
r8735 | assert_equal NUM_HEAD, extra_info_heads.size | ||
|
r8719 | extra_info_heads.delete_if { |x| x == "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c" } | ||
assert_equal 4, extra_info_heads.size | ||||
|
r5669 | |||
del_revs = [ | ||||
"83ca5fd546063a3c7dc2e568ba3355661a9e2b2c", | ||||
"ed5bb786bbda2dee66a2d50faf51429dbc043a7b", | ||||
"4f26664364207fa8b1af9f8722647ab2d4ac5d43", | ||||
"deff712f05a90d96edbd70facc47d944be5897e3", | ||||
"32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf", | ||||
"7e61ac704deecde634b51e59daa8110435dcb3da", | ||||
] | ||||
@repository.changesets.each do |rev| | ||||
rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s } | ||||
end | ||||
|
r6950 | @project.reload | ||
|
r8712 | assert_equal NUM_REV - 6, @repository.changesets.count | ||
c = Changeset.new(:repository => @repository, | ||||
:committed_on => Time.now, | ||||
:revision => "abcd1234efgh", | ||||
:scmid => "abcd1234efgh", | ||||
:comments => 'test') | ||||
assert c.save | ||||
@project.reload | ||||
assert_equal NUM_REV - 5, @repository.changesets.count | ||||
|
r8719 | extra_info_heads << "abcd1234efgh" | ||
h = {} | ||||
h["heads"] = extra_info_heads | ||||
|
r5669 | @repository.merge_extra_info(h) | ||
@repository.save | ||||
|
r6950 | @project.reload | ||
|
r8719 | h1 = @repository.extra_info["heads"].dup | ||
assert h1.index("abcd1234efgh") | ||||
assert_equal 5, h1.size | ||||
|
r5669 | |||
@repository.fetch_changesets | ||||
|
r6950 | @project.reload | ||
|
r8712 | assert_equal NUM_REV - 5, @repository.changesets.count | ||
|
r8719 | h2 = @repository.extra_info["heads"].dup | ||
assert_equal h1, h2 | ||||
|
r5669 | end | ||
|
r7592 | def test_parents | ||
assert_equal 0, @repository.changesets.count | ||||
@repository.fetch_changesets | ||||
@project.reload | ||||
assert_equal NUM_REV, @repository.changesets.count | ||||
r1 = @repository.find_changeset_by_name("7234cb2750b63") | ||||
assert_equal [], r1.parents | ||||
r2 = @repository.find_changeset_by_name("899a15dba03a3") | ||||
assert_equal 1, r2.parents.length | ||||
assert_equal "7234cb2750b63f47bff735edc50a1c0a433c2518", | ||||
r2.parents[0].identifier | ||||
r3 = @repository.find_changeset_by_name("32ae898b720c2") | ||||
assert_equal 2, r3.parents.length | ||||
|
r7600 | r4 = [r3.parents[0].identifier, r3.parents[1].identifier].sort | ||
assert_equal "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8", r4[0] | ||||
assert_equal "7e61ac704deecde634b51e59daa8110435dcb3da", r4[1] | ||||
|
r7592 | end | ||
|
r5734 | def test_db_consistent_ordering_init | ||
assert_nil @repository.extra_info | ||||
|
r6951 | assert_equal 0, @repository.changesets.count | ||
|
r5734 | @repository.fetch_changesets | ||
|
r6951 | @project.reload | ||
|
r5734 | assert_equal 1, @repository.extra_info["db_consistent"]["ordering"] | ||
end | ||||
|
r5735 | def test_db_consistent_ordering_before_1_2 | ||
assert_nil @repository.extra_info | ||||
|
r6952 | assert_equal 0, @repository.changesets.count | ||
|
r5735 | @repository.fetch_changesets | ||
|
r6952 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5735 | assert_not_nil @repository.extra_info | ||
|
r8779 | h = {} | ||
h["heads"] = [] | ||||
h["branches"] = {} | ||||
h["db_consistent"] = {} | ||||
@repository.merge_extra_info(h) | ||||
|
r5735 | @repository.save | ||
|
r6952 | assert_equal NUM_REV, @repository.changesets.count | ||
|
r5735 | @repository.fetch_changesets | ||
|
r6952 | @project.reload | ||
|
r5735 | assert_equal 0, @repository.extra_info["db_consistent"]["ordering"] | ||
|
r8719 | extra_info_heads = @repository.extra_info["heads"].dup | ||
extra_info_heads.delete_if { |x| x == "83ca5fd546063a3c7dc2e568ba3355661a9e2b2c" } | ||||
|
r5735 | del_revs = [ | ||
"83ca5fd546063a3c7dc2e568ba3355661a9e2b2c", | ||||
"ed5bb786bbda2dee66a2d50faf51429dbc043a7b", | ||||
"4f26664364207fa8b1af9f8722647ab2d4ac5d43", | ||||
"deff712f05a90d96edbd70facc47d944be5897e3", | ||||
"32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf", | ||||
"7e61ac704deecde634b51e59daa8110435dcb3da", | ||||
] | ||||
@repository.changesets.each do |rev| | ||||
rev.destroy if del_revs.detect {|r| r == rev.scmid.to_s } | ||||
end | ||||
|
r6964 | @project.reload | ||
|
r5735 | cs1 = @repository.changesets | ||
|
r8700 | assert_equal NUM_REV - 6, cs1.count | ||
|
r5735 | assert_equal 0, @repository.extra_info["db_consistent"]["ordering"] | ||
|
r8719 | |||
extra_info_heads << "4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8" | ||||
h = {} | ||||
h["heads"] = extra_info_heads | ||||
|
r5735 | @repository.merge_extra_info(h) | ||
@repository.save | ||||
|
r6952 | @project.reload | ||
|
r8719 | assert @repository.extra_info["heads"].index("4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8") | ||
|
r5735 | @repository.fetch_changesets | ||
|
r8719 | @project.reload | ||
|
r6952 | assert_equal NUM_REV, @repository.changesets.count | ||
|
r8735 | assert_equal NUM_HEAD, @repository.extra_info["heads"].size | ||
|
r8719 | |||
|
r5735 | assert_equal 0, @repository.extra_info["db_consistent"]["ordering"] | ||
end | ||||
|
r8696 | def test_heads_from_branches_hash | ||
assert_nil @repository.extra_info | ||||
assert_equal 0, @repository.changesets.count | ||||
assert_equal [], @repository.heads_from_branches_hash | ||||
h = {} | ||||
h["branches"] = {} | ||||
h["branches"]["test1"] = {} | ||||
h["branches"]["test1"]["last_scmid"] = "1234abcd" | ||||
h["branches"]["test2"] = {} | ||||
h["branches"]["test2"]["last_scmid"] = "abcd1234" | ||||
@repository.merge_extra_info(h) | ||||
@repository.save | ||||
@project.reload | ||||
assert_equal ["1234abcd", "abcd1234"], @repository.heads_from_branches_hash.sort | ||||
end | ||||
|
r4932 | def test_latest_changesets | ||
|
r6965 | assert_equal 0, @repository.changesets.count | ||
|
r4932 | @repository.fetch_changesets | ||
|
r6965 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4932 | # with limit | ||
|
r8690 | changesets = @repository.latest_changesets('', 'master', 2) | ||
|
r4932 | assert_equal 2, changesets.size | ||
# with path | ||||
|
r8690 | changesets = @repository.latest_changesets('images', 'master') | ||
|
r4932 | assert_equal [ | ||
'deff712f05a90d96edbd70facc47d944be5897e3', | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
changesets = @repository.latest_changesets('README', nil) | ||||
assert_equal [ | ||||
'32ae898b720c2f7eec2723d5bdd558b4cb2d3ddf', | ||||
'4a07fe31bffcf2888791f3e6cbc9c4545cefe3e8', | ||||
'713f4944648826f558cf548222f813dabe7cbb04', | ||||
'61b685fbe55ab05b5ac68402d5720c1a6ac973d1', | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
|
r4934 | # with path, revision and limit | ||
|
r4932 | changesets = @repository.latest_changesets('images', '899a15dba') | ||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
|
r4934 | changesets = @repository.latest_changesets('images', '899a15dba', 1) | ||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
], changesets.collect(&:revision) | ||||
|
r4932 | changesets = @repository.latest_changesets('README', '899a15dba') | ||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
|
r4934 | |||
changesets = @repository.latest_changesets('README', '899a15dba', 1) | ||||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
], changesets.collect(&:revision) | ||||
|
r4935 | # with path, tag and limit | ||
changesets = @repository.latest_changesets('images', 'tag01.annotated') | ||||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
changesets = @repository.latest_changesets('images', 'tag01.annotated', 1) | ||||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
], changesets.collect(&:revision) | ||||
changesets = @repository.latest_changesets('README', 'tag01.annotated') | ||||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
changesets = @repository.latest_changesets('README', 'tag01.annotated', 1) | ||||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
], changesets.collect(&:revision) | ||||
|
r4936 | |||
# with path, branch and limit | ||||
changesets = @repository.latest_changesets('images', 'test_branch') | ||||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
changesets = @repository.latest_changesets('images', 'test_branch', 1) | ||||
assert_equal [ | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
], changesets.collect(&:revision) | ||||
changesets = @repository.latest_changesets('README', 'test_branch') | ||||
assert_equal [ | ||||
'713f4944648826f558cf548222f813dabe7cbb04', | ||||
'61b685fbe55ab05b5ac68402d5720c1a6ac973d1', | ||||
'899a15dba03a3b350b89c3f537e4bbe02a03cdc9', | ||||
'7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
], changesets.collect(&:revision) | ||||
changesets = @repository.latest_changesets('README', 'test_branch', 2) | ||||
assert_equal [ | ||||
'713f4944648826f558cf548222f813dabe7cbb04', | ||||
'61b685fbe55ab05b5ac68402d5720c1a6ac973d1', | ||||
], changesets.collect(&:revision) | ||||
|
r4938 | |||
|
r5885 | if JRUBY_SKIP | ||
puts JRUBY_SKIP_STR | ||||
else | ||||
# latin-1 encoding path | ||||
changesets = @repository.latest_changesets( | ||||
"latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89') | ||||
assert_equal [ | ||||
|
r4938 | '64f1f3e89ad1cb57976ff0ad99a107012ba3481d', | ||
'4fc55c43bf3d3dc2efb66145365ddc17639ce81e', | ||||
], changesets.collect(&:revision) | ||||
|
r5885 | changesets = @repository.latest_changesets( | ||
|
r4938 | "latin-1-dir/test-#{@char_1}-2.txt", '64f1f3e89', 1) | ||
|
r5885 | assert_equal [ | ||
|
r4938 | '64f1f3e89ad1cb57976ff0ad99a107012ba3481d', | ||
], changesets.collect(&:revision) | ||||
|
r5885 | end | ||
|
r4932 | end | ||
|
r4943 | def test_latest_changesets_latin_1_dir | ||
|
r4952 | if WINDOWS_PASS | ||
# | ||||
|
r5885 | elsif JRUBY_SKIP | ||
puts JRUBY_SKIP_STR | ||||
|
r4943 | else | ||
|
r6967 | assert_equal 0, @repository.changesets.count | ||
|
r4943 | @repository.fetch_changesets | ||
|
r6967 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4943 | changesets = @repository.latest_changesets( | ||
"latin-1-dir/test-#{@char_1}-subdir", '1ca7f5ed') | ||||
assert_equal [ | ||||
'1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127', | ||||
], changesets.collect(&:revision) | ||||
end | ||||
end | ||||
|
r4583 | def test_find_changeset_by_name | ||
|
r6966 | assert_equal 0, @repository.changesets.count | ||
|
r4583 | @repository.fetch_changesets | ||
|
r6966 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4583 | ['7234cb2750b63f47bff735edc50a1c0a433c2518', '7234cb2750b'].each do |r| | ||
assert_equal '7234cb2750b63f47bff735edc50a1c0a433c2518', | ||||
@repository.find_changeset_by_name(r).revision | ||||
end | ||||
end | ||||
def test_find_changeset_by_empty_name | ||||
|
r6968 | assert_equal 0, @repository.changesets.count | ||
|
r4583 | @repository.fetch_changesets | ||
|
r6968 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4583 | ['', ' ', nil].each do |r| | ||
assert_nil @repository.find_changeset_by_name(r) | ||||
end | ||||
end | ||||
|
r4493 | def test_identifier | ||
|
r6969 | assert_equal 0, @repository.changesets.count | ||
|
r4493 | @repository.fetch_changesets | ||
|
r6969 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5602 | c = @repository.changesets.find_by_revision( | ||
'7234cb2750b63f47bff735edc50a1c0a433c2518') | ||||
|
r4493 | assert_equal c.scmid, c.identifier | ||
end | ||||
def test_format_identifier | ||||
|
r6970 | assert_equal 0, @repository.changesets.count | ||
|
r4493 | @repository.fetch_changesets | ||
|
r6970 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5602 | c = @repository.changesets.find_by_revision( | ||
'7234cb2750b63f47bff735edc50a1c0a433c2518') | ||||
|
r4571 | assert_equal '7234cb27', c.format_identifier | ||
|
r4493 | end | ||
def test_activities | ||||
|
r4571 | c = Changeset.new(:repository => @repository, | ||
:committed_on => Time.now, | ||||
|
r4503 | :revision => 'abc7234cb2750b63f47bff735edc50a1c0a433c2', | ||
:scmid => 'abc7234cb2750b63f47bff735edc50a1c0a433c2', | ||||
:comments => 'test') | ||||
assert c.event_title.include?('abc7234c:') | ||||
|
r4571 | assert_equal 'abc7234cb2750b63f47bff735edc50a1c0a433c2', c.event_url[:rev] | ||
|
r4493 | end | ||
|
r4836 | |||
def test_log_utf8 | ||||
|
r6971 | assert_equal 0, @repository.changesets.count | ||
|
r4836 | @repository.fetch_changesets | ||
|
r6971 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5043 | str_felix_hex = FELIX_HEX.dup | ||
|
r4836 | if str_felix_hex.respond_to?(:force_encoding) | ||
str_felix_hex.force_encoding('UTF-8') | ||||
end | ||||
|
r5602 | c = @repository.changesets.find_by_revision( | ||
'ed5bb786bbda2dee66a2d50faf51429dbc043a7b') | ||||
|
r4836 | assert_equal "#{str_felix_hex} <felix@fachschaften.org>", c.committer | ||
end | ||||
|
r4954 | |||
def test_previous | ||||
|
r6974 | assert_equal 0, @repository.changesets.count | ||
|
r4954 | @repository.fetch_changesets | ||
|
r6974 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4954 | %w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1| | ||
changeset = @repository.find_changeset_by_name(r1) | ||||
%w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2| | ||||
assert_equal @repository.find_changeset_by_name(r2), changeset.previous | ||||
end | ||||
end | ||||
end | ||||
def test_previous_nil | ||||
|
r6975 | assert_equal 0, @repository.changesets.count | ||
|
r4954 | @repository.fetch_changesets | ||
|
r6975 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r8719 | %w|7234cb2750b63f47bff735edc50a1c0a433c2518 7234cb275|.each do |r1| | ||
|
r4954 | changeset = @repository.find_changeset_by_name(r1) | ||
assert_nil changeset.previous | ||||
end | ||||
end | ||||
def test_next | ||||
|
r6976 | assert_equal 0, @repository.changesets.count | ||
|
r4954 | @repository.fetch_changesets | ||
|
r6976 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4954 | %w|64f1f3e89ad1cb57976ff0ad99a107012ba3481d 64f1f3e89ad1|.each do |r2| | ||
changeset = @repository.find_changeset_by_name(r2) | ||||
%w|1ca7f5ed374f3cb31a93ae5215c2e25cc6ec5127 1ca7f5ed|.each do |r1| | ||||
assert_equal @repository.find_changeset_by_name(r1), changeset.next | ||||
end | ||||
end | ||||
end | ||||
def test_next_nil | ||||
|
r6977 | assert_equal 0, @repository.changesets.count | ||
|
r4954 | @repository.fetch_changesets | ||
|
r6977 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r8719 | %w|2a682156a3b6e77a8bf9cd4590e8db757f3c6c78 2a682156a3b6e77a|.each do |r1| | ||
|
r4954 | changeset = @repository.find_changeset_by_name(r1) | ||
assert_nil changeset.next | ||||
end | ||||
end | ||||
|
r1222 | else | ||
puts "Git test repository NOT FOUND. Skipping unit tests !!!" | ||||
def test_fake; assert true end | ||||
end | ||||
end | ||||