# frozen_string_literal: true require 'spec_helper' RSpec.describe GraphqlTriggers, feature_category: :shared do let_it_be(:project) { create(:project) } let_it_be(:issuable, refind: true) { create(:work_item, project: project) } describe '.issuable_assignees_updated' do let(:assignees) { create_list(:user, 2) } before do issuable.update!(assignees: assignees) end it 'triggers the issuable_assignees_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :issuable_assignees_updated, { issuable_id: issuable.to_gid }, issuable ) described_class.issuable_assignees_updated(issuable) end end describe '.issuable_title_updated' do it 'triggers the issuable_title_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :issuable_title_updated, { issuable_id: issuable.to_gid }, issuable ).and_call_original described_class.issuable_title_updated(issuable) end end describe '.issuable_description_updated' do it 'triggers the issuable_description_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :issuable_description_updated, { issuable_id: issuable.to_gid }, issuable ).and_call_original described_class.issuable_description_updated(issuable) end end describe '.issuable_labels_updated' do let(:labels) { create_list(:label, 3, project: create(:project)) } before do issuable.update!(labels: labels) end it 'triggers the issuable_labels_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :issuable_labels_updated, { issuable_id: issuable.to_gid }, issuable ) described_class.issuable_labels_updated(issuable) end end describe '.issuable_dates_updated' do it 'triggers the issuable_dates_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :issuable_dates_updated, { issuable_id: issuable.to_gid }, issuable ).and_call_original described_class.issuable_dates_updated(issuable) end end describe '.issuable_milestone_updated' do it 'triggers the issuable_milestone_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :issuable_milestone_updated, { issuable_id: issuable.to_gid }, issuable ).and_call_original described_class.issuable_milestone_updated(issuable) end end describe '.merge_request_reviewers_updated' do it 'triggers the merge_request_reviewers_updated subscription' do merge_request = build_stubbed(:merge_request) expect(GitlabSchema.subscriptions).to receive(:trigger).with( :merge_request_reviewers_updated, { issuable_id: merge_request.to_gid }, merge_request ).and_call_original described_class.merge_request_reviewers_updated(merge_request) end end describe '.merge_request_merge_status_updated' do it 'triggers the merge_request_merge_status_updated subscription' do merge_request = build_stubbed(:merge_request) expect(GitlabSchema.subscriptions).to receive(:trigger).with( :merge_request_merge_status_updated, { issuable_id: merge_request.to_gid }, merge_request ).and_call_original described_class.merge_request_merge_status_updated(merge_request) end end describe '.merge_request_approval_state_updated' do it 'triggers the merge_request_approval_state_updated subscription' do merge_request = build_stubbed(:merge_request) expect(GitlabSchema.subscriptions).to receive(:trigger).with( :merge_request_approval_state_updated, { issuable_id: merge_request.to_gid }, merge_request ).and_call_original described_class.merge_request_approval_state_updated(merge_request) end end describe '.merge_request_diff_generated' do it 'triggers the merge_request_diff_generated subscription' do merge_request = build_stubbed(:merge_request) expect(GitlabSchema.subscriptions).to receive(:trigger).with( :merge_request_diff_generated, { issuable_id: merge_request.to_gid }, merge_request ).and_call_original described_class.merge_request_diff_generated(merge_request) end end describe '.work_item_updated' do it 'triggers the work_item_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( 'workItemUpdated', { work_item_id: issuable.to_gid }, issuable ).and_call_original described_class.work_item_updated(issuable) end context 'when triggered with an Issue' do it 'triggers the subscription with a work item' do issue = create(:issue, project: project) work_item = WorkItem.find(issue.id) expect(GitlabSchema.subscriptions).to receive(:trigger).with( 'workItemUpdated', { work_item_id: work_item.to_gid }, work_item ).and_call_original described_class.work_item_updated(issue) end end end describe '.issuable_todo_updated' do let_it_be(:user) { create(:user) } it 'triggers the issuable_todo_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :issuable_todo_updated, { issuable_id: issuable.to_gid }, issuable ).and_call_original described_class.issuable_todo_updated(issuable) end end describe '.user_merge_request_updated' do let_it_be(:user) { create(:user) } let_it_be(:merge_request) { create(:merge_request) } before do stub_feature_flags(merge_request_dashboard: true) end it 'triggers the user_merge_request_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :user_merge_request_updated, { user_id: user.to_gid }, merge_request ).and_call_original described_class.user_merge_request_updated(user, merge_request) end describe 'when merge_request_dashboard is disabled' do before do stub_feature_flags(merge_request_dashboard: false) end it 'does not trigger the user_merge_request_updated subscription' do expect(GitlabSchema.subscriptions).not_to receive(:trigger).with( :user_merge_request_updated, { user_id: user.id }, merge_request ).and_call_original described_class.user_merge_request_updated(user, merge_request) end end end describe '.ci_pipeline_status_updated' do let_it_be(:pipeline) { create(:ci_pipeline) } let_it_be(:user) { pipeline.project.owners.first } it 'triggers the ci_pipeline_status_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :ci_pipeline_status_updated, { pipeline_id: pipeline.to_gid }, pipeline ).and_call_original described_class.ci_pipeline_status_updated(pipeline) end end describe '.ci_pipeline_job_updated' do let_it_be(:job) { create(:ci_build) } it 'triggers the ci_job_status_updated subscription' do expect(GitlabSchema.subscriptions).to receive(:trigger).with( :ci_job_status_updated, { job_id: job.to_gid }, job ) described_class.ci_job_status_updated(job) end describe 'when ci_job_status_realtime is disabled' do before do stub_feature_flags(ci_job_status_realtime: false) end it 'does not trigger the ci_job_status_updated subscription' do expect(GitlabSchema.subscriptions).not_to receive(:trigger).with( :ci_job_status_updated, { job_id: job.to_gid }, job ) described_class.ci_job_status_updated(job) end end end end