12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe Gql::Mutations::Ticket::LiveUser::Delete, :aggregate_failures, type: :graphql do
- context 'when deleting live user entry', authenticated_as: :agent do
- let(:agent) { create(:agent, groups: [ticket.group]) }
- let(:ticket) { create(:ticket) }
- let(:live_user_entry) { create(:taskbar, key: "Ticket-#{ticket.id}", user: agent, app: 'mobile') }
- let(:query) do
- <<~QUERY
- mutation ticketLiveUserDelete($id: ID!, $app: EnumTaskbarApp!) {
- ticketLiveUserDelete(id: $id, app: $app) {
- success
- errors {
- message
- field
- }
- }
- }
- QUERY
- end
- let(:variables) { { id: gql.id(ticket), app: 'mobile' } }
- before do
- live_user_entry
- gql.execute(query, variables: variables)
- end
- context 'when live user entry does exist' do
- it 'does delete' do
- expect(live_user_entry.class).not_to exist(live_user_entry.id)
- end
- it 'returns success' do
- expect(gql.result.data[:success]).to be true
- end
- end
- context 'when live user entry does not exist (user id mismatch)' do
- let(:live_user_entry) { create(:taskbar, key: "Ticket-#{ticket.id}", user: User.find(1)) }
- it 'does not delete' do
- expect(live_user_entry.class).to exist(live_user_entry.id)
- end
- end
- context 'when live user entry does not exist (app mismatch)' do
- let(:live_user_entry) { create(:taskbar, key: "Ticket-#{ticket.id}", user: agent, app: 'desktop') }
- it 'does not delete' do
- expect(live_user_entry.class).to exist(live_user_entry.id)
- end
- end
- it_behaves_like 'graphql responds with error if unauthenticated'
- end
- end
|