123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe Gql::Mutations::Ticket::Article::Delete, :aggregate_failures, type: :graphql do
- let(:ticket) { create(:ticket) }
- let(:article) { create(:ticket_article, :internal_note, ticket: ticket, created_by: user) }
- let(:user) { create(:agent, groups: [ticket.group]) }
- let(:query) do
- <<~QUERY
- mutation ticketArticleDelete($articleId: ID!) {
- ticketArticleDelete(articleId: $articleId) {
- success
- errors {
- message
- field
- }
- }
- }
- QUERY
- end
- let(:variables) do
- {
- articleId: gql.id(article),
- }
- end
- context 'when logged in as an agent', authenticated_as: :user do
- before { article }
- it 'destroys article' do
- expect { gql.execute(query, variables: variables) }
- .to change { Ticket::Article.exists? article.id }
- .to false
- end
- context 'when article cannot be destroyed anymore' do
- before { travel 1.hour }
- it 'fails with Pundit error' do
- travel 1.hour
- expect { gql.execute(query, variables: variables) }
- .not_to change { Ticket::Article.exists? article.id }
- expect(gql.result.error_type).to eq(Pundit::NotAuthorizedError)
- end
- end
- end
- context 'when not logged in' do
- before do
- gql.execute(query, variables: variables)
- end
- it_behaves_like 'graphql responds with error if unauthenticated'
- end
- end
|