163 lines
4.2 KiB
Ruby
163 lines
4.2 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
require 'spec_helper'
|
||
|
|
||
|
describe Git::BaseHooksService do
|
||
|
include RepoHelpers
|
||
|
include GitHelpers
|
||
|
|
||
|
let(:user) { create(:user) }
|
||
|
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(:newrev) { "8a2a6eb295bb170b34c24c76c49ed0e9b2eaf34b" } # gitlab-test: git rev-parse refs/tags/v1.1.0
|
||
|
let(:ref) { 'refs/tags/v1.1.0' }
|
||
|
|
||
|
describe '#execute_project_hooks' do
|
||
|
class TestService < described_class
|
||
|
def hook_name
|
||
|
:push_hooks
|
||
|
end
|
||
|
|
||
|
def commits
|
||
|
[]
|
||
|
end
|
||
|
end
|
||
|
|
||
|
let(:project) { create(:project, :repository) }
|
||
|
|
||
|
subject { TestService.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) }
|
||
|
|
||
|
context '#execute_hooks' do
|
||
|
before do
|
||
|
expect(project).to receive(:has_active_hooks?).and_return(active)
|
||
|
end
|
||
|
|
||
|
context 'active hooks' do
|
||
|
let(:active) { true }
|
||
|
|
||
|
it 'executes the hooks' do
|
||
|
expect(subject).to receive(:push_data).at_least(:once).and_call_original
|
||
|
expect(project).to receive(:execute_hooks)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'inactive hooks' do
|
||
|
let(:active) { false }
|
||
|
|
||
|
it 'does not execute the hooks' do
|
||
|
expect(subject).not_to receive(:push_data)
|
||
|
expect(project).not_to receive(:execute_hooks)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context '#execute_services' do
|
||
|
before do
|
||
|
expect(project).to receive(:has_active_services?).and_return(active)
|
||
|
end
|
||
|
|
||
|
context 'active services' do
|
||
|
let(:active) { true }
|
||
|
|
||
|
it 'executes the services' do
|
||
|
expect(subject).to receive(:push_data).at_least(:once).and_call_original
|
||
|
expect(project).to receive(:execute_services)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'inactive services' do
|
||
|
let(:active) { false }
|
||
|
|
||
|
it 'does not execute the services' do
|
||
|
expect(subject).not_to receive(:push_data)
|
||
|
expect(project).not_to receive(:execute_services)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'with remote mirrors' do
|
||
|
class TestService < described_class
|
||
|
def commits
|
||
|
[]
|
||
|
end
|
||
|
end
|
||
|
|
||
|
let(:project) { create(:project, :repository, :remote_mirror) }
|
||
|
|
||
|
subject { TestService.new(project, user, oldrev: oldrev, newrev: newrev, ref: ref) }
|
||
|
|
||
|
before do
|
||
|
expect(subject).to receive(:execute_project_hooks)
|
||
|
end
|
||
|
|
||
|
context 'when remote mirror feature is enabled' do
|
||
|
it 'fails stuck remote mirrors' do
|
||
|
allow(project).to receive(:update_remote_mirrors).and_return(project.remote_mirrors)
|
||
|
expect(project).to receive(:mark_stuck_remote_mirrors_as_failed!)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
|
||
|
it 'updates remote mirrors' do
|
||
|
expect(project).to receive(:update_remote_mirrors)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'when remote mirror feature is disabled' do
|
||
|
before do
|
||
|
stub_application_setting(mirror_available: false)
|
||
|
end
|
||
|
|
||
|
context 'with remote mirrors global setting overridden' do
|
||
|
before do
|
||
|
project.remote_mirror_available_overridden = true
|
||
|
end
|
||
|
|
||
|
it 'fails stuck remote mirrors' do
|
||
|
allow(project).to receive(:update_remote_mirrors).and_return(project.remote_mirrors)
|
||
|
expect(project).to receive(:mark_stuck_remote_mirrors_as_failed!)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
|
||
|
it 'updates remote mirrors' do
|
||
|
expect(project).to receive(:update_remote_mirrors)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context 'without remote mirrors global setting overridden' do
|
||
|
before do
|
||
|
project.remote_mirror_available_overridden = false
|
||
|
end
|
||
|
|
||
|
it 'does not fails stuck remote mirrors' do
|
||
|
expect(project).not_to receive(:mark_stuck_remote_mirrors_as_failed!)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
|
||
|
it 'does not updates remote mirrors' do
|
||
|
expect(project).not_to receive(:update_remote_mirrors)
|
||
|
|
||
|
subject.execute
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|