##// END OF EJS Templates
Merged r14101 (#19354)....
Merged r14101 (#19354). git-svn-id: http://svn.redmine.org/redmine/branches/3.0-stable@14111 e93f8b46-1217-0410-a6f0-8f06a7374b81

File last commit:

r13490:000124f44f53
r13729:2f78c8a7ec28
Show More
repository_mercurial_test.rb
644 lines | 23.3 KiB | text/x-ruby | RubyLexer
/ test / unit / repository_mercurial_test.rb
Toshi MARUYAMA
scm: mercurial: remove trailing white-spaces from unit model test....
r5584 # Redmine - project management software
Jean-Philippe Lang
Copyright update....
r13490 # Copyright (C) 2006-2015 Jean-Philippe Lang
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 #
# 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.
Toshi MARUYAMA
scm: mercurial: remove trailing white-spaces from unit model test....
r5584 #
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 # 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.
Toshi MARUYAMA
scm: mercurial: remove trailing white-spaces from unit model test....
r5584 #
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 # 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.
Jean-Baptiste Barth
Use absolute paths in test/**/* requires for Ruby 1.9.2 compatibility. #4050...
r4395 require File.expand_path('../../test_helper', __FILE__)
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978
Eric Davis
Upgraded to Rails 2.3.4 (#3597)...
r2773 class RepositoryMercurialTest < ActiveSupport::TestCase
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 fixtures :projects
Toshi MARUYAMA
scm: mercurial: fix unit model test fails if hg command is unavailable....
r5529
Toshi MARUYAMA
scm: mercurial: add test to override human_attribute_name of "path to repository"...
r8844 include Redmine::I18n
Toshi MARUYAMA
scm: mercurial: replace RAILS_ROOT to Rails.root in unit model test....
r5931 REPOSITORY_PATH = Rails.root.join('tmp/test/mercurial_repository').to_s
Toshi MARUYAMA
scm: mercurial: add one "closed" branch to test repository (#16177)...
r12654 NUM_REV = 34
Jean-Philippe Lang
Merged rails-4.1 branch (#14534)....
r13100
CHAR_1_HEX = "\xc3\x9c".force_encoding('UTF-8')
BRANCH_CHAR_1 = "branch-#{CHAR_1_HEX}-01".force_encoding('UTF-8')
Toshi MARUYAMA
scm: mercurial: additional unit model tests for path encoding (#2664)....
r4879
Toshi MARUYAMA
scm: mercurial: split unit model test setup whether repository required or not...
r8842 def setup
@project = Project.find(3)
@repository = Repository::Mercurial.create(
:project => @project,
:url => REPOSITORY_PATH,
:path_encoding => 'ISO-8859-1'
)
assert @repository
end
Toshi MARUYAMA
scm: mercurial: add test to override human_attribute_name of "path to repository"...
r8844 def test_blank_path_to_repository_error_message
set_language_if_valid 'en'
repo = Repository::Mercurial.new(
:project => @project,
Toshi MARUYAMA
scm: mercurial: remove unnecessary log_encoding from overriding human_attribute_name test...
r8846 :identifier => 'test'
Toshi MARUYAMA
scm: mercurial: add test to override human_attribute_name of "path to repository"...
r8844 )
assert !repo.save
Jean-Philippe Lang
Replaced "can't" with "cannot" in error messages....
r13399 assert_include "Path to repository cannot be blank",
Toshi MARUYAMA
scm: mercurial: add test to override human_attribute_name of "path to repository"...
r8844 repo.errors.full_messages
end
def test_blank_path_to_repository_error_message_fr
set_language_if_valid 'fr'
Jean-Philippe Lang
Merged rails-4.1 branch (#14534)....
r13100 str = "Chemin du d\xc3\xa9p\xc3\xb4t doit \xc3\xaatre renseign\xc3\xa9(e)".force_encoding('UTF-8')
Toshi MARUYAMA
scm: mercurial: add test to override human_attribute_name of "path to repository"...
r8844 repo = Repository::Mercurial.new(
:project => @project,
:url => "",
:identifier => 'test',
Toshi MARUYAMA
scm: mercurial: remove unnecessary log_encoding from overriding human_attribute_name test...
r8846 :path_encoding => ''
Toshi MARUYAMA
scm: mercurial: add test to override human_attribute_name of "path to repository"...
r8844 )
assert !repo.save
assert_include str, repo.errors.full_messages
end
Toshi MARUYAMA
scm: mercurial: fix unit model test fails if hg command is unavailable....
r5529 if File.directory?(REPOSITORY_PATH)
Toshi MARUYAMA
scm: mercurial: split unit model test setup whether repository required or not...
r8842 def test_scm_available
Toshi MARUYAMA
scm: mercurial: fix unit model test fails if hg command is unavailable....
r5529 klass = Repository::Mercurial
assert_equal "Mercurial", klass.scm_name
assert klass.scm_adapter_class
assert_not_equal "", klass.scm_command
assert_equal true, klass.scm_available
Toshi MARUYAMA
scm: mercurial: additional unit model tests for path encoding (#2664)....
r4879 end
Toshi MARUYAMA
scm: mercurial: code clean up unit model test....
r4871
Toshi MARUYAMA
scm: mercurial: add model entries test (#14361)...
r12482 def test_entries_on_tip
Jean-Philippe Lang
Fixed that Repository#entries returns an Array....
r9621 entries = @repository.entries
assert_kind_of Redmine::Scm::Adapters::Entries, entries
end
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_entries (#14361)...
r12499 def assert_entries(is_short_scmid=true)
hex = "9d5b5b00419901478496242e0768deba1ce8c51e"
scmid = scmid_for_assert(hex, is_short_scmid)
Toshi MARUYAMA
scm: mercurial: add model entries test (#14361)...
r12482 [2, '400bb8672109', '400', 400].each do |r|
entries1 = @repository.entries(nil, r)
assert entries1
assert_kind_of Redmine::Scm::Adapters::Entries, entries1
assert_equal 3, entries1.size
readme = entries1[2]
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_entries (#14361)...
r12499 assert_equal '1', readme.lastrev.revision
assert_equal scmid, readme.lastrev.identifier
assert_equal '1', readme.changeset.revision
assert_equal scmid, readme.changeset.scmid
Toshi MARUYAMA
scm: mercurial: add model entries test (#14361)...
r12482 end
end
Toshi MARUYAMA
scm: mercurial: split test_entries_short_id to sub method (#14361)...
r12493 private :assert_entries
def test_entries_short_id
assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 create_rev0_short_id
assert_equal 1, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: split test_entries_short_id to sub method (#14361)...
r12493 @repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_entries (#14361)...
r12499 assert_entries(true)
Toshi MARUYAMA
scm: mercurial: split test_entries_short_id to sub method (#14361)...
r12493 end
Toshi MARUYAMA
scm: mercurial: add model entries test (#14361)...
r12482
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_entries_long_id
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
assert_entries(false)
end
Toshi MARUYAMA
scm: mercurial: add model entry test (#14361)...
r12483 def test_entry_on_tip
entry = @repository.entry
assert_kind_of Redmine::Scm::Adapters::Entry, entry
assert_equal "", entry.path
assert_equal 'dir', entry.kind
end
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_entry (#14361)...
r12498 def assert_entry(is_short_scmid=true)
hex = "0885933ad4f68d77c2649cd11f8311276e7ef7ce"
scmid = scmid_for_assert(hex, is_short_scmid)
Toshi MARUYAMA
scm: mercurial: add model entry test (#14361)...
r12483 ["README", "/README"].each do |path|
["0", "0885933ad4f6", "0885933ad4f68d77c2649cd11f8311276e7ef7ce"].each do |rev|
entry = @repository.entry(path, rev)
assert_kind_of Redmine::Scm::Adapters::Entry, entry
assert_equal "README", entry.path
assert_equal "file", entry.kind
assert_equal '0', entry.lastrev.revision
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_entry (#14361)...
r12498 assert_equal scmid, entry.lastrev.identifier
Toshi MARUYAMA
scm: mercurial: add model entry test (#14361)...
r12483 end
end
["sources", "/sources", "/sources/"].each do |path|
["0", "0885933ad4f6", "0885933ad4f68d77c2649cd11f8311276e7ef7ce"].each do |rev|
entry = @repository.entry(path, rev)
assert_kind_of Redmine::Scm::Adapters::Entry, entry
assert_equal "sources", entry.path
assert_equal "dir", entry.kind
end
end
["sources/watchers_controller.rb", "/sources/watchers_controller.rb"].each do |path|
["0", "0885933ad4f6", "0885933ad4f68d77c2649cd11f8311276e7ef7ce"].each do |rev|
entry = @repository.entry(path, rev)
assert_kind_of Redmine::Scm::Adapters::Entry, entry
assert_equal "sources/watchers_controller.rb", entry.path
assert_equal "file", entry.kind
assert_equal '0', entry.lastrev.revision
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_entry (#14361)...
r12498 assert_equal scmid, entry.lastrev.identifier
Toshi MARUYAMA
scm: mercurial: add model entry test (#14361)...
r12483 end
end
end
Toshi MARUYAMA
scm: mercurial: split test_entry_short_id to sub method (#14361)...
r12492 private :assert_entry
def test_entry_short_id
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 assert_equal 0, @repository.changesets.count
create_rev0_short_id
assert_equal 1, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_entry (#14361)...
r12498 assert_entry(true)
Toshi MARUYAMA
scm: mercurial: split test_entry_short_id to sub method (#14361)...
r12492 end
Toshi MARUYAMA
scm: mercurial: add model entry test (#14361)...
r12483
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_entry_long_id
assert_entry(false)
end
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 def test_fetch_changesets_from_scratch
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_fetch_changesets_from_scratch at unit model test...
r6979 assert_equal 0, @repository.changesets.count
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_fetch_changesets_from_scratch at unit model test...
r6979 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Jean-Philippe Lang
Renamed #changes association to #filechanges (clash with AR::Base.changes that triggers errors with Rails 3.2.5)....
r9576 assert_equal 46, @repository.filechanges.count
Toshi MARUYAMA
scm: mercurial: add check scmid to RepositoryMercurialTest#test_fetch_changesets_from_scratch (#14361)...
r12475 rev0 = @repository.changesets.find_by_revision('0')
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534 assert_equal "Initial import.\nThe repository contains 3 files.",
Toshi MARUYAMA
scm: mercurial: add check scmid to RepositoryMercurialTest#test_fetch_changesets_from_scratch (#14361)...
r12475 rev0.comments
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 assert_equal "0885933ad4f68d77c2649cd11f8311276e7ef7ce", rev0.scmid
Toshi MARUYAMA
scm: mercurial: add asserting first and last changeset to test_fetch_changesets_from_scratch (#14361)...
r12501 first_rev = @repository.changesets.first
last_rev = @repository.changesets.last
assert_equal "#{NUM_REV - 1}", first_rev.revision
assert_equal "0", last_rev.revision
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 end
Toshi MARUYAMA
scm: mercurial: code clean up unit model test....
r4871
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_fetch_changesets_keep_short_id
assert_equal 0, @repository.changesets.count
create_rev0_short_id
assert_equal 1, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
rev1 = @repository.changesets.find_by_revision('1')
assert_equal "9d5b5b004199", rev1.scmid
end
def test_fetch_changesets_keep_long_id
assert_equal 0, @repository.changesets.count
Changeset.create!(:repository => @repository,
:committed_on => Time.now,
:revision => '0',
:scmid => '0885933ad4f68d77c2649cd11f8311276e7ef7ce',
:comments => 'test')
assert_equal 1, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
rev1 = @repository.changesets.find_by_revision('1')
assert_equal "9d5b5b00419901478496242e0768deba1ce8c51e", rev1.scmid
end
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 def test_fetch_changesets_incremental
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_fetch_changesets_incremental at unit model test...
r6980 assert_equal 0, @repository.changesets.count
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_fetch_changesets_incremental at unit model test...
r6980 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 # Remove changesets with revision > 2
Toshi MARUYAMA
remove unneeded Relation#all from RepositoryMercurialTest...
r12301 @repository.changesets.each {|c| c.destroy if c.revision.to_i > 2}
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_fetch_changesets_incremental at unit model test...
r6980 @project.reload
Toshi MARUYAMA
Rails4: scm: reload repository after destroying changesets in incremental fetch test...
r12197 @repository.reload
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 assert_equal 3, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: fix unit model test fails if hg command is unavailable....
r5529
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_fetch_changesets_incremental at unit model test...
r6980 @project.reload
Toshi MARUYAMA
scm: mercurial: use NUM_REV instead of hard-coded number of revisions at "test_fetch_changesets_incremental" of unit model test...
r7532 assert_equal NUM_REV, @repository.changesets.count
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 end
Toshi MARUYAMA
scm: mercurial: code clean up unit model test....
r4871
Jean-Philippe Lang
Fixes: Mercurial adapter loses seconds of commit times (#6656)....
r4447 def test_isodatesec
# Template keyword 'isodatesec' supported in Mercurial 1.0 and higher
if @repository.scm.class.client_version_above?([1, 0])
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_isodatesec at unit model test...
r6981 assert_equal 0, @repository.changesets.count
Jean-Philippe Lang
Fixes: Mercurial adapter loses seconds of commit times (#6656)....
r4447 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: mercurial: git: fix error of test_isodatesec at unit model test...
r6981 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Jean-Philippe Lang
Fixes: Mercurial adapter loses seconds of commit times (#6656)....
r4447 rev0_committed_on = Time.gm(2007, 12, 14, 9, 22, 52)
assert_equal @repository.changesets.find_by_revision('0').committed_on, rev0_committed_on
end
end
Toshi MARUYAMA
Fixed: repository: mercurial: sort changesets by revision (#3449, #3567)....
r4491
def test_changeset_order_by_revision
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_changeset_order_by_revision at unit model test...
r6995 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
Fixed: repository: mercurial: sort changesets by revision (#3449, #3567)....
r4491 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_changeset_order_by_revision at unit model test...
r6995 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
Fixed: repository: mercurial: sort changesets by revision (#3449, #3567)....
r4491
c0 = @repository.latest_changeset
c1 = @repository.changesets.find_by_revision('0')
# sorted by revision (id), not by date
assert c0.revision.to_i > c1.revision.to_i
assert c0.committed_on < c1.committed_on
end
Toshi MARUYAMA
scm: mercurial: add some tests at unit and functional test....
r4515
def test_latest_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_latest_changesets at unit model test...
r6996 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add some tests at unit and functional test....
r4515 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_latest_changesets at unit model test...
r6996 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add some tests at unit and functional test....
r4515
# with_limit
changesets = @repository.latest_changesets('', nil, 2)
Toshi MARUYAMA
scm: mercurial: add one "closed" branch to test repository (#16177)...
r12654 assert_equal ["#{NUM_REV - 1}", "#{NUM_REV - 2}"], changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: add some tests at unit and functional test....
r4515
# with_filepath
Toshi MARUYAMA
scm: mercurial: code clean up unit model test....
r4996 changesets = @repository.latest_changesets(
'/sql_escape/percent%dir/percent%file1.txt', nil)
Toshi MARUYAMA
scm: mercurial: update test repository (#5501)...
r7542 assert_equal %w|30 11 10 9|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: add some tests at unit and functional test....
r4515
Toshi MARUYAMA
scm: mercurial: code clean up unit model test....
r4996 changesets = @repository.latest_changesets(
'/sql_escape/underscore_dir/understrike_file.txt', nil)
Toshi MARUYAMA
scm: mercurial: update test repository (#5501)...
r7542 assert_equal %w|30 12 9|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: fix unit model test fails on MySQL and remove duplicates tests....
r4969
changesets = @repository.latest_changesets('README', nil)
Toshi MARUYAMA
scm: mercurial: update test repository (#5501)...
r7542 assert_equal %w|31 30 28 17 8 6 1 0|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: fix unit model test fails on MySQL and remove duplicates tests....
r4969
Toshi MARUYAMA
scm: mercurial: add latest changesets improvement test in unit model test....
r5005 changesets = @repository.latest_changesets('README','8')
assert_equal %w|8 6 1 0|, changesets.collect(&:revision)
changesets = @repository.latest_changesets('README','8', 2)
assert_equal %w|8 6|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: fix unit model test fails on MySQL and remove duplicates tests....
r4969 # with_dirpath
changesets = @repository.latest_changesets('images', nil)
assert_equal %w|1 0|, changesets.collect(&:revision)
path = 'sql_escape/percent%dir'
changesets = @repository.latest_changesets(path, nil)
Toshi MARUYAMA
scm: mercurial: update test repository (#5501)...
r7542 assert_equal %w|30 13 11 10 9|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: fix unit model test fails on MySQL and remove duplicates tests....
r4969
Toshi MARUYAMA
scm: mercurial: add latest changesets improvement test in unit model test....
r5005 changesets = @repository.latest_changesets(path, '11')
assert_equal %w|11 10 9|, changesets.collect(&:revision)
changesets = @repository.latest_changesets(path, '11', 2)
assert_equal %w|11 10|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: fix unit model test fails on MySQL and remove duplicates tests....
r4969 path = 'sql_escape/underscore_dir'
changesets = @repository.latest_changesets(path, nil)
Toshi MARUYAMA
scm: mercurial: update test repository (#5501)...
r7542 assert_equal %w|30 13 12 9|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: add latest changesets improvement test in unit model test....
r5005
changesets = @repository.latest_changesets(path, '12')
assert_equal %w|12 9|, changesets.collect(&:revision)
changesets = @repository.latest_changesets(path, '12', 1)
assert_equal %w|12|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: split latest_changesets test to tag and branch...
r12473 end
Toshi MARUYAMA
scm: mercurial: split latest_changesets tag test to sub method (#14361)...
r12491 def assert_latest_changesets_tag
changesets = @repository.latest_changesets('', 'tag_test.00')
assert_equal %w|5 4 3 2 1 0|, changesets.collect(&:revision)
end
private :assert_latest_changesets_tag
Toshi MARUYAMA
scm: mercurial: split latest_changesets test to tag and branch...
r12473 def test_latest_changesets_tag
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: split latest_changesets tag test to sub method (#14361)...
r12491 assert_latest_changesets_tag
Toshi MARUYAMA
scm: mercurial: split latest_changesets tag test with path or not (#14361)...
r12489 end
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_latest_changesets_tag_short_id
assert_equal 0, @repository.changesets.count
create_rev0_short_id
assert_equal 1, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
assert_latest_changesets_tag
end
Toshi MARUYAMA
scm: mercurial: split latest_changesets tag test with path or not (#14361)...
r12489 def test_latest_changesets_tag_with_path
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add latest changesets supporting tag test in unit model test (#1981)....
r5006
changesets = @repository.latest_changesets('sources', 'tag_test.00')
assert_equal %w|4 3 2 1 0|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: split latest_changesets tag test with limit or not (#14361)...
r12487 end
def test_latest_changesets_tag_with_limit
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
changesets = @repository.latest_changesets('', 'tag_test.00', 2)
assert_equal %w|5 4|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: remove trailing white-spaces from unit model test....
r5584
Toshi MARUYAMA
scm: mercurial: add latest changesets supporting tag test in unit model test (#1981)....
r5006 changesets = @repository.latest_changesets('sources', 'tag_test.00', 2)
assert_equal %w|4 3|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: split latest_changesets test to tag and branch...
r12473 end
def test_latest_changesets_branch
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add test of latest changesets support named branch in unit model test (#7246)....
r5008
Toshi MARUYAMA
scm: mercurial: skip failing unit model tests on below Mercurial 1.5 (#9465)...
r7523 if @repository.scm.class.client_version_above?([1, 6])
Jean-Philippe Lang
Merged rails-4.1 branch (#14534)....
r13100 changesets = @repository.latest_changesets('', BRANCH_CHAR_1)
Toshi MARUYAMA
scm: mercurial: skip failing unit model tests on below Mercurial 1.5 (#9465)...
r7523 assert_equal %w|27 26|, changesets.collect(&:revision)
end
Toshi MARUYAMA
scm: mercurial: add test of latest changesets support named branch in unit model test (#7246)....
r5008
Jean-Philippe Lang
Merged rails-4.1 branch (#14534)....
r13100 changesets = @repository.latest_changesets("latin-1-dir/test-#{CHAR_1_HEX}-subdir", BRANCH_CHAR_1)
Toshi MARUYAMA
scm: mercurial: add test of latest changesets support named branch in unit model test (#7246)....
r5008 assert_equal %w|27|, changesets.collect(&:revision)
Toshi MARUYAMA
scm: mercurial: add some tests at unit and functional test....
r4515 end
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516
Toshi MARUYAMA
scm: mercurial: split latest_changesets default branch test to sub method (#14361)...
r12490 def assert_latest_changesets_default_branch
changesets = @repository.latest_changesets('', 'default')
assert_equal %w|31 28 24 6 4 3 2 1 0|, changesets.collect(&:revision)
end
private :assert_latest_changesets_default_branch
Toshi MARUYAMA
scm: mercurial: add latest_changesets "default" branch test (#14361)...
r12488 def test_latest_changesets_default_branch
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: split latest_changesets default branch test to sub method (#14361)...
r12490 assert_latest_changesets_default_branch
Toshi MARUYAMA
scm: mercurial: add latest_changesets "default" branch test (#14361)...
r12488 end
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_latest_changesets_default_branch_short_id
assert_equal 0, @repository.changesets.count
create_rev0_short_id
assert_equal 1, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
assert_latest_changesets_default_branch
end
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497 def assert_copied_files(is_short_scmid=true)
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516 cs1 = @repository.changesets.find_by_revision('13')
Jean-Philippe Lang
Adds assertion to prevent error in test....
r4524 assert_not_nil cs1
Jean-Philippe Lang
Renamed #changes association to #filechanges (clash with AR::Base.changes that triggers errors with Rails 3.2.5)....
r9576 c1 = cs1.filechanges.sort_by(&:path)
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516 assert_equal 2, c1.size
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497 hex1 = "3a330eb329586ea2adb3f83237c23310e744ebe9"
scmid1 = scmid_for_assert(hex1, is_short_scmid)
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516 assert_equal 'A', c1[0].action
assert_equal '/sql_escape/percent%dir/percentfile1.txt', c1[0].path
assert_equal '/sql_escape/percent%dir/percent%file1.txt', c1[0].from_path
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497 assert_equal scmid1, c1[0].from_revision
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516
assert_equal 'A', c1[1].action
assert_equal '/sql_escape/underscore_dir/understrike-file.txt', c1[1].path
assert_equal '/sql_escape/underscore_dir/understrike_file.txt', c1[1].from_path
cs2 = @repository.changesets.find_by_revision('15')
Jean-Philippe Lang
Renamed #changes association to #filechanges (clash with AR::Base.changes that triggers errors with Rails 3.2.5)....
r9576 c2 = cs2.filechanges
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516 assert_equal 1, c2.size
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497 hex2 = "933ca60293d78f7c7979dd123cc0c02431683575"
scmid2 = scmid_for_assert(hex2, is_short_scmid)
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516 assert_equal 'A', c2[0].action
assert_equal '/README (1)[2]&,%.-3_4', c2[0].path
assert_equal '/README', c2[0].from_path
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497 assert_equal scmid2, c2[0].from_revision
Toshi MARUYAMA
scm: mercurial: additional unit model tests for path encoding (#2664)....
r4879
cs3 = @repository.changesets.find_by_revision('19')
Jean-Philippe Lang
Renamed #changes association to #filechanges (clash with AR::Base.changes that triggers errors with Rails 3.2.5)....
r9576 c3 = cs3.filechanges
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497
hex3 = "5d9891a1b4258ea256552aa856e388f2da28256a"
scmid3 = scmid_for_assert(hex3, is_short_scmid)
Toshi MARUYAMA
scm: mercurial: additional unit model tests for path encoding (#2664)....
r4879 assert_equal 1, c3.size
assert_equal 'A', c3[0].action
Jean-Philippe Lang
Merged rails-4.1 branch (#14534)....
r13100 assert_equal "/latin-1-dir/test-#{CHAR_1_HEX}-1.txt", c3[0].path
assert_equal "/latin-1-dir/test-#{CHAR_1_HEX}.txt", c3[0].from_path
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497 assert_equal scmid3, c3[0].from_revision
Toshi MARUYAMA
scm: mercurial: add unit test for copied file (#7064)....
r4516 end
Toshi MARUYAMA
scm: mercurial: split test_copied_files to sub method (#14361)...
r12494 private :assert_copied_files
def test_copied_files_short_id
assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 create_rev0_short_id
assert_equal 1, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: split test_copied_files to sub method (#14361)...
r12494 @repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_copied_files (#14361)...
r12497 assert_copied_files(true)
Toshi MARUYAMA
scm: mercurial: split test_copied_files to sub method (#14361)...
r12494 end
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_copied_files_long_id
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
assert_copied_files(false)
end
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534 def test_find_changeset_by_name
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_find_changeset_by_name at unit model test...
r6991 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_find_changeset_by_name at unit model test...
r6991 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534 %w|2 400bb8672109 400|.each do |r|
Toshi MARUYAMA
scm: mercurial: fix assert_equal parameter order at app unit test_find_changeset_by_name()....
r4535 assert_equal '2', @repository.find_changeset_by_name(r).revision
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534 end
end
def test_find_changeset_by_invalid_name
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_find_changeset_by_invalid_name at unit model test...
r6992 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_find_changeset_by_invalid_name at unit model test...
r6992 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: accept both of revision and nodeid as changeset id (#3724)....
r4534 assert_nil @repository.find_changeset_by_name('100000')
end
Toshi MARUYAMA
scm: mercurial: use scmid as identifier (#3724)....
r4575
def test_identifier
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_identifier at unit model test...
r6993 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use scmid as identifier (#3724)....
r4575 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_identifier at unit model test...
r6993 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use scmid as identifier (#3724)....
r4575 c = @repository.changesets.find_by_revision('2')
assert_equal c.scmid, c.identifier
end
Toshi MARUYAMA
scm: mercurial: use revision text mercurial style "2:400bb8672109" (#3724)....
r4577
def test_format_identifier
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_format_identifier at unit model test...
r6994 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use revision text mercurial style "2:400bb8672109" (#3724)....
r4577 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_format_identifier at unit model test...
r6994 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use revision text mercurial style "2:400bb8672109" (#3724)....
r4577 c = @repository.changesets.find_by_revision('2')
assert_equal '2:400bb8672109', c.format_identifier
end
Toshi MARUYAMA
scm: mercurial: use 12 chars id for format_changeset_identifier (#14361)...
r12474 def test_format_identifier_long_id
assert_equal 0, @repository.changesets.count
Changeset.create!(:repository => @repository,
:committed_on => Time.now,
:revision => '0',
:scmid => '0885933ad4f68d77c2649cd11f8311276e7ef7ce',
:comments => 'test')
c = @repository.changesets.find_by_revision('0')
assert_equal '0:0885933ad4f6', c.format_identifier
end
Toshi MARUYAMA
scm: mercurial: fix error on revision page for empty revision (#7307)....
r4584 def test_find_changeset_by_empty_name
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_find_changeset_by_empty_name at unit model test...
r6982 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: fix error on revision page for empty revision (#7307)....
r4584 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_find_changeset_by_empty_name at unit model test...
r6982 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: fix error on revision page for empty revision (#7307)....
r4584 ['', ' ', nil].each do |r|
assert_nil @repository.find_changeset_by_name(r)
end
end
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_parents (#14361)...
r12500 def assert_parents(is_short_scmid=true)
Toshi MARUYAMA
scm: mercurial: test: model: add test of parents (#5501)...
r7594 r1 = @repository.changesets.find_by_revision('0')
assert_equal [], r1.parents
r2 = @repository.changesets.find_by_revision('1')
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_parents (#14361)...
r12500 hex2 = "0885933ad4f68d77c2649cd11f8311276e7ef7ce"
scmid2 = scmid_for_assert(hex2, is_short_scmid)
Toshi MARUYAMA
scm: mercurial: test: model: add test of parents (#5501)...
r7594 assert_equal 1, r2.parents.length
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_parents (#14361)...
r12500 assert_equal scmid2, r2.parents[0].identifier
Toshi MARUYAMA
scm: mercurial: test: model: add test of parents (#5501)...
r7594 r3 = @repository.changesets.find_by_revision('30')
assert_equal 2, r3.parents.length
Toshi MARUYAMA
scm: mercurial: test: model: fix failing test_parents on PostgreSQL (#5501)...
r7599 r4 = [r3.parents[0].identifier, r3.parents[1].identifier].sort
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_parents (#14361)...
r12500 hex41 = "3a330eb329586ea2adb3f83237c23310e744ebe9"
scmid41 = scmid_for_assert(hex41, is_short_scmid)
hex42 = "a94b0528f24fe05ebaef496ae0500bb050772e36"
scmid42 = scmid_for_assert(hex42, is_short_scmid)
assert_equal scmid41, r4[0]
assert_equal scmid42, r4[1]
Toshi MARUYAMA
scm: mercurial: test: model: add test of parents (#5501)...
r7594 end
Toshi MARUYAMA
scm: mercurial: split test_parents to sub method (#14361)...
r12495 private :assert_parents
def test_parents_short_id
assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 create_rev0_short_id
assert_equal 1, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: split test_parents to sub method (#14361)...
r12495 @repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: use scmid_for_assert in assert_parents (#14361)...
r12500 assert_parents(true)
Toshi MARUYAMA
scm: mercurial: split test_parents to sub method (#14361)...
r12495 end
Toshi MARUYAMA
scm: mercurial: test: model: add test of parents (#5501)...
r7594
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_parents_long_id
assert_equal 0, @repository.changesets.count
@repository.fetch_changesets
@project.reload
assert_equal NUM_REV, @repository.changesets.count
assert_parents(false)
end
Toshi MARUYAMA
scm: mercurial: use revision text mercurial style "2:400bb8672109" (#3724)....
r4577 def test_activities
c = Changeset.new(:repository => @repository,
:committed_on => Time.now,
:revision => '123',
:scmid => 'abc400bb8672',
:comments => 'test')
assert c.event_title.include?('123:abc400bb8672:')
assert_equal 'abc400bb8672', c.event_url[:rev]
end
Toshi MARUYAMA
scm: mercurial: unit app test for latest_changeset....
r4749
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 def test_previous
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_previous at unit model test...
r6983 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_previous at unit model test...
r6983 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add latin-1 encoding directory to test repository (#2664)....
r4939 %w|28 3ae45e2d177d 3ae45|.each do |r1|
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 changeset = @repository.find_changeset_by_name(r1)
Toshi MARUYAMA
scm: mercurial: add latin-1 encoding directory to test repository (#2664)....
r4939 %w|27 7bbf4c738e71 7bbf|.each do |r2|
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 assert_equal @repository.find_changeset_by_name(r2), changeset.previous
end
end
end
def test_previous_nil
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_previous_nil at unit model test...
r6984 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_previous_nil at unit model test...
r6984 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 %w|0 0885933ad4f6 0885|.each do |r1|
changeset = @repository.find_changeset_by_name(r1)
assert_nil changeset.previous
end
end
def test_next
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_next at unit model test...
r6985 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_next at unit model test...
r6985 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add latin-1 encoding directory to test repository (#2664)....
r4939 %w|27 7bbf4c738e71 7bbf|.each do |r2|
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 changeset = @repository.find_changeset_by_name(r2)
Toshi MARUYAMA
scm: mercurial: add latin-1 encoding directory to test repository (#2664)....
r4939 %w|28 3ae45e2d177d 3ae45|.each do |r1|
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 assert_equal @repository.find_changeset_by_name(r1), changeset.next
end
end
end
def test_next_nil
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_next_nil at unit model test...
r6986 assert_equal 0, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 @repository.fetch_changesets
Toshi MARUYAMA
Rails3: scm: mercurial: fix error of test_next_nil at unit model test...
r6986 @project.reload
assert_equal NUM_REV, @repository.changesets.count
Toshi MARUYAMA
scm: mercurial: add one "closed" branch to test repository (#16177)...
r12654 ["#{NUM_REV - 1}", "2e6d54642923", "2e6d5"].each do |r1|
Toshi MARUYAMA
scm: mercurial: add changesets order test in unit model test (#5357)....
r4882 changeset = @repository.find_changeset_by_name(r1)
assert_nil changeset.next
end
end
Toshi MARUYAMA
scm: mercurial: add test helper method to switch short or long id (#14361)...
r12496
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502 def test_scmid_for_inserting_db_short_id
assert_equal 0, @repository.changesets.count
create_rev0_short_id
assert_equal 1, @repository.changesets.count
rev = "0123456789012345678901234567890123456789"
assert_equal 12, @repository.scmid_for_inserting_db(rev).length
end
def test_scmid_for_inserting_db_long_id
rev = "0123456789012345678901234567890123456789"
assert_equal 0, @repository.changesets.count
assert_equal 40, @repository.scmid_for_inserting_db(rev).length
Changeset.create!(:repository => @repository,
:committed_on => Time.now,
:revision => '0',
:scmid => rev,
:comments => 'test')
assert_equal 1, @repository.changesets.count
assert_equal 40, @repository.scmid_for_inserting_db(rev).length
end
Toshi MARUYAMA
scm: mercurial: add test helper method to switch short or long id (#14361)...
r12496 def test_scmid_for_assert
rev = "0123456789012345678901234567890123456789"
assert_equal rev, scmid_for_assert(rev, false)
assert_equal "012345678901", scmid_for_assert(rev, true)
end
private
def scmid_for_assert(hex, is_short=true)
is_short ? hex[0, 12] : hex
end
Toshi MARUYAMA
scm: mercurial: insert long id to DB unless existing id in DB is not short id (#14361)...
r12502
def create_rev0_short_id
Changeset.create!(:repository => @repository,
:committed_on => Time.now,
:revision => '0',
:scmid => '0885933ad4f6',
:comments => 'test')
end
Jean-Philippe Lang
Added a Mercurial test repository with unit and functional tests....
r978 else
puts "Mercurial test repository NOT FOUND. Skipping unit tests !!!"
def test_fake; assert true end
end
end