# 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