Files
gitlab-foss/spec/graphql/graphql_triggers_spec.rb
2025-05-14 18:12:16 +00:00

270 lines
7.9 KiB
Ruby

# 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