Commit 9bb098a9 authored by Nick Thomas's avatar Nick Thomas

Merge branch 'fj-replace-project-with-repositorable' into 'master'

Replacing project references with container name in repository classes

See merge request gitlab-org/gitlab!23678
parents d7a0a552 13b396b3
...@@ -65,7 +65,10 @@ class Blob < SimpleDelegator ...@@ -65,7 +65,10 @@ class Blob < SimpleDelegator
BlobViewer::YarnLock BlobViewer::YarnLock
].freeze ].freeze
attr_reader :project attr_reader :container
delegate :repository, to: :container, allow_nil: true
delegate :project, to: :repository, allow_nil: true
# Wrap a Gitlab::Git::Blob object, or return nil when given nil # Wrap a Gitlab::Git::Blob object, or return nil when given nil
# #
...@@ -77,22 +80,22 @@ class Blob < SimpleDelegator ...@@ -77,22 +80,22 @@ class Blob < SimpleDelegator
# #
# blob = Blob.decorate(nil) # blob = Blob.decorate(nil)
# puts "truthy" if blob # No output # puts "truthy" if blob # No output
def self.decorate(blob, project = nil) def self.decorate(blob, container = nil)
return if blob.nil? return if blob.nil?
new(blob, project) new(blob, container)
end end
def self.lazy(project, commit_id, path, blob_size_limit: Gitlab::Git::Blob::MAX_DATA_DISPLAY_SIZE) def self.lazy(container, commit_id, path, blob_size_limit: Gitlab::Git::Blob::MAX_DATA_DISPLAY_SIZE)
BatchLoader.for([commit_id, path]).batch(key: project.repository) do |items, loader, args| BatchLoader.for([commit_id, path]).batch(key: container.repository) do |items, loader, args|
args[:key].blobs_at(items, blob_size_limit: blob_size_limit).each do |blob| args[:key].blobs_at(items, blob_size_limit: blob_size_limit).each do |blob|
loader.call([blob.commit_id, blob.path], blob) if blob loader.call([blob.commit_id, blob.path], blob) if blob
end end
end end
end end
def initialize(blob, project = nil) def initialize(blob, container = nil)
@project = project @container = container
super(blob) super(blob)
end end
...@@ -116,7 +119,7 @@ class Blob < SimpleDelegator ...@@ -116,7 +119,7 @@ class Blob < SimpleDelegator
def load_all_data! def load_all_data!
# Endpoint needed: https://gitlab.com/gitlab-org/gitaly/issues/756 # Endpoint needed: https://gitlab.com/gitlab-org/gitaly/issues/756
Gitlab::GitalyClient.allow_n_plus_1_calls do Gitlab::GitalyClient.allow_n_plus_1_calls do
super(project.repository) if project super(repository) if container
end end
end end
......
...@@ -21,11 +21,14 @@ class Commit ...@@ -21,11 +21,14 @@ class Commit
participant :committer participant :committer
participant :notes_with_associations participant :notes_with_associations
attr_accessor :project, :author attr_accessor :author
attr_accessor :redacted_description_html attr_accessor :redacted_description_html
attr_accessor :redacted_title_html attr_accessor :redacted_title_html
attr_accessor :redacted_full_title_html attr_accessor :redacted_full_title_html
attr_reader :gpg_commit attr_reader :gpg_commit, :container
delegate :repository, to: :container
delegate :project, to: :repository, allow_nil: true
DIFF_SAFE_LINES = Gitlab::Git::DiffCollection::DEFAULT_LIMITS[:max_lines] DIFF_SAFE_LINES = Gitlab::Git::DiffCollection::DEFAULT_LIMITS[:max_lines]
...@@ -44,12 +47,12 @@ class Commit ...@@ -44,12 +47,12 @@ class Commit
cache_markdown_field :description, pipeline: :commit_description cache_markdown_field :description, pipeline: :commit_description
class << self class << self
def decorate(commits, project) def decorate(commits, container)
commits.map do |commit| commits.map do |commit|
if commit.is_a?(Commit) if commit.is_a?(Commit)
commit commit
else else
self.new(commit, project) self.new(commit, container)
end end
end end
end end
...@@ -85,24 +88,24 @@ class Commit ...@@ -85,24 +88,24 @@ class Commit
} }
end end
def from_hash(hash, project) def from_hash(hash, container)
raw_commit = Gitlab::Git::Commit.new(project.repository.raw, hash) raw_commit = Gitlab::Git::Commit.new(container.repository.raw, hash)
new(raw_commit, project) new(raw_commit, container)
end end
def valid_hash?(key) def valid_hash?(key)
!!(EXACT_COMMIT_SHA_PATTERN =~ key) !!(EXACT_COMMIT_SHA_PATTERN =~ key)
end end
def lazy(project, oid) def lazy(container, oid)
BatchLoader.for({ project: project, oid: oid }).batch(replace_methods: false) do |items, loader| BatchLoader.for({ container: container, oid: oid }).batch(replace_methods: false) do |items, loader|
items_by_project = items.group_by { |i| i[:project] } items_by_container = items.group_by { |i| i[:container] }
items_by_project.each do |project, commit_ids| items_by_container.each do |container, commit_ids|
oids = commit_ids.map { |i| i[:oid] } oids = commit_ids.map { |i| i[:oid] }
project.repository.commits_by(oids: oids).each do |commit| container.repository.commits_by(oids: oids).each do |commit|
loader.call({ project: commit.project, oid: commit.id }, commit) if commit loader.call({ container: commit.container, oid: commit.id }, commit) if commit
end end
end end
end end
...@@ -115,12 +118,12 @@ class Commit ...@@ -115,12 +118,12 @@ class Commit
attr_accessor :raw attr_accessor :raw
def initialize(raw_commit, project) def initialize(raw_commit, container)
raise "Nil as raw commit passed" unless raw_commit raise "Nil as raw commit passed" unless raw_commit
@raw = raw_commit @raw = raw_commit
@project = project @container = container
@gpg_commit = Gitlab::Gpg::Commit.new(self) if project @gpg_commit = Gitlab::Gpg::Commit.new(self) if container
end end
delegate \ delegate \
...@@ -141,7 +144,7 @@ class Commit ...@@ -141,7 +144,7 @@ class Commit
end end
def project_id def project_id
project.id project&.id
end end
def ==(other) def ==(other)
...@@ -269,17 +272,17 @@ class Commit ...@@ -269,17 +272,17 @@ class Commit
end end
def parents def parents
@parents ||= parent_ids.map { |oid| Commit.lazy(project, oid) } @parents ||= parent_ids.map { |oid| Commit.lazy(container, oid) }
end end
def parent def parent
strong_memoize(:parent) do strong_memoize(:parent) do
project.commit_by(oid: self.parent_id) if self.parent_id container.commit_by(oid: self.parent_id) if self.parent_id
end end
end end
def notes def notes
project.notes.for_commit_id(self.id) container.notes.for_commit_id(self.id)
end end
def user_mentions def user_mentions
...@@ -295,7 +298,7 @@ class Commit ...@@ -295,7 +298,7 @@ class Commit
end end
def merge_requests def merge_requests
@merge_requests ||= project.merge_requests.by_commit_sha(sha) @merge_requests ||= project&.merge_requests&.by_commit_sha(sha)
end end
def method_missing(method, *args, &block) def method_missing(method, *args, &block)
...@@ -330,7 +333,7 @@ class Commit ...@@ -330,7 +333,7 @@ class Commit
end end
def cherry_pick_branch_name def cherry_pick_branch_name
project.repository.next_branch("cherry-pick-#{short_id}", mild: true) repository.next_branch("cherry-pick-#{short_id}", mild: true)
end end
def cherry_pick_description(user) def cherry_pick_description(user)
...@@ -418,7 +421,7 @@ class Commit ...@@ -418,7 +421,7 @@ class Commit
return unless entry return unless entry
if entry[:type] == :blob if entry[:type] == :blob
blob = ::Blob.decorate(Gitlab::Git::Blob.new(name: entry[:name]), @project) blob = ::Blob.decorate(Gitlab::Git::Blob.new(name: entry[:name]), container)
blob.image? || blob.video? || blob.audio? ? :raw : :blob blob.image? || blob.video? || blob.audio? ? :raw : :blob
else else
entry[:type] entry[:type]
...@@ -484,7 +487,7 @@ class Commit ...@@ -484,7 +487,7 @@ class Commit
end end
def commit_reference(from, referable_commit_id, full: false) def commit_reference(from, referable_commit_id, full: false)
base = project.to_reference_base(from, full: full) base = project&.to_reference_base(from, full: full)
if base.present? if base.present?
"#{base}#{self.class.reference_prefix}#{referable_commit_id}" "#{base}#{self.class.reference_prefix}#{referable_commit_id}"
...@@ -510,6 +513,6 @@ class Commit ...@@ -510,6 +513,6 @@ class Commit
end end
def merged_merge_request_no_cache(user) def merged_merge_request_no_cache(user)
MergeRequestsFinder.new(user, project_id: project.id).find_by(merge_commit_sha: id) if merge_commit? MergeRequestsFinder.new(user, project_id: project_id).find_by(merge_commit_sha: id) if merge_commit?
end end
end end
# frozen_string_literal: true # frozen_string_literal: true
# A collection of Commit instances for a specific project and Git reference. # A collection of Commit instances for a specific container and Git reference.
class CommitCollection class CommitCollection
include Enumerable include Enumerable
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
attr_reader :project, :ref, :commits attr_reader :container, :ref, :commits
# project - The project the commits belong to. delegate :repository, to: :container, allow_nil: true
delegate :project, to: :repository, allow_nil: true
# container - The object the commits belong to.
# commits - The Commit instances to store. # commits - The Commit instances to store.
# ref - The name of the ref (e.g. "master"). # ref - The name of the ref (e.g. "master").
def initialize(project, commits, ref = nil) def initialize(container, commits, ref = nil)
@project = project @container = container
@commits = commits @commits = commits
@ref = ref @ref = ref
end end
...@@ -39,6 +42,8 @@ class CommitCollection ...@@ -39,6 +42,8 @@ class CommitCollection
# Setting the pipeline for each commit ahead of time removes the need for running # Setting the pipeline for each commit ahead of time removes the need for running
# a query for every commit we're displaying. # a query for every commit we're displaying.
def with_latest_pipeline(ref = nil) def with_latest_pipeline(ref = nil)
return self unless project
pipelines = project.ci_pipelines.latest_pipeline_per_commit(map(&:id), ref) pipelines = project.ci_pipelines.latest_pipeline_per_commit(map(&:id), ref)
each do |commit| each do |commit|
...@@ -59,16 +64,16 @@ class CommitCollection ...@@ -59,16 +64,16 @@ class CommitCollection
# Batch load any commits that are not backed by full gitaly data, and # Batch load any commits that are not backed by full gitaly data, and
# replace them in the collection. # replace them in the collection.
def enrich! def enrich!
# A project is needed in order to fetch data from gitaly. Projects # A container is needed in order to fetch data from gitaly. Containers
# can be absent from commits in certain rare situations (like when # can be absent from commits in certain rare situations (like when
# viewing a MR of a deleted fork). In these cases, assume that the # viewing a MR of a deleted fork). In these cases, assume that the
# enriched data is not needed. # enriched data is not needed.
return self if project.blank? || fully_enriched? return self if container.blank? || fully_enriched?
# Batch load full Commits from the repository # Batch load full Commits from the repository
# and map to a Hash of id => Commit # and map to a Hash of id => Commit
replacements = Hash[unenriched.map do |c| replacements = Hash[unenriched.map do |c|
[c.id, Commit.lazy(project, c.id)] [c.id, Commit.lazy(container, c.id)]
end.compact] end.compact]
# Replace the commits, keeping the same order # Replace the commits, keeping the same order
......
# frozen_string_literal: true
module HasRepository
extend ActiveSupport::Concern
include Gitlab::ShellAdapter
include AfterCommitQueue
include Gitlab::Utils::StrongMemoize
delegate :base_dir, :disk_path, to: :storage
def valid_repo?
repository.exists?
rescue
errors.add(:path, _('Invalid repository path'))
false
end
def repo_exists?
strong_memoize(:repo_exists) do
repository.exists?
rescue
false
end
end
def repository_exists?
!!repository.exists?
end
def root_ref?(branch)
repository.root_ref == branch
end
def commit(ref = 'HEAD')
repository.commit(ref)
end
def commit_by(oid:)
repository.commit_by(oid: oid)
end
def commits_by(oids:)
repository.commits_by(oids: oids)
end
def repository
raise NotImplementedError
end
def storage
raise NotImplementedError
end
def full_path
raise NotImplementedError
end
def empty_repo?
repository.empty?
end
def default_branch
@default_branch ||= repository.root_ref
end
def reload_default_branch
@default_branch = nil # rubocop:disable Gitlab/ModuleWithInstanceVariables
default_branch
end
def url_to_repo
gitlab_shell.url_to_repo(full_path)
end
def ssh_url_to_repo
url_to_repo
end
def http_url_to_repo
custom_root = Gitlab::CurrentSettings.custom_http_clone_url_root
url = if custom_root.present?
Gitlab::Utils.append_path(
custom_root,
web_url(only_path: true)
)
else
web_url
end
"#{url}.git"
end
def web_url(only_path: nil)
raise NotImplementedError
end
end
...@@ -19,6 +19,7 @@ class Project < ApplicationRecord ...@@ -19,6 +19,7 @@ class Project < ApplicationRecord
include ProjectFeaturesCompatibility include ProjectFeaturesCompatibility
include SelectForProjectAuthorization include SelectForProjectAuthorization
include Presentable include Presentable
include HasRepository
include Routable include Routable
include GroupDescendant include GroupDescendant
include Gitlab::SQL::Pattern include Gitlab::SQL::Pattern
...@@ -326,7 +327,6 @@ class Project < ApplicationRecord ...@@ -326,7 +327,6 @@ class Project < ApplicationRecord
to: :project_feature, allow_nil: true to: :project_feature, allow_nil: true
delegate :scheduled?, :started?, :in_progress?, :failed?, :finished?, delegate :scheduled?, :started?, :in_progress?, :failed?, :finished?,
prefix: :import, to: :import_state, allow_nil: true prefix: :import, to: :import_state, allow_nil: true
delegate :base_dir, :disk_path, to: :storage
delegate :no_import?, to: :import_state, allow_nil: true delegate :no_import?, to: :import_state, allow_nil: true
delegate :name, to: :owner, allow_nil: true, prefix: true delegate :name, to: :owner, allow_nil: true, prefix: true
delegate :members, to: :team, prefix: true delegate :members, to: :team, prefix: true
...@@ -767,10 +767,6 @@ class Project < ApplicationRecord ...@@ -767,10 +767,6 @@ class Project < ApplicationRecord
Feature.enabled?(:context_commits, default_enabled: true) Feature.enabled?(:context_commits, default_enabled: true)
end end
def empty_repo?
repository.empty?
end
def team def team
@team ||= ProjectTeam.new(self) @team ||= ProjectTeam.new(self)
end end
...@@ -798,18 +794,6 @@ class Project < ApplicationRecord ...@@ -798,18 +794,6 @@ class Project < ApplicationRecord
has_root_container_repository_tags? has_root_container_repository_tags?
end end
def commit(ref = 'HEAD')
repository.commit(ref)
end
def commit_by(oid:)
repository.commit_by(oid: oid)
end
def commits_by(oids:)
repository.commits_by(oids: oids)
end
# ref can't be HEAD, can only be branch/tag name # ref can't be HEAD, can only be branch/tag name
def latest_successful_build_for_ref(job_name, ref = default_branch) def latest_successful_build_for_ref(job_name, ref = default_branch)
return unless ref return unless ref
...@@ -1357,48 +1341,6 @@ class Project < ApplicationRecord ...@@ -1357,48 +1341,6 @@ class Project < ApplicationRecord
services.public_send(hooks_scope).any? # rubocop:disable GitlabSecurity/PublicSend services.public_send(hooks_scope).any? # rubocop:disable GitlabSecurity/PublicSend
end end
def valid_repo?
repository.exists?
rescue
errors.add(:path, _('Invalid repository path'))
false
end
def url_to_repo
gitlab_shell.url_to_repo(full_path)
end
def repo_exists?
strong_memoize(:repo_exists) do
repository.exists?
rescue
false
end
end
def root_ref?(branch)
repository.root_ref == branch
end
def ssh_url_to_repo
url_to_repo
end
def http_url_to_repo
custom_root = Gitlab::CurrentSettings.custom_http_clone_url_root
project_url = if custom_root.present?
Gitlab::Utils.append_path(
custom_root,
web_url(only_path: true)
)
else
web_url
end
"#{project_url}.git"
end
# Is overridden in EE # Is overridden in EE
def lfs_http_url_to_repo(_) def lfs_http_url_to_repo(_)
http_url_to_repo http_url_to_repo
...@@ -1538,15 +1480,6 @@ class Project < ApplicationRecord ...@@ -1538,15 +1480,6 @@ class Project < ApplicationRecord
end end
end end
def default_branch
@default_branch ||= repository.root_ref
end
def reload_default_branch
@default_branch = nil
default_branch
end
def visibility_level_field def visibility_level_field
:visibility_level :visibility_level
end end
...@@ -1583,10 +1516,6 @@ class Project < ApplicationRecord ...@@ -1583,10 +1516,6 @@ class Project < ApplicationRecord
create_repository(force: true) unless repository_exists? create_repository(force: true) unless repository_exists?
end end
def repository_exists?
!!repository.exists?
end
def wiki_repository_exists? def wiki_repository_exists?
wiki.repository_exists? wiki.repository_exists?
end end
......
...@@ -22,7 +22,7 @@ class Repository ...@@ -22,7 +22,7 @@ class Repository
include Gitlab::RepositoryCacheAdapter include Gitlab::RepositoryCacheAdapter
attr_accessor :full_path, :disk_path, :project, :repo_type attr_accessor :full_path, :disk_path, :container, :repo_type
delegate :ref_name_for_sha, to: :raw_repository delegate :ref_name_for_sha, to: :raw_repository
delegate :bundle_to_disk, to: :raw_repository delegate :bundle_to_disk, to: :raw_repository
...@@ -67,10 +67,10 @@ class Repository ...@@ -67,10 +67,10 @@ class Repository
MERGED_BRANCH_NAMES_CACHE_DURATION = 10.minutes MERGED_BRANCH_NAMES_CACHE_DURATION = 10.minutes
def initialize(full_path, project, disk_path: nil, repo_type: Gitlab::GlRepository::PROJECT) def initialize(full_path, container, disk_path: nil, repo_type: Gitlab::GlRepository::PROJECT)
@full_path = full_path @full_path = full_path
@disk_path = disk_path || full_path @disk_path = disk_path || full_path
@project = project @container = container
@commit_cache = {} @commit_cache = {}
@repo_type = repo_type @repo_type = repo_type
end end
...@@ -97,7 +97,7 @@ class Repository ...@@ -97,7 +97,7 @@ class Repository
def path_to_repo def path_to_repo
@path_to_repo ||= @path_to_repo ||=
begin begin
storage = Gitlab.config.repositories.storages[project.repository_storage] storage = Gitlab.config.repositories.storages[container.repository_storage]
File.expand_path( File.expand_path(
File.join(storage.legacy_disk_path, disk_path + '.git') File.join(storage.legacy_disk_path, disk_path + '.git')
...@@ -130,7 +130,7 @@ class Repository ...@@ -130,7 +130,7 @@ class Repository
commits = Gitlab::Git::Commit.batch_by_oid(raw_repository, oids) commits = Gitlab::Git::Commit.batch_by_oid(raw_repository, oids)
if commits.present? if commits.present?
Commit.decorate(commits, project) Commit.decorate(commits, container)
else else
[] []
end end
...@@ -161,14 +161,14 @@ class Repository ...@@ -161,14 +161,14 @@ class Repository
} }
commits = Gitlab::Git::Commit.where(options) commits = Gitlab::Git::Commit.where(options)
commits = Commit.decorate(commits, project) if commits.present? commits = Commit.decorate(commits, container) if commits.present?
CommitCollection.new(project, commits, ref) CommitCollection.new(container, commits, ref)
end end
def commits_between(from, to) def commits_between(from, to)
commits = Gitlab::Git::Commit.between(raw_repository, from, to) commits = Gitlab::Git::Commit.between(raw_repository, from, to)
commits = Commit.decorate(commits, project) if commits.present? commits = Commit.decorate(commits, container) if commits.present?
commits commits
end end
...@@ -176,7 +176,7 @@ class Repository ...@@ -176,7 +176,7 @@ class Repository
def new_commits(newrev) def new_commits(newrev)
commits = raw.new_commits(newrev) commits = raw.new_commits(newrev)
::Commit.decorate(commits, project) ::Commit.decorate(commits, container)
end end
# Gitaly migration: https://gitlab.com/gitlab-org/gitaly/issues/384 # Gitaly migration: https://gitlab.com/gitlab-org/gitaly/issues/384
...@@ -188,7 +188,7 @@ class Repository ...@@ -188,7 +188,7 @@ class Repository
commits = raw_repository.find_commits_by_message(query, ref, path, limit, offset).map do |c| commits = raw_repository.find_commits_by_message(query, ref, path, limit, offset).map do |c|
commit(c) commit(c)
end end
CommitCollection.new(project, commits, ref) CommitCollection.new(container, commits, ref)
end end
def find_branch(name) def find_branch(name)
...@@ -281,7 +281,7 @@ class Repository ...@@ -281,7 +281,7 @@ class Repository
raw_repository.archive_metadata( raw_repository.archive_metadata(
ref, ref,
storage_path, storage_path,
project.path, project&.path,
format, format,
append_sha: append_sha, append_sha: append_sha,
path: path path: path
...@@ -499,7 +499,7 @@ class Repository ...@@ -499,7 +499,7 @@ class Repository
end end
def blob_at(sha, path) def blob_at(sha, path)
blob = Blob.decorate(raw_repository.blob_at(sha, path), project) blob = Blob.decorate(raw_repository.blob_at(sha, path), container)
# Don't attempt to return a special result if there is no blob at all # Don't attempt to return a special result if there is no blob at all
return unless blob return unless blob
...@@ -522,7 +522,7 @@ class Repository ...@@ -522,7 +522,7 @@ class Repository
return [] unless exists? return [] unless exists?
raw_repository.batch_blobs(items, blob_size_limit: blob_size_limit).map do |blob| raw_repository.batch_blobs(items, blob_size_limit: blob_size_limit).map do |blob|
Blob.decorate(blob, project) Blob.decorate(blob, container)
end end
end end
...@@ -701,13 +701,13 @@ class Repository ...@@ -701,13 +701,13 @@ class Repository
commits = raw_repository.list_last_commits_for_tree(sha, path, offset: offset, limit: limit) commits = raw_repository.list_last_commits_for_tree(sha, path, offset: offset, limit: limit)
commits.each do |path, commit| commits.each do |path, commit|
commits[path] = ::Commit.new(commit, project) commits[path] = ::Commit.new(commit, container)
end end
end end
def last_commit_for_path(sha, path) def last_commit_for_path(sha, path)
commit = raw_repository.last_commit_for_path(sha, path) commit = raw_repository.last_commit_for_path(sha, path)
::Commit.new(commit, project) if commit ::Commit.new(commit, container) if commit
end end
def last_commit_id_for_path(sha, path) def last_commit_id_for_path(sha, path)
...@@ -986,6 +986,7 @@ class Repository ...@@ -986,6 +986,7 @@ class Repository
# rubocop:disable Gitlab/RailsLogger # rubocop:disable Gitlab/RailsLogger
def async_remove_remote(remote_name) def async_remove_remote(remote_name)
return unless remote_name return unless remote_name
return unless project
job_id = RepositoryRemoveRemoteWorker.perform_async(project.id, remote_name) job_id = RepositoryRemoveRemoteWorker.perform_async(project.id, remote_name)
...@@ -1157,6 +1158,10 @@ class Repository ...@@ -1157,6 +1158,10 @@ class Repository
Gitlab::Git::Blob.batch_metadata(raw, references).map { |raw_blob| Blob.decorate(raw_blob) } Gitlab::Git::Blob.batch_metadata(raw, references).map { |raw_blob| Blob.decorate(raw_blob) }
end end
def project
container
end
private private
# TODO Genericize finder, later split this on finders by Ref or Oid # TODO Genericize finder, later split this on finders by Ref or Oid
...@@ -1203,10 +1208,10 @@ class Repository ...@@ -1203,10 +1208,10 @@ class Repository
end end
def initialize_raw_repository def initialize_raw_repository
Gitlab::Git::Repository.new(project.repository_storage, Gitlab::Git::Repository.new(container.repository_storage,
disk_path + '.git', disk_path + '.git',
repo_type.identifier_for_container(project), repo_type.identifier_for_container(container),
project.full_path) container.full_path)
end end
end end
......
...@@ -8,7 +8,7 @@ module Gitlab ...@@ -8,7 +8,7 @@ module Gitlab
def initialize(commit) def initialize(commit)
@commit = commit @commit = commit
repo = commit.project.repository.raw_repository repo = commit.container.repository.raw_repository
@signature_data = Gitlab::Git::Commit.extract_signature_lazily(repo, commit.sha || commit.id) @signature_data = Gitlab::Git::Commit.extract_signature_lazily(repo, commit.sha || commit.id)
lazy_signature lazy_signature
......
...@@ -106,6 +106,14 @@ describe Project do ...@@ -106,6 +106,14 @@ describe Project do
it { is_expected.to have_many(:sourced_pipelines) } it { is_expected.to have_many(:sourced_pipelines) }
it { is_expected.to have_many(:source_pipelines) } it { is_expected.to have_many(:source_pipelines) }
it_behaves_like 'model with repository' do
let_it_be(:container) { create(:project, :repository, path: 'somewhere') }
let(:stubbed_container) { build_stubbed(:project) }
let(:expected_full_path) { "#{container.namespace.full_path}/somewhere" }
let(:expected_repository_klass) { Repository }
let(:expected_storage_klass) { Storage::Hashed }
end
it 'has an inverse relationship with merge requests' do it 'has an inverse relationship with merge requests' do
expect(described_class.reflect_on_association(:merge_requests).has_inverse?).to eq(:target_project) expect(described_class.reflect_on_association(:merge_requests).has_inverse?).to eq(:target_project)
end end
...@@ -510,7 +518,6 @@ describe Project do ...@@ -510,7 +518,6 @@ describe Project do
describe 'Respond to' do describe 'Respond to' do
it { is_expected.to respond_to(:url_to_repo) } it { is_expected.to respond_to(:url_to_repo) }
it { is_expected.to respond_to(:repo_exists?) }
it { is_expected.to respond_to(:execute_hooks) } it { is_expected.to respond_to(:execute_hooks) }
it { is_expected.to respond_to(:owner) } it { is_expected.to respond_to(:owner) }
it { is_expected.to respond_to(:path_with_namespace) } it { is_expected.to respond_to(:path_with_namespace) }
...@@ -664,44 +671,6 @@ describe Project do ...@@ -664,44 +671,6 @@ describe Project do
expect(project.url_to_repo).to eq(Gitlab.config.gitlab_shell.ssh_path_prefix + 'somewhere.git') expect(project.url_to_repo).to eq(Gitlab.config.gitlab_shell.ssh_path_prefix + 'somewhere.git')
end end
describe "#web_url" do
let(:project) { create(:project, path: "somewhere") }
context 'when given the only_path option' do
subject { project.web_url(only_path: only_path) }
context 'when only_path is false' do
let(:only_path) { false }
it 'returns the full web URL for this repo' do
expect(subject).to eq("#{Gitlab.config.gitlab.url}/#{project.namespace.full_path}/somewhere")
end
end
context 'when only_path is true' do
let(:only_path) { true }
it 'returns the relative web URL for this repo' do
expect(subject).to eq("/#{project.namespace.full_path}/somewhere")
end
end
context 'when only_path is nil' do
let(:only_path) { nil }
it 'returns the full web URL for this repo' do
expect(subject).to eq("#{Gitlab.config.gitlab.url}/#{project.namespace.full_path}/somewhere")
end
end
end
context 'when not given the only_path option' do
it 'returns the full web URL for this repo' do
expect(project.web_url).to eq("#{Gitlab.config.gitlab.url}/#{project.namespace.full_path}/somewhere")
end
end
end
describe "#readme_url" do describe "#readme_url" do
context 'with a non-existing repository' do context 'with a non-existing repository' do
let(:project) { create(:project) } let(:project) { create(:project) }
...@@ -931,14 +900,6 @@ describe Project do ...@@ -931,14 +900,6 @@ describe Project do
end end
end end
describe '#repository' do
let(:project) { create(:project, :repository) }
it 'returns valid repo' do
expect(project.repository).to be_kind_of(Repository)
end
end
describe '#default_issues_tracker?' do describe '#default_issues_tracker?' do
it "is true if used internal tracker" do it "is true if used internal tracker" do
project = build(:project) project = build(:project)
...@@ -954,24 +915,6 @@ describe Project do ...@@ -954,24 +915,6 @@ describe Project do
end end
end end
describe '#empty_repo?' do
context 'when the repo does not exist' do
let(:project) { build_stubbed(:project) }
it 'returns true' do
expect(project.empty_repo?).to be(true)
end
end
context 'when the repo exists' do
let(:project) { create(:project, :repository) }
let(:empty_project) { create(:project, :empty_repo) }
it { expect(empty_project.empty_repo?).to be(true) }
it { expect(project.empty_repo?).to be(false) }
end
end
describe '#external_issue_tracker' do describe '#external_issue_tracker' do
let(:project) { create(:project) } let(:project) { create(:project) }
let(:ext_project) { create(:redmine_project) } let(:ext_project) { create(:redmine_project) }
...@@ -3406,59 +3349,6 @@ describe Project do ...@@ -3406,59 +3349,6 @@ describe Project do
end end
end end
describe '#http_url_to_repo' do
let(:project) { create(:project) }
context 'when a custom HTTP clone URL root is not set' do
it 'returns the url to the repo without a username' do
expect(project.http_url_to_repo).to eq("#{project.web_url}.git")
expect(project.http_url_to_repo).not_to include('@')
end
end
context 'when a custom HTTP clone URL root is set' do
before do
stub_application_setting(custom_http_clone_url_root: custom_http_clone_url_root)
end
context 'when custom HTTP clone URL root has a relative URL root' do
context 'when custom HTTP clone URL root ends with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234/mygitlab/' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(project.http_url_to_repo).to eq("https://git.example.com:51234/mygitlab/#{project.full_path}.git")
end
end
context 'when custom HTTP clone URL root does not end with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234/mygitlab' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(project.http_url_to_repo).to eq("https://git.example.com:51234/mygitlab/#{project.full_path}.git")
end
end
end
context 'when custom HTTP clone URL root does not have a relative URL root' do
context 'when custom HTTP clone URL root ends with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234/' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(project.http_url_to_repo).to eq("https://git.example.com:51234/#{project.full_path}.git")
end
end
context 'when custom HTTP clone URL root does not end with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(project.http_url_to_repo).to eq("https://git.example.com:51234/#{project.full_path}.git")
end
end
end
end
end
describe '#lfs_http_url_to_repo' do describe '#lfs_http_url_to_repo' do
let(:project) { create(:project) } let(:project) { create(:project) }
...@@ -5054,16 +4944,6 @@ describe Project do ...@@ -5054,16 +4944,6 @@ describe Project do
end end
end end
context '#commits_by' do
let(:project) { create(:project, :repository) }
let(:commits) { project.repository.commits('HEAD', limit: 3).commits }
let(:commit_shas) { commits.map(&:id) }
it 'retrieves several commits from the repository by oid' do
expect(project.commits_by(oids: commit_shas)).to eq commits
end
end
context '#members_among' do context '#members_among' do
let(:users) { create_list(:user, 3) } let(:users) { create_list(:user, 3) }
......
# frozen_string_literal: true
RSpec.shared_examples 'model with repository' do
describe '#commits_by' do
let(:commits) { container.repository.commits('HEAD', limit: 3).commits }
let(:commit_shas) { commits.map(&:id) }
it 'retrieves several commits from the repository by oid' do
expect(container.commits_by(oids: commit_shas)).to eq commits
end
end
describe "#web_url" do
context 'when given the only_path option' do
subject { container.web_url(only_path: only_path) }
context 'when only_path is false' do
let(:only_path) { false }
it 'returns the full web URL for this repo' do
expect(subject).to eq("#{Gitlab.config.gitlab.url}/#{expected_full_path}")
end
end
context 'when only_path is true' do
let(:only_path) { true }
it 'returns the relative web URL for this repo' do
expect(subject).to eq("/#{expected_full_path}")
end
end
context 'when only_path is nil' do
let(:only_path) { nil }
it 'returns the full web URL for this repo' do
expect(subject).to eq("#{Gitlab.config.gitlab.url}/#{expected_full_path}")
end
end
end
context 'when not given the only_path option' do
it 'returns the full web URL for this repo' do
expect(container.web_url).to eq("#{Gitlab.config.gitlab.url}/#{expected_full_path}")
end
end
end
describe '#ssh_url_to_repo' do
it 'returns container ssh address' do
expect(container.ssh_url_to_repo).to eq container.url_to_repo
end
end
describe '#http_url_to_repo' do
subject { container.http_url_to_repo }
context 'when a custom HTTP clone URL root is not set' do
it 'returns the url to the repo without a username' do
expect(subject).to eq("#{container.web_url}.git")
expect(subject).not_to include('@')
end
end
context 'when a custom HTTP clone URL root is set' do
before do
stub_application_setting(custom_http_clone_url_root: custom_http_clone_url_root)
end
context 'when custom HTTP clone URL root has a relative URL root' do
context 'when custom HTTP clone URL root ends with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234/mygitlab/' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(subject).to eq("#{custom_http_clone_url_root}#{expected_full_path}.git")
end
end
context 'when custom HTTP clone URL root does not end with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234/mygitlab' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(subject).to eq("#{custom_http_clone_url_root}/#{expected_full_path}.git")
end
end
end
context 'when custom HTTP clone URL root does not have a relative URL root' do
context 'when custom HTTP clone URL root ends with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234/' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(subject).to eq("#{custom_http_clone_url_root}#{expected_full_path}.git")
end
end
context 'when custom HTTP clone URL root does not end with a slash' do
let(:custom_http_clone_url_root) { 'https://git.example.com:51234' }
it 'returns the url to the repo, with the root replaced with the custom one' do
expect(subject).to eq("#{custom_http_clone_url_root}/#{expected_full_path}.git")
end
end
end
end
end
describe '#repository' do
it 'returns valid repo' do
expect(container.repository).to be_kind_of(expected_repository_klass)
end
end
describe '#storage' do
it 'returns valid storage' do
expect(container.storage).to be_kind_of(expected_storage_klass)
end
end
describe '#full_path' do
it 'returns valid full_path' do
expect(container.full_path).to eq(expected_full_path)
end
end
describe '#empty_repo?' do
context 'when the repo does not exist' do
it 'returns true' do
expect(stubbed_container.empty_repo?).to be(true)
end
end
context 'when the repo exists' do
it { expect(container.empty_repo?).to be(false) }
it 'returns true when repository is empty' do
allow(container.repository).to receive(:empty?).and_return(true)
expect(container.empty_repo?).to be(true)
end
end
end
describe '#valid_repo?' do
it { expect(stubbed_container.valid_repo?).to be(false)}
it { expect(container.valid_repo?).to be(true) }
end
describe '#repository_exists?' do
it { expect(stubbed_container.repository_exists?).to be(false)}
it { expect(container.repository_exists?).to be(true) }
end
describe '#repo_exists?' do
it { expect(stubbed_container.repo_exists?).to be(false)}
it { expect(container.repo_exists?).to be(true) }
end
describe '#root_ref' do
let(:root_ref) { container.repository.root_ref }
it { expect(container.root_ref?(root_ref)).to be(true) }
it { expect(container.root_ref?('HEAD')).to be(false) }
it { expect(container.root_ref?('foo')).to be(false) }
end
describe 'Respond to' do
it { is_expected.to respond_to(:base_dir) }
it { is_expected.to respond_to(:disk_path) }
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment