123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe Gql::Mutations::Ticket::SharedDraft::Start::Create, type: :graphql do
- let(:group) { create(:group) }
- let(:content) { { content: Faker::Lorem.unique.sentence } }
- let(:name) { Faker::Lorem.unique.sentence }
- let(:form_id) { '123' }
- let(:variables) do
- {
- name:,
- input: {
- content:,
- formId: form_id,
- groupId: gql.id(group),
- }
- }
- end
- let(:query) do
- <<~QUERY
- mutation ticketSharedDraftStartCreate($name: String!, $input: TicketSharedDraftStartInput!) {
- ticketSharedDraftStartCreate(name: $name, input: $input) {
- sharedDraft {
- id
- }
- errors {
- message
- field
- }
- }
- }
- QUERY
- end
- context 'with an agent', authenticated_as: :agent do
- let(:agent) do
- create(:agent)
- .tap { |elem| elem.user_groups.create!(group:, access: :create) }
- end
- context 'when agent has access to the draft group' do
- it 'returns new object' do
- gql.execute(query, variables:)
- draft = Gql::ZammadSchema.verified_object_from_id(
- gql.result.data.dig('sharedDraft', 'id'),
- type: Ticket::SharedDraftStart
- )
- expect(draft).to have_attributes(name:, content:, group:)
- end
- end
- end
- it_behaves_like 'graphql responds with error if unauthenticated' do
- before do
- gql.execute(query, variables:)
- end
- end
- end
|