summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorTiago Botelho <tiagonbotelho@hotmail.com>2018-02-19 14:42:00 +0000
committerTiago Botelho <tiagonbotelho@hotmail.com>2018-03-01 14:38:35 +0000
commitcd9daf644e2b3844b9382768a3add335f942b76c (patch)
treed0ddb0cdbf494c8fbb32133b4f46adf50178ea9b /lib
parent442a6e880058138b6ae6843d9b70d62cbc5aadb0 (diff)
downloadgitlab-ce-cd9daf644e2b3844b9382768a3add335f942b76c.tar.gz
Diffstat (limited to 'lib')
-rw-r--r--lib/api/commits.rb2
-rw-r--r--lib/gitlab/git/repository.rb25
2 files changed, 16 insertions, 11 deletions
diff --git a/lib/api/commits.rb b/lib/api/commits.rb
index c4a180d3b0e..982f45425a3 100644
--- a/lib/api/commits.rb
+++ b/lib/api/commits.rb
@@ -38,7 +38,7 @@ module API
all: all)
commit_count =
- if path || before || after
+ if all || path || before || after
user_project.repository.count_commits(ref: ref, path: path, before: before, after: after, all: all)
else
# Cacheable commit count.
diff --git a/lib/gitlab/git/repository.rb b/lib/gitlab/git/repository.rb
index e51cdac4a04..0d749b7f5c6 100644
--- a/lib/gitlab/git/repository.rb
+++ b/lib/gitlab/git/repository.rb
@@ -467,7 +467,8 @@ module Gitlab
follow: false,
skip_merges: false,
after: nil,
- before: nil
+ before: nil,
+ all: false
}
options = default_options.merge(options)
@@ -478,8 +479,9 @@ module Gitlab
raise ArgumentError.new("invalid Repository#log limit: #{limit.inspect}")
end
+ # TODO support options[:all] in Gitaly https://gitlab.com/gitlab-org/gitaly/issues/1049
gitaly_migrate(:find_commits) do |is_enabled|
- if is_enabled
+ if is_enabled && !options[:all]
gitaly_commit_client.find_commits(options)
else
raw_log(options).map { |c| Commit.decorate(self, c) }
@@ -506,8 +508,9 @@ module Gitlab
def count_commits(options)
count_commits_options = process_count_commits_options(options)
+ # TODO add support for options[:all] in Gitaly https://gitlab.com/gitlab-org/gitaly/issues/1050
gitaly_migrate(:count_commits) do |is_enabled|
- if is_enabled
+ if is_enabled && !options[:all]
count_commits_by_gitaly(count_commits_options)
else
count_commits_by_shelling_out(count_commits_options)
@@ -1707,7 +1710,7 @@ module Gitlab
if options[:all]
cmd += %w[--all --reverse]
- elsif sha
+ else
cmd << sha
end
@@ -1926,15 +1929,17 @@ module Gitlab
cmd << "--before=#{options[:before].iso8601}" if options[:before]
cmd << "--max-count=#{options[:max_count]}" if options[:max_count]
cmd << "--left-right" if options[:left_right]
+ cmd << '--count'
- if options[:all]
- cmd += %w[--count --all]
- elsif options[:ref].present?
- cmd += %W[--count #{options[:ref]}]
- end
+ cmd << if options[:all]
+ '--all'
+ elsif options[:ref]
+ options[:ref]
+ else
+ raise ArgumentError, "Please specify a valid ref or set the 'all' attribute to true"
+ end
cmd += %W[-- #{options[:path]}] if options[:path].present?
-
cmd
end