repository_test.rb
238 lines
| 8.2 KiB
| text/x-ruby
|
RubyLexer
|
r5538 | # Redmine - project management software | ||
# Copyright (C) 2006-2011 Jean-Philippe Lang | ||||
|
r470 | # | ||
# 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. | ||||
|
r5538 | # | ||
|
r470 | # 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. | ||||
|
r5538 | # | ||
|
r470 | # 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__) | ||
|
r470 | |||
|
r2773 | class RepositoryTest < ActiveSupport::TestCase | ||
|
r1112 | fixtures :projects, | ||
:trackers, | ||||
:projects_trackers, | ||||
|
r4434 | :enabled_modules, | ||
|
r1112 | :repositories, | ||
:issues, | ||||
:issue_statuses, | ||||
|
r4434 | :issue_categories, | ||
|
r1112 | :changesets, | ||
:changes, | ||||
:users, | ||||
|
r4434 | :members, | ||
:member_roles, | ||||
:roles, | ||||
|
r1112 | :enumerations | ||
|
r5075 | |||
|
r532 | def setup | ||
@repository = Project.find(1).repository | ||||
end | ||||
|
r5075 | |||
|
r2781 | def test_create | ||
|
r925 | repository = Repository::Subversion.new(:project => Project.find(3)) | ||
|
r470 | assert !repository.save | ||
|
r5538 | |||
|
r2781 | repository.url = "svn://localhost" | ||
|
r470 | assert repository.save | ||
repository.reload | ||||
|
r5495 | |||
|
r925 | project = Project.find(3) | ||
|
r2781 | assert_equal repository, project.repository | ||
|
r470 | end | ||
|
r5075 | |||
|
r1651 | def test_destroy | ||
changesets = Changeset.count(:all, :conditions => "repository_id = 10") | ||||
|
r5589 | changes = Change.count(:all, :conditions => "repository_id = 10", | ||
:include => :changeset) | ||||
|
r1651 | assert_difference 'Changeset.count', -changesets do | ||
assert_difference 'Change.count', -changes do | ||||
Repository.find(10).destroy | ||||
end | ||||
end | ||||
end | ||||
|
r5075 | |||
|
r1493 | def test_should_not_create_with_disabled_scm | ||
# disable Subversion | ||||
|
r4606 | with_settings :enabled_scm => ['Darcs', 'Git'] do | ||
|
r5589 | repository = Repository::Subversion.new( | ||
:project => Project.find(3), :url => "svn://localhost") | ||||
|
r4606 | assert !repository.save | ||
|
r5589 | assert_equal I18n.translate('activerecord.errors.messages.invalid'), | ||
repository.errors.on(:type) | ||||
|
r4606 | end | ||
|
r1493 | end | ||
|
r5075 | |||
|
r470 | def test_scan_changesets_for_issue_ids | ||
|
r2053 | Setting.default_language = 'en' | ||
|
r4107 | Setting.notified_events = ['issue_added','issue_updated'] | ||
|
r5495 | |||
|
r470 | # choosing a status to apply to fix issues | ||
|
r5589 | Setting.commit_fix_status_id = IssueStatus.find( | ||
:first, | ||||
:conditions => ["is_closed = ?", true]).id | ||||
|
r810 | Setting.commit_fix_done_ratio = "90" | ||
|
r848 | Setting.commit_ref_keywords = 'refs , references, IssueID' | ||
Setting.commit_fix_keywords = 'fixes , closes' | ||||
|
r1112 | Setting.default_language = 'en' | ||
ActionMailer::Base.deliveries.clear | ||||
|
r5495 | |||
|
r470 | # make sure issue 1 is not already closed | ||
|
r1112 | fixed_issue = Issue.find(1) | ||
assert !fixed_issue.status.is_closed? | ||||
old_status = fixed_issue.status | ||||
|
r5495 | |||
|
r470 | Repository.scan_changesets_for_issue_ids | ||
assert_equal [101, 102], Issue.find(3).changeset_ids | ||||
|
r5495 | |||
|
r470 | # fixed issues | ||
|
r1112 | fixed_issue.reload | ||
|
r810 | assert fixed_issue.status.is_closed? | ||
assert_equal 90, fixed_issue.done_ratio | ||||
assert_equal [101], fixed_issue.changeset_ids | ||||
|
r5495 | |||
|
r1112 | # issue change | ||
journal = fixed_issue.journals.find(:first, :order => 'created_on desc') | ||||
assert_equal User.find_by_login('dlopper'), journal.user | ||||
assert_equal 'Applied in changeset r2.', journal.notes | ||||
|
r5495 | |||
|
r1112 | # 2 email notifications | ||
assert_equal 2, ActionMailer::Base.deliveries.size | ||||
mail = ActionMailer::Base.deliveries.first | ||||
assert_kind_of TMail::Mail, mail | ||||
|
r5589 | assert mail.subject.starts_with?( | ||
"[#{fixed_issue.project.name} - #{fixed_issue.tracker.name} ##{fixed_issue.id}]") | ||||
assert mail.body.include?( | ||||
"Status changed from #{old_status} to #{fixed_issue.status}") | ||||
|
r5495 | |||
|
r470 | # ignoring commits referencing an issue of another project | ||
assert_equal [], Issue.find(4).changesets | ||||
end | ||||
|
r5075 | |||
|
r651 | def test_for_changeset_comments_strip | ||
|
r5589 | repository = Repository::Mercurial.create( | ||
:project => Project.find( 4 ), | ||||
:url => '/foo/bar/baz' ) | ||||
|
r651 | comment = <<-COMMENT | ||
This is a loooooooooooooooooooooooooooong comment | ||||
COMMENT | ||||
changeset = Changeset.new( | ||||
|
r5589 | :comments => comment, :commit_date => Time.now, | ||
:revision => 0, :scmid => 'f39b7922fb3c', | ||||
:committer => 'foo <foo@example.com>', | ||||
:committed_on => Time.now, :repository => repository ) | ||||
|
r651 | assert( changeset.save ) | ||
assert_not_equal( comment, changeset.comments ) | ||||
|
r5589 | assert_equal( 'This is a loooooooooooooooooooooooooooong comment', | ||
changeset.comments ) | ||||
|
r651 | end | ||
|
r4862 | |||
|
r1234 | def test_for_urls_strip | ||
|
r4862 | repository = Repository::Cvs.create( | ||
:project => Project.find(4), | ||||
:url => ' :pserver:login:password@host:/path/to/the/repository', | ||||
:root_url => 'foo ', | ||||
:log_encoding => 'UTF-8') | ||||
|
r1234 | assert repository.save | ||
repository.reload | ||||
|
r5589 | assert_equal ':pserver:login:password@host:/path/to/the/repository', | ||
repository.url | ||||
|
r1234 | assert_equal 'foo', repository.root_url | ||
end | ||||
|
r4862 | |||
|
r2004 | def test_manual_user_mapping | ||
assert_no_difference "Changeset.count(:conditions => 'user_id <> 2')" do | ||||
|
r5075 | c = Changeset.create!( | ||
:repository => @repository, | ||||
:committer => 'foo', | ||||
:committed_on => Time.now, | ||||
:revision => 100, | ||||
:comments => 'Committed by foo.' | ||||
) | ||||
|
r2004 | assert_nil c.user | ||
@repository.committer_ids = {'foo' => '2'} | ||||
assert_equal User.find(2), c.reload.user | ||||
# committer is now mapped | ||||
|
r5075 | c = Changeset.create!( | ||
:repository => @repository, | ||||
:committer => 'foo', | ||||
:committed_on => Time.now, | ||||
:revision => 101, | ||||
:comments => 'Another commit by foo.' | ||||
) | ||||
|
r2004 | assert_equal User.find(2), c.user | ||
end | ||||
end | ||||
|
r5075 | |||
|
r2004 | def test_auto_user_mapping_by_username | ||
|
r5075 | c = Changeset.create!( | ||
|
r5538 | :repository => @repository, | ||
:committer => 'jsmith', | ||||
|
r5075 | :committed_on => Time.now, | ||
|
r5538 | :revision => 100, | ||
:comments => 'Committed by john.' | ||||
|
r5075 | ) | ||
|
r2004 | assert_equal User.find(2), c.user | ||
end | ||||
|
r5075 | |||
|
r2004 | def test_auto_user_mapping_by_email | ||
|
r5075 | c = Changeset.create!( | ||
|
r5538 | :repository => @repository, | ||
:committer => 'john <jsmith@somenet.foo>', | ||||
|
r5075 | :committed_on => Time.now, | ||
|
r5538 | :revision => 100, | ||
:comments => 'Committed by john.' | ||||
|
r5075 | ) | ||
|
r2004 | assert_equal User.find(2), c.user | ||
end | ||||
|
r5244 | |||
def test_filesystem_avaialbe | ||||
klass = Repository::Filesystem | ||||
assert klass.scm_adapter_class | ||||
assert_equal true, klass.scm_available | ||||
end | ||||
|
r5647 | |||
def test_merge_extra_info | ||||
repo = Repository::Subversion.new(:project => Project.find(3)) | ||||
assert !repo.save | ||||
repo.url = "svn://localhost" | ||||
assert repo.save | ||||
repo.reload | ||||
project = Project.find(3) | ||||
assert_equal repo, project.repository | ||||
assert_nil repo.extra_info | ||||
h1 = {"test_1" => {"test_11" => "test_value_11"}} | ||||
repo.merge_extra_info(h1) | ||||
assert_equal h1, repo.extra_info | ||||
h2 = {"test_2" => { | ||||
"test_21" => "test_value_21", | ||||
"test_22" => "test_value_22", | ||||
}} | ||||
repo.merge_extra_info(h2) | ||||
assert_equal (h = {"test_11" => "test_value_11"}), | ||||
repo.extra_info["test_1"] | ||||
assert_equal "test_value_21", | ||||
repo.extra_info["test_2"]["test_21"] | ||||
h3 = {"test_2" => { | ||||
"test_23" => "test_value_23", | ||||
"test_24" => "test_value_24", | ||||
}} | ||||
repo.merge_extra_info(h3) | ||||
assert_equal (h = {"test_11" => "test_value_11"}), | ||||
repo.extra_info["test_1"] | ||||
assert_nil repo.extra_info["test_2"]["test_21"] | ||||
assert_equal "test_value_23", | ||||
repo.extra_info["test_2"]["test_23"] | ||||
end | ||||
|
r470 | end | ||