gitlab-org--gitlab-foss/spec/graphql/graphql_triggers_spec.rb

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

120 lines
3.4 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe GraphqlTriggers do
let_it_be(:issuable, refind: true) { create(:work_item) }
describe '.issuable_assignees_updated' do
let(:assignees) { create_list(:user, 2) }
before do
issuable.update!(assignees: assignees)
end
it 'triggers the issuableAssigneesUpdated subscription' do
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'issuableAssigneesUpdated',
{ issuable_id: issuable.to_gid },
issuable
)
GraphqlTriggers.issuable_assignees_updated(issuable)
end
end
describe '.issuable_title_updated' do
it 'triggers the issuableTitleUpdated subscription' do
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'issuableTitleUpdated',
{ issuable_id: issuable.to_gid },
issuable
).and_call_original
GraphqlTriggers.issuable_title_updated(issuable)
end
end
describe '.issuable_description_updated' do
it 'triggers the issuableDescriptionUpdated subscription' do
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'issuableDescriptionUpdated',
{ issuable_id: issuable.to_gid },
issuable
).and_call_original
GraphqlTriggers.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 issuableLabelsUpdated subscription' do
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'issuableLabelsUpdated',
{ issuable_id: issuable.to_gid },
issuable
)
GraphqlTriggers.issuable_labels_updated(issuable)
end
end
describe '.issuable_dates_updated' do
it 'triggers the issuableDatesUpdated subscription' do
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'issuableDatesUpdated',
{ issuable_id: issuable.to_gid },
issuable
).and_call_original
GraphqlTriggers.issuable_dates_updated(issuable)
end
end
describe '.issuable_milestone_updated' do
it 'triggers the issuableMilestoneUpdated subscription' do
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'issuableMilestoneUpdated',
{ issuable_id: issuable.to_gid },
issuable
).and_call_original
GraphqlTriggers.issuable_milestone_updated(issuable)
end
end
describe '.merge_request_reviewers_updated' do
it 'triggers the mergeRequestReviewersUpdated subscription' do
merge_request = build_stubbed(:merge_request)
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'mergeRequestReviewersUpdated',
{ issuable_id: merge_request.to_gid },
merge_request
).and_call_original
GraphqlTriggers.merge_request_reviewers_updated(merge_request)
end
end
describe '.merge_request_merge_status_updated' do
it 'triggers the mergeRequestMergeStatusUpdated subscription' do
merge_request = build_stubbed(:merge_request)
expect(GitlabSchema.subscriptions).to receive(:trigger).with(
'mergeRequestMergeStatusUpdated',
{ issuable_id: merge_request.to_gid },
merge_request
).and_call_original
GraphqlTriggers.merge_request_merge_status_updated(merge_request)
end
end
end