gitlab-org--gitlab-foss/spec/workers/deployments/hooks_worker_spec.rb

68 lines
2.4 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Deployments::HooksWorker do
let(:worker) { described_class.new }
describe '#perform' do
before do
allow(Integrations::ExecuteWorker).to receive(:perform_async)
end
it 'logs deployment and project IDs as metadata' do
deployment = create(:deployment, :running)
project = deployment.project
expect(worker).to receive(:log_extra_metadata_on_done).with(:deployment_project_id, project.id)
expect(worker).to receive(:log_extra_metadata_on_done).with(:deployment_id, deployment.id)
worker.perform(deployment_id: deployment.id, status_changed_at: Time.current)
end
it 'executes project services for deployment_hooks' do
deployment = create(:deployment, :running)
project = deployment.project
service = create(:integrations_slack, project: project, deployment_events: true)
expect(Integrations::ExecuteWorker).to receive(:perform_async).with(service.id, an_instance_of(Hash))
worker.perform(deployment_id: deployment.id, status_changed_at: Time.current)
end
it 'does not execute an inactive service' do
deployment = create(:deployment, :running)
project = deployment.project
create(:integrations_slack, project: project, deployment_events: true, active: false)
expect(Integrations::ExecuteWorker).not_to receive(:perform_async)
worker.perform(deployment_id: deployment.id, status_changed_at: Time.current)
end
it 'does not execute if a deployment does not exist' do
expect(Integrations::ExecuteWorker).not_to receive(:perform_async)
worker.perform(deployment_id: non_existing_record_id, status_changed_at: Time.current)
end
it 'execute webhooks' do
deployment = create(:deployment, :running)
project = deployment.project
web_hook = create(:project_hook, deployment_events: true, project: project)
status_changed_at = Time.current
expect_next_instance_of(WebHookService, web_hook, hash_including(status_changed_at: status_changed_at), "deployment_hooks") do |service|
expect(service).to receive(:async_execute)
end
worker.perform(deployment_id: deployment.id, status_changed_at: status_changed_at)
end
it_behaves_like 'worker with data consistency',
described_class,
data_consistency: :delayed
end
end