debian-mirror-gitlab/spec/workers/deployments/hooks_worker_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

68 lines
2.4 KiB
Ruby
Raw Normal View History

2021-06-08 01:23:25 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe Deployments::HooksWorker, feature_category: :continuous_delivery do
2021-06-08 01:23:25 +05:30
let(:worker) { described_class.new }
describe '#perform' do
before do
2022-07-23 23:45:48 +05:30
allow(Integrations::ExecuteWorker).to receive(:perform_async)
2021-06-08 01:23:25 +05:30
end
2022-07-16 23:28:13 +05:30
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
2021-06-08 01:23:25 +05:30
it 'executes project services for deployment_hooks' do
deployment = create(:deployment, :running)
project = deployment.project
2022-05-07 20:08:51 +05:30
service = create(:integrations_slack, project: project, deployment_events: true)
2021-06-08 01:23:25 +05:30
2022-07-23 23:45:48 +05:30
expect(Integrations::ExecuteWorker).to receive(:perform_async).with(service.id, an_instance_of(Hash))
2021-06-08 01:23:25 +05:30
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
2022-05-07 20:08:51 +05:30
create(:integrations_slack, project: project, deployment_events: true, active: false)
2021-06-08 01:23:25 +05:30
2022-07-23 23:45:48 +05:30
expect(Integrations::ExecuteWorker).not_to receive(:perform_async)
2021-06-08 01:23:25 +05:30
worker.perform(deployment_id: deployment.id, status_changed_at: Time.current)
end
it 'does not execute if a deployment does not exist' do
2022-07-23 23:45:48 +05:30
expect(Integrations::ExecuteWorker).not_to receive(:perform_async)
2021-06-08 01:23:25 +05:30
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
2021-10-27 15:23:28 +05:30
it_behaves_like 'worker with data consistency',
described_class,
data_consistency: :delayed
2021-06-08 01:23:25 +05:30
end
end