From 2ae2d3ef834c4d17b1c7a4e09f299b537f91d3cc Mon Sep 17 00:00:00 2001 From: Toshi MARUYAMA Date: Sun, 2 Jan 2011 06:05:54 +0000 Subject: [PATCH] Fixed: repository: mercurial: sort changesets by revision (#3449, #3567). In DVCS, changesets are not in date order. Because Mercurial backend inserts changesets from eariest, 'ORDER BY id' means 'order by revision number'. Contributed by Yuya Nishihara. git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4611 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/models/repository/mercurial.rb | 15 +++++++++++++++ .../repositories/mercurial_repository.tar.gz | Bin 7827 -> 8058 bytes test/unit/repository_mercurial_test.rb | 11 +++++++++++ 3 files changed, 26 insertions(+) diff --git a/app/models/repository/mercurial.rb b/app/models/repository/mercurial.rb index 107223956..9ce3b63eb 100644 --- a/app/models/repository/mercurial.rb +++ b/app/models/repository/mercurial.rb @@ -18,6 +18,9 @@ require 'redmine/scm/adapters/mercurial_adapter' class Repository::Mercurial < Repository + # sort changesets by revision number + has_many :changesets, :order => "#{Changeset.table_name}.id DESC", :foreign_key => 'repository_id' + attr_protected :root_url validates_presence_of :url @@ -52,6 +55,18 @@ class Repository::Mercurial < Repository entries end + # Returns the latest changesets for +path+; sorted by revision number + def latest_changesets(path, rev, limit=10) + if path.blank? + changesets.find(:all, :include => :user, :limit => limit) + else + changes.find(:all, :include => {:changeset => :user}, + :conditions => ["path = ?", path.with_leading_slash], + :order => "#{Changeset.table_name}.id DESC", + :limit => limit).collect(&:changeset) + end + end + def fetch_changesets scm_info = scm.info if scm_info diff --git a/test/fixtures/repositories/mercurial_repository.tar.gz b/test/fixtures/repositories/mercurial_repository.tar.gz index 1d8ad305732f7a0d7bfbcd52bbeec919da88e3f1..c2a1b58745c8fdf994e7ab43b11919e79a639be4 100644 GIT binary patch literal 8058 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 I@&KR!02pZfuK)l5 literal 7827 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 diff --git a/test/unit/repository_mercurial_test.rb b/test/unit/repository_mercurial_test.rb index 16e72c35d..17b72cf67 100644 --- a/test/unit/repository_mercurial_test.rb +++ b/test/unit/repository_mercurial_test.rb @@ -76,6 +76,17 @@ class RepositoryMercurialTest < ActiveSupport::TestCase assert_equal @repository.changesets.find_by_revision('0').committed_on, rev0_committed_on end end + + def test_changeset_order_by_revision + @repository.fetch_changesets + @repository.reload + + 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 else puts "Mercurial test repository NOT FOUND. Skipping unit tests !!!" def test_fake; assert true end