Commit dff1e638 authored by Patrick Bajao's avatar Patrick Bajao

Refactor PostReceive to be more readable

This refactors the implementation of gathering/iterating changes
from the post-receive hook to be a bit more readable (removed
the need for calling `enum_for(:changes_refs)` in different
places).

This is done with the help of the new `Gitlab::Git::Changes`
collection object which will be used while parsing the changes.

Also changed the signature of BranchPushService and TagPushService
to accept a single `change` param instead of having oldrev, newrev
and ref params.

This also prepares the `PostReceive` worker to be able to process
branches and tags separately so we'll be able to aggregate events
by branches or tags.
parent 5e21cc09
# frozen_string_literal: true
module Git
module ChangeParams
private
%i[oldrev newrev ref].each do |method|
define_method method do
change[method]
end
end
def change
@change ||= params.fetch(:change, {})
end
end
end
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
module Git module Git
class BaseHooksService < ::BaseService class BaseHooksService < ::BaseService
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
include ChangeParams
# The N most recent commits to process in a single push payload. # The N most recent commits to process in a single push payload.
PROCESS_COMMIT_LIMIT = 100 PROCESS_COMMIT_LIMIT = 100
...@@ -77,20 +78,20 @@ module Git ...@@ -77,20 +78,20 @@ module Git
def pipeline_params def pipeline_params
{ {
before: params[:oldrev], before: oldrev,
after: params[:newrev], after: newrev,
ref: params[:ref], ref: ref,
push_options: params[:push_options] || {}, push_options: params[:push_options] || {},
checkout_sha: Gitlab::DataBuilder::Push.checkout_sha( checkout_sha: Gitlab::DataBuilder::Push.checkout_sha(
project.repository, params[:newrev], params[:ref]) project.repository, newrev, ref)
} }
end end
def push_data_params(commits:, with_changed_files: true) def push_data_params(commits:, with_changed_files: true)
{ {
oldrev: params[:oldrev], oldrev: oldrev,
newrev: params[:newrev], newrev: newrev,
ref: params[:ref], ref: ref,
project: project, project: project,
user: current_user, user: current_user,
commits: commits, commits: commits,
......
...@@ -20,15 +20,15 @@ module Git ...@@ -20,15 +20,15 @@ module Git
strong_memoize(:commits) do strong_memoize(:commits) do
if creating_default_branch? if creating_default_branch?
# The most recent PROCESS_COMMIT_LIMIT commits in the default branch # The most recent PROCESS_COMMIT_LIMIT commits in the default branch
project.repository.commits(params[:newrev], limit: PROCESS_COMMIT_LIMIT) project.repository.commits(newrev, limit: PROCESS_COMMIT_LIMIT)
elsif creating_branch? elsif creating_branch?
# Use the pushed commits that aren't reachable by the default branch # Use the pushed commits that aren't reachable by the default branch
# as a heuristic. This may include more commits than are actually # as a heuristic. This may include more commits than are actually
# pushed, but that shouldn't matter because we check for existing # pushed, but that shouldn't matter because we check for existing
# cross-references later. # cross-references later.
project.repository.commits_between(project.default_branch, params[:newrev]) project.repository.commits_between(project.default_branch, newrev)
elsif updating_branch? elsif updating_branch?
project.repository.commits_between(params[:oldrev], params[:newrev]) project.repository.commits_between(oldrev, newrev)
else # removing branch else # removing branch
[] []
end end
...@@ -70,7 +70,7 @@ module Git ...@@ -70,7 +70,7 @@ module Git
def branch_update_hooks def branch_update_hooks
# Update the bare repositories info/attributes file using the contents of # Update the bare repositories info/attributes file using the contents of
# the default branch's .gitattributes file # the default branch's .gitattributes file
project.repository.copy_gitattributes(params[:ref]) if default_branch? project.repository.copy_gitattributes(ref) if default_branch?
end end
def branch_change_hooks def branch_change_hooks
...@@ -118,7 +118,7 @@ module Git ...@@ -118,7 +118,7 @@ module Git
# https://gitlab.com/gitlab-org/gitlab-foss/issues/59257 # https://gitlab.com/gitlab-org/gitlab-foss/issues/59257
def creating_branch? def creating_branch?
strong_memoize(:creating_branch) do strong_memoize(:creating_branch) do
Gitlab::Git.blank_ref?(params[:oldrev]) || Gitlab::Git.blank_ref?(oldrev) ||
!project.repository.branch_exists?(branch_name) !project.repository.branch_exists?(branch_name)
end end
end end
...@@ -128,7 +128,7 @@ module Git ...@@ -128,7 +128,7 @@ module Git
end end
def removing_branch? def removing_branch?
Gitlab::Git.blank_ref?(params[:newrev]) Gitlab::Git.blank_ref?(newrev)
end end
def creating_default_branch? def creating_default_branch?
...@@ -137,7 +137,7 @@ module Git ...@@ -137,7 +137,7 @@ module Git
def count_commits_in_branch def count_commits_in_branch
strong_memoize(:count_commits_in_branch) do strong_memoize(:count_commits_in_branch) do
project.repository.commit_count_for_ref(params[:ref]) project.repository.commit_count_for_ref(ref)
end end
end end
...@@ -148,7 +148,7 @@ module Git ...@@ -148,7 +148,7 @@ module Git
end end
def branch_name def branch_name
strong_memoize(:branch_name) { Gitlab::Git.ref_name(params[:ref]) } strong_memoize(:branch_name) { Gitlab::Git.ref_name(ref) }
end end
def upstream_commit_ids(commits) def upstream_commit_ids(commits)
......
...@@ -4,6 +4,7 @@ module Git ...@@ -4,6 +4,7 @@ module Git
class BranchPushService < ::BaseService class BranchPushService < ::BaseService
include Gitlab::Access include Gitlab::Access
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
include ChangeParams
# This method will be called after each git update # This method will be called after each git update
# and only if the provided user and project are present in GitLab. # and only if the provided user and project are present in GitLab.
...@@ -19,7 +20,7 @@ module Git ...@@ -19,7 +20,7 @@ module Git
# 6. Checks if the project's main language has changed # 6. Checks if the project's main language has changed
# #
def execute def execute
return unless Gitlab::Git.branch_ref?(params[:ref]) return unless Gitlab::Git.branch_ref?(ref)
enqueue_update_mrs enqueue_update_mrs
enqueue_detect_repository_languages enqueue_detect_repository_languages
...@@ -38,9 +39,9 @@ module Git ...@@ -38,9 +39,9 @@ module Git
UpdateMergeRequestsWorker.perform_async( UpdateMergeRequestsWorker.perform_async(
project.id, project.id,
current_user.id, current_user.id,
params[:oldrev], oldrev,
params[:newrev], newrev,
params[:ref] ref
) )
end end
...@@ -69,11 +70,11 @@ module Git ...@@ -69,11 +70,11 @@ module Git
end end
def removing_branch? def removing_branch?
Gitlab::Git.blank_ref?(params[:newrev]) Gitlab::Git.blank_ref?(newrev)
end end
def branch_name def branch_name
strong_memoize(:branch_name) { Gitlab::Git.ref_name(params[:ref]) } strong_memoize(:branch_name) { Gitlab::Git.ref_name(ref) }
end end
def default_branch? def default_branch?
......
...@@ -18,12 +18,12 @@ module Git ...@@ -18,12 +18,12 @@ module Git
def tag def tag
strong_memoize(:tag) do strong_memoize(:tag) do
next if Gitlab::Git.blank_ref?(params[:newrev]) next if Gitlab::Git.blank_ref?(newrev)
tag_name = Gitlab::Git.ref_name(params[:ref]) tag_name = Gitlab::Git.ref_name(ref)
tag = project.repository.find_tag(tag_name) tag = project.repository.find_tag(tag_name)
tag if tag && tag.target == params[:newrev] tag if tag && tag.target == newrev
end end
end end
......
...@@ -2,8 +2,10 @@ ...@@ -2,8 +2,10 @@
module Git module Git
class TagPushService < ::BaseService class TagPushService < ::BaseService
include ChangeParams
def execute def execute
return unless Gitlab::Git.tag_ref?(params[:ref]) return unless Gitlab::Git.tag_ref?(ref)
project.repository.before_push_tag project.repository.before_push_tag
TagHooksService.new(project, current_user, params).execute TagHooksService.new(project, current_user, params).execute
......
...@@ -37,41 +37,22 @@ class PostReceive ...@@ -37,41 +37,22 @@ class PostReceive
end end
def process_project_changes(post_received) def process_project_changes(post_received)
changes = []
refs = Set.new
user = identify_user(post_received) user = identify_user(post_received)
return false unless user return false unless user
project = post_received.project
push_options = post_received.push_options
changes = post_received.changes
# We only need to expire certain caches once per push # We only need to expire certain caches once per push
expire_caches(post_received, post_received.project.repository) expire_caches(post_received, post_received.project.repository)
enqueue_repository_cache_update(post_received) enqueue_repository_cache_update(post_received)
post_received.enum_for(:changes_refs).with_index do |(oldrev, newrev, ref), index| process_changes(Git::BranchPushService, project, user, push_options, changes.branch_changes)
service_klass = process_changes(Git::TagPushService, project, user, push_options, changes.tag_changes)
if Gitlab::Git.tag_ref?(ref)
Git::TagPushService
elsif Gitlab::Git.branch_ref?(ref)
Git::BranchPushService
end
if service_klass
service_klass.new(
post_received.project,
user,
oldrev: oldrev,
newrev: newrev,
ref: ref,
push_options: post_received.push_options,
create_pipelines: index < PIPELINE_PROCESS_LIMIT || Feature.enabled?(:git_push_create_all_pipelines, post_received.project)
).execute
end
changes << Gitlab::DataBuilder::Repository.single_change(oldrev, newrev, ref)
refs << ref
end
update_remote_mirrors(post_received) update_remote_mirrors(post_received)
after_project_changes_hooks(post_received, user, refs.to_a, changes) after_project_changes_hooks(project, user, changes.refs, changes.repository_data)
end end
# Expire the repository status, branch, and tag cache once per push. # Expire the repository status, branch, and tag cache once per push.
...@@ -94,6 +75,20 @@ class PostReceive ...@@ -94,6 +75,20 @@ class PostReceive
) )
end end
def process_changes(service_class, project, user, push_options, changes)
return if changes.empty?
changes.each do |change|
service_class.new(
project,
user,
change: change,
push_options: push_options,
create_pipelines: change[:index] < PIPELINE_PROCESS_LIMIT || Feature.enabled?(:git_push_create_all_pipelines, project)
).execute
end
end
def update_remote_mirrors(post_received) def update_remote_mirrors(post_received)
return unless post_received.includes_branches? || post_received.includes_tags? return unless post_received.includes_branches? || post_received.includes_tags?
...@@ -104,9 +99,9 @@ class PostReceive ...@@ -104,9 +99,9 @@ class PostReceive
project.update_remote_mirrors project.update_remote_mirrors
end end
def after_project_changes_hooks(post_received, user, refs, changes) def after_project_changes_hooks(project, user, refs, changes)
hook_data = Gitlab::DataBuilder::Repository.update(post_received.project, user, changes, refs) repository_update_hook_data = Gitlab::DataBuilder::Repository.update(project, user, changes, refs)
SystemHooksService.new.execute_hooks(hook_data, :repository_update_hooks) SystemHooksService.new.execute_hooks(repository_update_hook_data, :repository_update_hooks)
Gitlab::UsageDataCounters::SourceCodeCounter.count(:pushes) Gitlab::UsageDataCounters::SourceCodeCounter.count(:pushes)
end end
...@@ -121,7 +116,7 @@ class PostReceive ...@@ -121,7 +116,7 @@ class PostReceive
# We only need to expire certain caches once per push # We only need to expire certain caches once per push
expire_caches(post_received, post_received.project.wiki.repository) expire_caches(post_received, post_received.project.wiki.repository)
::Git::WikiPushService.new(post_received.project, user, changes: post_received.enum_for(:changes_refs)).execute ::Git::WikiPushService.new(post_received.project, user, changes: post_received.changes).execute
end end
def log(message) def log(message)
......
...@@ -150,9 +150,11 @@ class Gitlab::Seeder::CycleAnalytics ...@@ -150,9 +150,11 @@ class Gitlab::Seeder::CycleAnalytics
::Git::BranchPushService.new( ::Git::BranchPushService.new(
issue.project, issue.project,
@user, @user,
change: {
oldrev: issue.project.repository.commit("master").sha, oldrev: issue.project.repository.commit("master").sha,
newrev: commit_sha, newrev: commit_sha,
ref: 'refs/heads/master' ref: 'refs/heads/master'
}
).execute ).execute
branch_name branch_name
......
...@@ -18,7 +18,7 @@ module EE ...@@ -18,7 +18,7 @@ module EE
def enqueue_elasticsearch_indexing def enqueue_elasticsearch_indexing
return unless should_index_commits? return unless should_index_commits?
project.repository.index_commits_and_blobs(from_rev: params[:oldrev], to_rev: params[:newrev]) project.repository.index_commits_and_blobs(from_rev: oldrev, to_rev: newrev)
end end
def enqueue_update_external_pull_requests def enqueue_update_external_pull_requests
...@@ -28,7 +28,7 @@ module EE ...@@ -28,7 +28,7 @@ module EE
UpdateExternalPullRequestsWorker.perform_async( UpdateExternalPullRequestsWorker.perform_async(
project.id, project.id,
current_user.id, current_user.id,
params[:ref] ref
) )
end end
......
...@@ -9,11 +9,11 @@ module EE ...@@ -9,11 +9,11 @@ module EE
return unless project.use_elasticsearch? return unless project.use_elasticsearch?
# Check if one of the changes we got was for the default branch. If it was, trigger an ES update # Check if one of the changes we got was for the default branch. If it was, trigger an ES update
params[:changes].each do |_oldrev, newrev, ref| params[:changes].each do |change|
branch_name = ::Gitlab::Git.ref_name(ref) branch_name = ::Gitlab::Git.ref_name(change[:ref])
next unless project.wiki.default_branch == branch_name next unless project.wiki.default_branch == branch_name
project.wiki.index_wiki_blobs(newrev) project.wiki.index_wiki_blobs(change[:newrev])
end end
end end
end end
......
...@@ -83,12 +83,12 @@ module Projects ...@@ -83,12 +83,12 @@ module Projects
Git::TagPushService.new( Git::TagPushService.new(
project, project,
current_user, current_user,
{ change: {
oldrev: old_tag_target, oldrev: old_tag_target,
newrev: tag_target, newrev: tag_target,
ref: "#{Gitlab::Git::TAG_REF_PREFIX}#{tag.name}", ref: "#{Gitlab::Git::TAG_REF_PREFIX}#{tag.name}"
},
mirror_update: true mirror_update: true
}
).execute ).execute
end end
......
...@@ -10,11 +10,9 @@ module EE ...@@ -10,11 +10,9 @@ module EE
private private
def after_project_changes_hooks(post_received, user, refs, changes) def after_project_changes_hooks(project, user, refs, changes)
super super
project = post_received.project
if audit_push?(project) if audit_push?(project)
::RepositoryPushAuditEventWorker.perform_async(changes, project.id, user.id) ::RepositoryPushAuditEventWorker.perform_async(changes, project.id, user.id)
end end
......
...@@ -87,9 +87,11 @@ class Gitlab::Seeder::ProductivityAnalytics ...@@ -87,9 +87,11 @@ class Gitlab::Seeder::ProductivityAnalytics
::Git::BranchPushService.new( ::Git::BranchPushService.new(
issue.project, issue.project,
@user, @user,
change: {
oldrev: issue.project.repository.commit("master").sha, oldrev: issue.project.repository.commit("master").sha,
newrev: commit_sha, newrev: commit_sha,
ref: 'refs/heads/master' ref: 'refs/heads/master'
}
).execute ).execute
end end
......
...@@ -12,7 +12,7 @@ describe Git::BranchPushService do ...@@ -12,7 +12,7 @@ describe Git::BranchPushService do
let(:ref) { 'refs/heads/master' } let(:ref) { 'refs/heads/master' }
let(:params) do let(:params) do
{ oldrev: oldrev, newrev: newrev, ref: ref } { change: { oldrev: oldrev, newrev: newrev, ref: ref } }
end end
subject do subject do
...@@ -60,16 +60,20 @@ describe Git::BranchPushService do ...@@ -60,16 +60,20 @@ describe Git::BranchPushService do
subject.execute subject.execute
end end
it "does not trigger indexer when push to non-default branch" do it "triggers indexer when push to default branch" do
expect_any_instance_of(Gitlab::Elastic::Indexer).not_to receive(:run) expect_any_instance_of(Gitlab::Elastic::Indexer).to receive(:run)
execute_service(project, user, oldrev, newrev, 'refs/heads/other') subject.execute
end end
it "triggers indexer when push to default branch" do context 'when push to non-default branch' do
expect_any_instance_of(Gitlab::Elastic::Indexer).to receive(:run) let(:ref) { 'refs/heads/other' }
execute_service(project, user, oldrev, newrev, ref) it 'does not trigger indexer when push to non-default branch' do
expect_any_instance_of(Gitlab::Elastic::Indexer).not_to receive(:run)
subject.execute
end
end end
context 'when limited indexing is on' do context 'when limited indexing is on' do
...@@ -231,10 +235,4 @@ describe Git::BranchPushService do ...@@ -231,10 +235,4 @@ describe Git::BranchPushService do
it_behaves_like 'does not enqueue Jira sync worker' it_behaves_like 'does not enqueue Jira sync worker'
end end
end end
def execute_service(project, user, oldrev, newrev, ref)
service = described_class.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
service.execute
service
end
end end
...@@ -26,7 +26,7 @@ describe Git::WikiPushService do ...@@ -26,7 +26,7 @@ describe Git::WikiPushService do
it 'triggers a wiki update' do it 'triggers a wiki update' do
expect(project.wiki).to receive(:index_wiki_blobs).with("797823") expect(project.wiki).to receive(:index_wiki_blobs).with("797823")
described_class.new(project, project.owner, changes: post_received.enum_for(:changes_refs)).execute described_class.new(project, project.owner, changes: post_received.changes).execute
end end
end end
...@@ -36,7 +36,7 @@ describe Git::WikiPushService do ...@@ -36,7 +36,7 @@ describe Git::WikiPushService do
it 'does not trigger a wiki update' do it 'does not trigger a wiki update' do
expect(project.wiki).not_to receive(:index_wiki_blobs) expect(project.wiki).not_to receive(:index_wiki_blobs)
described_class.new(project, project.owner, changes: post_received.enum_for(:changes_refs)).execute described_class.new(project, project.owner, changes: post_received.changes).execute
end end
end end
end end
...@@ -52,7 +52,7 @@ describe Git::WikiPushService do ...@@ -52,7 +52,7 @@ describe Git::WikiPushService do
it 'does nothing even if changes include master ref' do it 'does nothing even if changes include master ref' do
expect(project.wiki).not_to receive(:index_wiki_blobs) expect(project.wiki).not_to receive(:index_wiki_blobs)
described_class.new(project, project.owner, changes: post_received.enum_for(:changes_refs)).execute described_class.new(project, project.owner, changes: post_received.changes).execute
end end
end end
end end
......
...@@ -65,7 +65,7 @@ describe Projects::UpdateMirrorService do ...@@ -65,7 +65,7 @@ describe Projects::UpdateMirrorService do
stub_fetch_mirror(project) stub_fetch_mirror(project)
expect(Git::TagPushService).to receive(:new) expect(Git::TagPushService).to receive(:new)
.with(project, project.owner, hash_including(ref: 'refs/tags/new-tag')) .with(project, project.owner, change: hash_including(ref: 'refs/tags/new-tag'), mirror_update: true)
.and_return(double(execute: true)) .and_return(double(execute: true))
service.execute service.execute
......
# frozen_string_literal: true
module Gitlab
module Git
class Changes
include Enumerable
attr_reader :repository_data
def initialize
@refs = Set.new
@items = []
@branches_index = []
@tags_index = []
@repository_data = []
end
def includes_branches?
branches_index.any?
end
def includes_tags?
tags_index.any?
end
def add_branch_change(change)
@branches_index << add_change(change)
self
end
def add_tag_change(change)
@tags_index << add_change(change)
self
end
def each
items.each do |item|
yield item
end
end
def refs
@refs.to_a
end
def branch_changes
items.values_at(*branches_index)
end
def tag_changes
items.values_at(*tags_index)
end
private
attr_reader :items, :branches_index, :tags_index
def add_change(change)
# refs and repository_data are being cached when a change is added to
# the collection to remove the need to iterate through changes multiple
# times.
@refs << change[:ref]
@repository_data << build_change_repository_data(change)
@items << change
@items.size - 1
end
def build_change_repository_data(change)
DataBuilder::Repository.single_change(change[:oldrev], change[:newrev], change[:ref])
end
end
end
end
...@@ -8,7 +8,7 @@ module Gitlab ...@@ -8,7 +8,7 @@ module Gitlab
def initialize(project, identifier, changes, push_options = {}) def initialize(project, identifier, changes, push_options = {})
@project = project @project = project
@identifier = identifier @identifier = identifier
@changes = deserialize_changes(changes) @changes = parse_changes(changes)
@push_options = push_options @push_options = push_options
end end
...@@ -16,27 +16,12 @@ module Gitlab ...@@ -16,27 +16,12 @@ module Gitlab
super(identifier) super(identifier)
end end
def changes_refs
return changes unless block_given?
changes.each do |change|
change.strip!
oldrev, newrev, ref = change.split(' ')
yield oldrev, newrev, ref
end
end
def includes_branches? def includes_branches?
enum_for(:changes_refs).any? do |_oldrev, _newrev, ref| changes.includes_branches?
Gitlab::Git.branch_ref?(ref)
end
end end
def includes_tags? def includes_tags?
enum_for(:changes_refs).any? do |_oldrev, _newrev, ref| changes.includes_tags?
Gitlab::Git.tag_ref?(ref)
end
end end
def includes_default_branch? def includes_default_branch?
...@@ -44,16 +29,28 @@ module Gitlab ...@@ -44,16 +29,28 @@ module Gitlab
# first branch pushed will be the default. # first branch pushed will be the default.
return true unless project.default_branch.present? return true unless project.default_branch.present?
enum_for(:changes_refs).any? do |_oldrev, _newrev, ref| changes.branch_changes.any? do |change|
Gitlab::Git.branch_ref?(ref) && Gitlab::Git.branch_name(change[:ref]) == project.default_branch
Gitlab::Git.branch_name(ref) == project.default_branch
end end
end end
private private
def deserialize_changes(changes) def parse_changes(changes)
utf8_encode_changes(changes).each_line deserialized_changes = utf8_encode_changes(changes).each_line
Git::Changes.new.tap do |collection|
deserialized_changes.each_with_index do |raw_change, index|
oldrev, newrev, ref = raw_change.strip.split(' ')
change = { index: index, oldrev: oldrev, newrev: newrev, ref: ref }
if Git.branch_ref?(ref)
collection.add_branch_change(change)
elsif Git.tag_ref?(ref)
collection.add_tag_change(change)
end
end
end
end end
def utf8_encode_changes(changes) def utf8_encode_changes(changes)
......
...@@ -304,10 +304,12 @@ describe 'Environment' do ...@@ -304,10 +304,12 @@ describe 'Environment' do
# #
def remove_branch_with_hooks(project, user, branch) def remove_branch_with_hooks(project, user, branch)
params = { params = {
change: {
oldrev: project.commit(branch).id, oldrev: project.commit(branch).id,
newrev: Gitlab::Git::BLANK_SHA, newrev: Gitlab::Git::BLANK_SHA,
ref: "refs/heads/#{branch}" ref: "refs/heads/#{branch}"
} }
}
yield yield
......
# frozen_string_literal: true
require 'spec_helper'
describe Gitlab::Git::Changes do
let(:changes) { described_class.new }
describe '#includes_branches?' do
subject { changes.includes_branches? }
context 'has changes for branches' do
before do
changes.add_branch_change(oldrev: 'abc123', newrev: 'def456', ref: 'branch')
end
it { is_expected.to be_truthy }
end
context 'has no changes for branches' do
before do
changes.add_tag_change(oldrev: 'abc123', newrev: 'def456', ref: 'tag')
end
it { is_expected.to be_falsey }
end
end
describe '#includes_tags?' do
subject { changes.includes_tags? }
context 'has changes for tags' do
before do
changes.add_tag_change(oldrev: 'abc123', newrev: 'def456', ref: 'tag')
end
it { is_expected.to be_truthy }
end
context 'has no changes for tags' do
before do
changes.add_branch_change(oldrev: 'abc123', newrev: 'def456', ref: 'branch')
end
it { is_expected.to be_falsey }
end
end
describe '#add_branch_change' do
let(:change) { { oldrev: 'abc123', newrev: 'def456', ref: 'branch' } }
subject { changes.add_branch_change(change) }
it 'adds the branch change to the collection' do
expect(subject).to include(change)
expect(subject.refs).to include(change[:ref])
expect(subject.repository_data).to include(before: change[:oldrev], after: change[:newrev], ref: change[:ref])
expect(subject.branch_changes).to include(change)
end
it 'does not add the change as a tag change' do
expect(subject.tag_changes).not_to include(change)
end
end
describe '#add_tag_change' do
let(:change) { { oldrev: 'abc123', newrev: 'def456', ref: 'tag' } }
subject { changes.add_tag_change(change) }
it 'adds the tag change to the collection' do
expect(subject).to include(change)
expect(subject.refs).to include(change[:ref])
expect(subject.repository_data).to include(before: change[:oldrev], after: change[:newrev], ref: change[:ref])
expect(subject.tag_changes).to include(change)
end
it 'does not add the change as a branch change' do
expect(subject.branch_changes).not_to include(change)
end
end
end
...@@ -8,7 +8,6 @@ describe Git::BaseHooksService do ...@@ -8,7 +8,6 @@ describe Git::BaseHooksService do
let(:user) { create(:user) } let(:user) { create(:user) }
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
let(:service) { described_class.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) }
let(:oldrev) { Gitlab::Git::BLANK_SHA } let(:oldrev) { Gitlab::Git::BLANK_SHA }
let(:newrev) { "8a2a6eb295bb170b34c24c76c49ed0e9b2eaf34b" } # gitlab-test: git rev-parse refs/tags/v1.1.0 let(:newrev) { "8a2a6eb295bb170b34c24c76c49ed0e9b2eaf34b" } # gitlab-test: git rev-parse refs/tags/v1.1.0
...@@ -27,7 +26,7 @@ describe Git::BaseHooksService do ...@@ -27,7 +26,7 @@ describe Git::BaseHooksService do
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
subject { TestService.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) } subject { TestService.new(project, user, change: { oldrev: oldrev, newrev: newrev, ref: ref }) }
context '#execute_hooks' do context '#execute_hooks' do
before do before do
......
...@@ -16,7 +16,7 @@ describe Git::BranchHooksService do ...@@ -16,7 +16,7 @@ describe Git::BranchHooksService do
let(:newrev) { commit.id } let(:newrev) { commit.id }
let(:service) do let(:service) do
described_class.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) described_class.new(project, user, change: { oldrev: oldrev, newrev: newrev, ref: ref })
end end
describe "Git Push Data" do describe "Git Push Data" do
...@@ -350,7 +350,7 @@ describe Git::BranchHooksService do ...@@ -350,7 +350,7 @@ describe Git::BranchHooksService do
let(:forked_project) { fork_project(upstream_project, user, repository: true) } let(:forked_project) { fork_project(upstream_project, user, repository: true) }
let!(:forked_service) do let!(:forked_service) do
described_class.new(forked_project, user, oldrev: oldrev, newrev: newrev, ref: ref) described_class.new(forked_project, user, change: { oldrev: oldrev, newrev: newrev, ref: ref })
end end
context 'when commits already exists in the upstream project' do context 'when commits already exists in the upstream project' do
......
...@@ -19,7 +19,7 @@ describe Git::BranchPushService, services: true do ...@@ -19,7 +19,7 @@ describe Git::BranchPushService, services: true do
describe 'Push branches' do describe 'Push branches' do
subject do subject do
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
context 'new branch' do context 'new branch' do
...@@ -70,7 +70,7 @@ describe Git::BranchPushService, services: true do ...@@ -70,7 +70,7 @@ describe Git::BranchPushService, services: true do
end end
describe "Pipelines" do describe "Pipelines" do
subject { execute_service(project, user, oldrev, newrev, ref) } subject { execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref) }
before do before do
stub_ci_pipeline_to_return_yaml_file stub_ci_pipeline_to_return_yaml_file
...@@ -121,7 +121,7 @@ describe Git::BranchPushService, services: true do ...@@ -121,7 +121,7 @@ describe Git::BranchPushService, services: true do
.to receive(:perform_async) .to receive(:perform_async)
.with(project.id, user.id, blankrev, 'newrev', ref) .with(project.id, user.id, blankrev, 'newrev', ref)
execute_service(project, user, blankrev, 'newrev', ref ) execute_service(project, user, oldrev: blankrev, newrev: 'newrev', ref: ref)
end end
end end
...@@ -130,13 +130,13 @@ describe Git::BranchPushService, services: true do ...@@ -130,13 +130,13 @@ describe Git::BranchPushService, services: true do
it "calls the copy attributes method for the first push to the default branch" do it "calls the copy attributes method for the first push to the default branch" do
expect(project.repository).to receive(:copy_gitattributes).with('master') expect(project.repository).to receive(:copy_gitattributes).with('master')
execute_service(project, user, blankrev, 'newrev', ref) execute_service(project, user, oldrev: blankrev, newrev: 'newrev', ref: ref)
end end
it "calls the copy attributes method for changes to the default branch" do it "calls the copy attributes method for changes to the default branch" do
expect(project.repository).to receive(:copy_gitattributes).with(ref) expect(project.repository).to receive(:copy_gitattributes).with(ref)
execute_service(project, user, 'oldrev', 'newrev', ref) execute_service(project, user, oldrev: 'oldrev', newrev: 'newrev', ref: ref)
end end
end end
...@@ -149,7 +149,7 @@ describe Git::BranchPushService, services: true do ...@@ -149,7 +149,7 @@ describe Git::BranchPushService, services: true do
it "does not call copy attributes method" do it "does not call copy attributes method" do
expect(project.repository).not_to receive(:copy_gitattributes) expect(project.repository).not_to receive(:copy_gitattributes)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
end end
...@@ -163,7 +163,7 @@ describe Git::BranchPushService, services: true do ...@@ -163,7 +163,7 @@ describe Git::BranchPushService, services: true do
it "when pushing a branch for the first time" do it "when pushing a branch for the first time" do
expect(project).to receive(:execute_hooks) expect(project).to receive(:execute_hooks)
expect(project.default_branch).to eq("master") expect(project.default_branch).to eq("master")
execute_service(project, user, blankrev, 'newrev', ref) execute_service(project, user, oldrev: blankrev, newrev: 'newrev', ref: ref)
expect(project.protected_branches).not_to be_empty expect(project.protected_branches).not_to be_empty
expect(project.protected_branches.first.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::MAINTAINER]) expect(project.protected_branches.first.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::MAINTAINER])
expect(project.protected_branches.first.merge_access_levels.map(&:access_level)).to eq([Gitlab::Access::MAINTAINER]) expect(project.protected_branches.first.merge_access_levels.map(&:access_level)).to eq([Gitlab::Access::MAINTAINER])
...@@ -174,7 +174,7 @@ describe Git::BranchPushService, services: true do ...@@ -174,7 +174,7 @@ describe Git::BranchPushService, services: true do
expect(project).to receive(:execute_hooks) expect(project).to receive(:execute_hooks)
expect(project.default_branch).to eq("master") expect(project.default_branch).to eq("master")
execute_service(project, user, blankrev, 'newrev', ref) execute_service(project, user, oldrev: blankrev, newrev: 'newrev', ref: ref)
expect(project.protected_branches).to be_empty expect(project.protected_branches).to be_empty
end end
...@@ -184,7 +184,7 @@ describe Git::BranchPushService, services: true do ...@@ -184,7 +184,7 @@ describe Git::BranchPushService, services: true do
expect(project).to receive(:execute_hooks) expect(project).to receive(:execute_hooks)
expect(project.default_branch).to eq("master") expect(project.default_branch).to eq("master")
execute_service(project, user, blankrev, 'newrev', ref) execute_service(project, user, oldrev: blankrev, newrev: 'newrev', ref: ref)
expect(project.protected_branches).not_to be_empty expect(project.protected_branches).not_to be_empty
expect(project.protected_branches.last.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::DEVELOPER]) expect(project.protected_branches.last.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::DEVELOPER])
...@@ -199,7 +199,7 @@ describe Git::BranchPushService, services: true do ...@@ -199,7 +199,7 @@ describe Git::BranchPushService, services: true do
expect(project.default_branch).to eq("master") expect(project.default_branch).to eq("master")
expect(ProtectedBranches::CreateService).not_to receive(:new) expect(ProtectedBranches::CreateService).not_to receive(:new)
execute_service(project, user, blankrev, 'newrev', ref) execute_service(project, user, oldrev: blankrev, newrev: 'newrev', ref: ref)
expect(project.protected_branches).not_to be_empty expect(project.protected_branches).not_to be_empty
expect(project.protected_branches.last.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::NO_ACCESS]) expect(project.protected_branches.last.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::NO_ACCESS])
...@@ -211,7 +211,7 @@ describe Git::BranchPushService, services: true do ...@@ -211,7 +211,7 @@ describe Git::BranchPushService, services: true do
expect(project).to receive(:execute_hooks) expect(project).to receive(:execute_hooks)
expect(project.default_branch).to eq("master") expect(project.default_branch).to eq("master")
execute_service(project, user, blankrev, 'newrev', ref) execute_service(project, user, oldrev: blankrev, newrev: 'newrev', ref: ref)
expect(project.protected_branches).not_to be_empty expect(project.protected_branches).not_to be_empty
expect(project.protected_branches.first.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::MAINTAINER]) expect(project.protected_branches.first.push_access_levels.map(&:access_level)).to eq([Gitlab::Access::MAINTAINER])
expect(project.protected_branches.first.merge_access_levels.map(&:access_level)).to eq([Gitlab::Access::DEVELOPER]) expect(project.protected_branches.first.merge_access_levels.map(&:access_level)).to eq([Gitlab::Access::DEVELOPER])
...@@ -219,7 +219,7 @@ describe Git::BranchPushService, services: true do ...@@ -219,7 +219,7 @@ describe Git::BranchPushService, services: true do
it "when pushing new commits to existing branch" do it "when pushing new commits to existing branch" do
expect(project).to receive(:execute_hooks) expect(project).to receive(:execute_hooks)
execute_service(project, user, 'oldrev', 'newrev', ref) execute_service(project, user, oldrev: 'oldrev', newrev: 'newrev', ref: ref)
end end
end end
end end
...@@ -249,7 +249,7 @@ describe Git::BranchPushService, services: true do ...@@ -249,7 +249,7 @@ describe Git::BranchPushService, services: true do
it "creates a note if a pushed commit mentions an issue" do it "creates a note if a pushed commit mentions an issue" do
expect(SystemNoteService).to receive(:cross_reference).with(issue, commit, commit_author) expect(SystemNoteService).to receive(:cross_reference).with(issue, commit, commit_author)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
it "only creates a cross-reference note if one doesn't already exist" do it "only creates a cross-reference note if one doesn't already exist" do
...@@ -257,7 +257,7 @@ describe Git::BranchPushService, services: true do ...@@ -257,7 +257,7 @@ describe Git::BranchPushService, services: true do
expect(SystemNoteService).not_to receive(:cross_reference).with(issue, commit, commit_author) expect(SystemNoteService).not_to receive(:cross_reference).with(issue, commit, commit_author)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
it "defaults to the pushing user if the commit's author is not known" do it "defaults to the pushing user if the commit's author is not known" do
...@@ -267,7 +267,7 @@ describe Git::BranchPushService, services: true do ...@@ -267,7 +267,7 @@ describe Git::BranchPushService, services: true do
) )
expect(SystemNoteService).to receive(:cross_reference).with(issue, commit, user) expect(SystemNoteService).to receive(:cross_reference).with(issue, commit, user)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
it "finds references in the first push to a non-default branch" do it "finds references in the first push to a non-default branch" do
...@@ -276,7 +276,7 @@ describe Git::BranchPushService, services: true do ...@@ -276,7 +276,7 @@ describe Git::BranchPushService, services: true do
expect(SystemNoteService).to receive(:cross_reference).with(issue, commit, commit_author) expect(SystemNoteService).to receive(:cross_reference).with(issue, commit, commit_author)
execute_service(project, user, blankrev, newrev, 'refs/heads/other') execute_service(project, user, oldrev: blankrev, newrev: newrev, ref: 'refs/heads/other')
end end
end end
...@@ -306,14 +306,14 @@ describe Git::BranchPushService, services: true do ...@@ -306,14 +306,14 @@ describe Git::BranchPushService, services: true do
context "while saving the 'first_mentioned_in_commit_at' metric for an issue" do context "while saving the 'first_mentioned_in_commit_at' metric for an issue" do
it 'sets the metric for referenced issues' do it 'sets the metric for referenced issues' do
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
expect(issue.reload.metrics.first_mentioned_in_commit_at).to be_like_time(commit_time) expect(issue.reload.metrics.first_mentioned_in_commit_at).to be_like_time(commit_time)
end end
it 'does not set the metric for non-referenced issues' do it 'does not set the metric for non-referenced issues' do
non_referenced_issue = create(:issue, project: project) non_referenced_issue = create(:issue, project: project)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
expect(non_referenced_issue.reload.metrics.first_mentioned_in_commit_at).to be_nil expect(non_referenced_issue.reload.metrics.first_mentioned_in_commit_at).to be_nil
end end
...@@ -345,18 +345,18 @@ describe Git::BranchPushService, services: true do ...@@ -345,18 +345,18 @@ describe Git::BranchPushService, services: true do
context "to default branches" do context "to default branches" do
it "closes issues" do it "closes issues" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(Issue.find(issue.id)).to be_closed expect(Issue.find(issue.id)).to be_closed
end end
it "adds a note indicating that the issue is now closed" do it "adds a note indicating that the issue is now closed" do
expect(SystemNoteService).to receive(:change_status).with(issue, project, commit_author, "closed", closing_commit) expect(SystemNoteService).to receive(:change_status).with(issue, project, commit_author, "closed", closing_commit)
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
end end
it "doesn't create additional cross-reference notes" do it "doesn't create additional cross-reference notes" do
expect(SystemNoteService).not_to receive(:cross_reference) expect(SystemNoteService).not_to receive(:cross_reference)
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
...@@ -368,11 +368,11 @@ describe Git::BranchPushService, services: true do ...@@ -368,11 +368,11 @@ describe Git::BranchPushService, services: true do
it "creates cross-reference notes" do it "creates cross-reference notes" do
expect(SystemNoteService).to receive(:cross_reference).with(issue, closing_commit, commit_author) expect(SystemNoteService).to receive(:cross_reference).with(issue, closing_commit, commit_author)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
it "doesn't close issues" do it "doesn't close issues" do
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
expect(Issue.find(issue.id)).to be_opened expect(Issue.find(issue.id)).to be_opened
end end
end end
...@@ -408,7 +408,7 @@ describe Git::BranchPushService, services: true do ...@@ -408,7 +408,7 @@ describe Git::BranchPushService, services: true do
let(:message) { "this is some work.\n\nrelated to JIRA-1" } let(:message) { "this is some work.\n\nrelated to JIRA-1" }
it "initiates one api call to jira server to mention the issue" do it "initiates one api call to jira server to mention the issue" do
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
expect(WebMock).to have_requested(:post, jira_api_comment_url('JIRA-1')).with( expect(WebMock).to have_requested(:post, jira_api_comment_url('JIRA-1')).with(
body: /mentioned this issue in/ body: /mentioned this issue in/
...@@ -436,13 +436,13 @@ describe Git::BranchPushService, services: true do ...@@ -436,13 +436,13 @@ describe Git::BranchPushService, services: true do
context "using right markdown" do context "using right markdown" do
it "initiates one api call to jira server to close the issue" do it "initiates one api call to jira server to close the issue" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(WebMock).to have_requested(:post, jira_api_transition_url('JIRA-1')).once expect(WebMock).to have_requested(:post, jira_api_transition_url('JIRA-1')).once
end end
it "initiates one api call to jira server to comment on the issue" do it "initiates one api call to jira server to comment on the issue" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(WebMock).to have_requested(:post, jira_api_comment_url('JIRA-1')).with( expect(WebMock).to have_requested(:post, jira_api_comment_url('JIRA-1')).with(
body: comment_body body: comment_body
...@@ -459,13 +459,13 @@ describe Git::BranchPushService, services: true do ...@@ -459,13 +459,13 @@ describe Git::BranchPushService, services: true do
let(:message) { "this is some work.\n\ncloses #1" } let(:message) { "this is some work.\n\ncloses #1" }
it "does not initiates one api call to jira server to close the issue" do it "does not initiates one api call to jira server to close the issue" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(WebMock).not_to have_requested(:post, jira_api_transition_url('JIRA-1')) expect(WebMock).not_to have_requested(:post, jira_api_transition_url('JIRA-1'))
end end
it "does not initiates one api call to jira server to comment on the issue" do it "does not initiates one api call to jira server to comment on the issue" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(WebMock).not_to have_requested(:post, jira_api_comment_url('JIRA-1')).with( expect(WebMock).not_to have_requested(:post, jira_api_comment_url('JIRA-1')).with(
body: comment_body body: comment_body
...@@ -478,13 +478,13 @@ describe Git::BranchPushService, services: true do ...@@ -478,13 +478,13 @@ describe Git::BranchPushService, services: true do
let(:message) { "this is some work.\n\ncloses JIRA-1 \n\n closes #{issue.to_reference}" } let(:message) { "this is some work.\n\ncloses JIRA-1 \n\n closes #{issue.to_reference}" }
it "initiates one api call to jira server to close the jira issue" do it "initiates one api call to jira server to close the jira issue" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(WebMock).to have_requested(:post, jira_api_transition_url('JIRA-1')).once expect(WebMock).to have_requested(:post, jira_api_transition_url('JIRA-1')).once
end end
it "initiates one api call to jira server to comment on the jira issue" do it "initiates one api call to jira server to comment on the jira issue" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(WebMock).to have_requested(:post, jira_api_comment_url('JIRA-1')).with( expect(WebMock).to have_requested(:post, jira_api_comment_url('JIRA-1')).with(
body: comment_body body: comment_body
...@@ -492,14 +492,14 @@ describe Git::BranchPushService, services: true do ...@@ -492,14 +492,14 @@ describe Git::BranchPushService, services: true do
end end
it "closes the internal issue" do it "closes the internal issue" do
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
expect(issue.reload).to be_closed expect(issue.reload).to be_closed
end end
it "adds a note indicating that the issue is now closed" do it "adds a note indicating that the issue is now closed" do
expect(SystemNoteService).to receive(:change_status) expect(SystemNoteService).to receive(:change_status)
.with(issue, project, commit_author, "closed", closing_commit) .with(issue, project, commit_author, "closed", closing_commit)
execute_service(project, commit_author, oldrev, newrev, ref) execute_service(project, commit_author, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
end end
...@@ -517,7 +517,7 @@ describe Git::BranchPushService, services: true do ...@@ -517,7 +517,7 @@ describe Git::BranchPushService, services: true do
end end
it 'push to first branch updates HEAD' do it 'push to first branch updates HEAD' do
execute_service(project, user, blankrev, newrev, new_ref) execute_service(project, user, oldrev: blankrev, newrev: newrev, ref: new_ref)
end end
end end
...@@ -542,7 +542,7 @@ describe Git::BranchPushService, services: true do ...@@ -542,7 +542,7 @@ describe Git::BranchPushService, services: true do
it 'does not perform housekeeping when not needed' do it 'does not perform housekeeping when not needed' do
expect(housekeeping).not_to receive(:execute) expect(housekeeping).not_to receive(:execute)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
context 'when housekeeping is needed' do context 'when housekeeping is needed' do
...@@ -553,20 +553,20 @@ describe Git::BranchPushService, services: true do ...@@ -553,20 +553,20 @@ describe Git::BranchPushService, services: true do
it 'performs housekeeping' do it 'performs housekeeping' do
expect(housekeeping).to receive(:execute) expect(housekeeping).to receive(:execute)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
it 'does not raise an exception' do it 'does not raise an exception' do
allow(housekeeping).to receive(:try_obtain_lease).and_return(false) allow(housekeeping).to receive(:try_obtain_lease).and_return(false)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
it 'increments the push counter' do it 'increments the push counter' do
expect(housekeeping).to receive(:increment!) expect(housekeeping).to receive(:increment!)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
...@@ -577,7 +577,7 @@ describe Git::BranchPushService, services: true do ...@@ -577,7 +577,7 @@ describe Git::BranchPushService, services: true do
it 'does nothing' do it 'does nothing' do
expect(::Ci::StopEnvironmentsService).not_to receive(:new) expect(::Ci::StopEnvironmentsService).not_to receive(:new)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
...@@ -585,7 +585,7 @@ describe Git::BranchPushService, services: true do ...@@ -585,7 +585,7 @@ describe Git::BranchPushService, services: true do
it 'does nothing' do it 'does nothing' do
expect(::Ci::StopEnvironmentsService).not_to receive(:new) expect(::Ci::StopEnvironmentsService).not_to receive(:new)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
...@@ -599,7 +599,7 @@ describe Git::BranchPushService, services: true do ...@@ -599,7 +599,7 @@ describe Git::BranchPushService, services: true do
expect(stop_service).to receive(:execute).with(branch) expect(stop_service).to receive(:execute).with(branch)
end end
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
end end
...@@ -611,15 +611,17 @@ describe Git::BranchPushService, services: true do ...@@ -611,15 +611,17 @@ describe Git::BranchPushService, services: true do
expect(hooks_service.project).to eq(project) expect(hooks_service.project).to eq(project)
expect(hooks_service.current_user).to eq(user) expect(hooks_service.current_user).to eq(user)
expect(hooks_service.params).to include( expect(hooks_service.params).to include(
change: {
oldrev: oldrev, oldrev: oldrev,
newrev: newrev, newrev: newrev,
ref: ref ref: ref
}
) )
expect(hooks_service).to receive(:execute) expect(hooks_service).to receive(:execute)
end end
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
...@@ -629,13 +631,13 @@ describe Git::BranchPushService, services: true do ...@@ -629,13 +631,13 @@ describe Git::BranchPushService, services: true do
it 'does nothing' do it 'does nothing' do
expect(::Git::BranchHooksService).not_to receive(:new) expect(::Git::BranchHooksService).not_to receive(:new)
execute_service(project, user, oldrev, newrev, ref) execute_service(project, user, oldrev: oldrev, newrev: newrev, ref: ref)
end end
end end
end end
def execute_service(project, user, oldrev, newrev, ref) def execute_service(project, user, change)
service = described_class.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) service = described_class.new(project, user, change: change)
service.execute service.execute
service service
end end
......
...@@ -15,7 +15,7 @@ describe Git::TagHooksService, :service do ...@@ -15,7 +15,7 @@ describe Git::TagHooksService, :service do
let(:commit) { tag.dereferenced_target } let(:commit) { tag.dereferenced_target }
let(:service) do let(:service) do
described_class.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) described_class.new(project, user, change: { oldrev: oldrev, newrev: newrev, ref: ref })
end end
describe 'System hooks' do describe 'System hooks' do
......
...@@ -8,7 +8,7 @@ describe Git::TagPushService do ...@@ -8,7 +8,7 @@ describe Git::TagPushService do
let(:user) { create(:user) } let(:user) { create(:user) }
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
let(:service) { described_class.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) } let(:service) { described_class.new(project, user, change: { oldrev: oldrev, newrev: newrev, ref: ref }) }
let(:oldrev) { Gitlab::Git::BLANK_SHA } let(:oldrev) { Gitlab::Git::BLANK_SHA }
let(:newrev) { "8a2a6eb295bb170b34c24c76c49ed0e9b2eaf34b" } # gitlab-test: git rev-parse refs/tags/v1.1.0 let(:newrev) { "8a2a6eb295bb170b34c24c76c49ed0e9b2eaf34b" } # gitlab-test: git rev-parse refs/tags/v1.1.0
......
...@@ -25,11 +25,15 @@ module CycleAnalyticsHelpers ...@@ -25,11 +25,15 @@ module CycleAnalyticsHelpers
return if skip_push_handler return if skip_push_handler
Git::BranchPushService.new(project, Git::BranchPushService.new(
project,
user, user,
change: {
oldrev: oldrev, oldrev: oldrev,
newrev: commit_shas.last, newrev: commit_shas.last,
ref: 'refs/heads/master').execute ref: 'refs/heads/master'
}
).execute
end end
def create_cycle(user, project, issue, mr, milestone, pipeline) def create_cycle(user, project, issue, mr, milestone, pipeline)
......
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