scm: code clean up unit repository test.

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@5709 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Toshi MARUYAMA 2011-05-08 14:08:46 +00:00
parent 615c81f3df
commit a05a2e0c4d
1 changed files with 24 additions and 11 deletions

View File

@ -52,7 +52,8 @@ class RepositoryTest < ActiveSupport::TestCase
def test_destroy def test_destroy
changesets = Changeset.count(:all, :conditions => "repository_id = 10") changesets = Changeset.count(:all, :conditions => "repository_id = 10")
changes = Change.count(:all, :conditions => "repository_id = 10", :include => :changeset) changes = Change.count(:all, :conditions => "repository_id = 10",
:include => :changeset)
assert_difference 'Changeset.count', -changesets do assert_difference 'Changeset.count', -changesets do
assert_difference 'Change.count', -changes do assert_difference 'Change.count', -changes do
Repository.find(10).destroy Repository.find(10).destroy
@ -63,9 +64,11 @@ class RepositoryTest < ActiveSupport::TestCase
def test_should_not_create_with_disabled_scm def test_should_not_create_with_disabled_scm
# disable Subversion # disable Subversion
with_settings :enabled_scm => ['Darcs', 'Git'] do with_settings :enabled_scm => ['Darcs', 'Git'] do
repository = Repository::Subversion.new(:project => Project.find(3), :url => "svn://localhost") repository = Repository::Subversion.new(
:project => Project.find(3), :url => "svn://localhost")
assert !repository.save assert !repository.save
assert_equal I18n.translate('activerecord.errors.messages.invalid'), repository.errors.on(:type) assert_equal I18n.translate('activerecord.errors.messages.invalid'),
repository.errors.on(:type)
end end
end end
@ -74,7 +77,9 @@ class RepositoryTest < ActiveSupport::TestCase
Setting.notified_events = ['issue_added','issue_updated'] Setting.notified_events = ['issue_added','issue_updated']
# choosing a status to apply to fix issues # choosing a status to apply to fix issues
Setting.commit_fix_status_id = IssueStatus.find(:first, :conditions => ["is_closed = ?", true]).id Setting.commit_fix_status_id = IssueStatus.find(
:first,
:conditions => ["is_closed = ?", true]).id
Setting.commit_fix_done_ratio = "90" Setting.commit_fix_done_ratio = "90"
Setting.commit_ref_keywords = 'refs , references, IssueID' Setting.commit_ref_keywords = 'refs , references, IssueID'
Setting.commit_fix_keywords = 'fixes , closes' Setting.commit_fix_keywords = 'fixes , closes'
@ -104,26 +109,33 @@ class RepositoryTest < ActiveSupport::TestCase
assert_equal 2, ActionMailer::Base.deliveries.size assert_equal 2, ActionMailer::Base.deliveries.size
mail = ActionMailer::Base.deliveries.first mail = ActionMailer::Base.deliveries.first
assert_kind_of TMail::Mail, mail assert_kind_of TMail::Mail, mail
assert mail.subject.starts_with?("[#{fixed_issue.project.name} - #{fixed_issue.tracker.name} ##{fixed_issue.id}]") assert mail.subject.starts_with?(
assert mail.body.include?("Status changed from #{old_status} to #{fixed_issue.status}") "[#{fixed_issue.project.name} - #{fixed_issue.tracker.name} ##{fixed_issue.id}]")
assert mail.body.include?(
"Status changed from #{old_status} to #{fixed_issue.status}")
# ignoring commits referencing an issue of another project # ignoring commits referencing an issue of another project
assert_equal [], Issue.find(4).changesets assert_equal [], Issue.find(4).changesets
end end
def test_for_changeset_comments_strip def test_for_changeset_comments_strip
repository = Repository::Mercurial.create( :project => Project.find( 4 ), :url => '/foo/bar/baz' ) repository = Repository::Mercurial.create(
:project => Project.find( 4 ),
:url => '/foo/bar/baz' )
comment = <<-COMMENT comment = <<-COMMENT
This is a loooooooooooooooooooooooooooong comment This is a loooooooooooooooooooooooooooong comment
COMMENT COMMENT
changeset = Changeset.new( changeset = Changeset.new(
:comments => comment, :commit_date => Time.now, :revision => 0, :scmid => 'f39b7922fb3c', :comments => comment, :commit_date => Time.now,
:committer => 'foo <foo@example.com>', :committed_on => Time.now, :repository => repository ) :revision => 0, :scmid => 'f39b7922fb3c',
:committer => 'foo <foo@example.com>',
:committed_on => Time.now, :repository => repository )
assert( changeset.save ) assert( changeset.save )
assert_not_equal( comment, changeset.comments ) assert_not_equal( comment, changeset.comments )
assert_equal( 'This is a loooooooooooooooooooooooooooong comment', changeset.comments ) assert_equal( 'This is a loooooooooooooooooooooooooooong comment',
changeset.comments )
end end
def test_for_urls_strip def test_for_urls_strip
@ -134,7 +146,8 @@ class RepositoryTest < ActiveSupport::TestCase
:log_encoding => 'UTF-8') :log_encoding => 'UTF-8')
assert repository.save assert repository.save
repository.reload repository.reload
assert_equal ':pserver:login:password@host:/path/to/the/repository', repository.url assert_equal ':pserver:login:password@host:/path/to/the/repository',
repository.url
assert_equal 'foo', repository.root_url assert_equal 'foo', repository.root_url
end end