123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe 'Assist agent/customer to prevent duplicate ticket creation #4592', authenticated_as: :authenticate, type: :system do
- let(:permitted_group1) { create(:group) }
- let(:permitted_group2) { create(:group) }
- let(:non_permitted_group) { create(:group) }
- let(:current_user) { create(:agent, groups: [permitted_group1, permitted_group2]) }
- let(:customer) { create(:customer) }
- let(:ticket1) { create(:ticket, customer: customer, group: permitted_group1, title: '123') }
- let(:ticket2) { create(:ticket, customer: customer, group: permitted_group2, title: 'ABC') }
- let(:ticket3) { create(:ticket, group: non_permitted_group, title: '123') }
- let(:ticket4) { create(:ticket, group: non_permitted_group, title: 'XXX') }
- let(:attributes) { %w[group_id title] }
- let(:show_tickets) { true }
- let(:permission_level) { 'user' }
- let(:role_ids) { [Role.find_by(name: 'Agent').id] }
- let(:route) { 'ticket/create' }
- def authenticate
- create_text_attribute if defined?(create_text_attribute)
- ticket1 && ticket2 && ticket3 && ticket4
- Setting.set('ticket_duplicate_detection', true)
- Setting.set('ticket_duplicate_detection_attributes', attributes)
- Setting.set('ticket_duplicate_detection_show_tickets', show_tickets)
- Setting.set('ticket_duplicate_detection_permission_level', permission_level)
- Setting.set('ticket_duplicate_detection_role_ids', role_ids)
- current_user
- end
- before do
- visit route
- end
- shared_examples 'showing a warning' do
- it 'shows a warning' do
- find('[name="title"]').send_keys title, :tab if defined?(title)
- set_tree_select_value('group_id', group.name) if defined?(group)
- find('[name="text_attribute"]').send_keys text_attribute, :tab if defined?(text_attribute)
- expect(page).to have_text 'Similar tickets found'
- expect(page).to have_text 'Tickets with the same attributes were found.'
- shown_tickets.each do |ticket|
- expect(page).to have_text ticket.number
- end
- hidden_tickets.each do |ticket|
- expect(page).to have_no_text ticket.number
- end
- end
- end
- shared_examples 'showing no warning' do
- it 'shows no warning' do
- find('[name="title"]').send_keys title, :tab
- set_tree_select_value('group_id', group.name)
- expect(page).to have_no_text 'Similar tickets found'
- end
- end
- context 'with matching attributes shows a warning and accessible tickets only' do
- let(:title) { '123' }
- let(:group) { permitted_group1 }
- let(:shown_tickets) { [ticket1] }
- let(:hidden_tickets) { [ticket2, ticket3, ticket4] }
- it_behaves_like 'showing a warning'
- end
- context 'with non-matching attributes shows no warning' do
- let(:title) { '123' }
- let(:group) { permitted_group2 }
- it_behaves_like 'showing no warning'
- end
- context 'with matching attributes but no access to the tickets shows no warning' do
- let(:title) { 'XXX' }
- let(:group) { permitted_group1 }
- it_behaves_like 'showing no warning'
- end
- context 'with no tickets shown in the warning' do
- let(:show_tickets) { false }
- context 'with matching attributes shows a warning without tickets' do
- let(:title) { '123' }
- let(:group) { permitted_group1 }
- let(:shown_tickets) { [] }
- let(:hidden_tickets) { [ticket1, ticket2, ticket3, ticket4] }
- it_behaves_like 'showing a warning'
- end
- end
- context 'with permission level system' do
- let(:attributes) { ['title'] }
- let(:permission_level) { 'system' }
- context 'with matching attributes shows a warning and accessible tickets only' do
- let(:title) { '123' }
- let(:shown_tickets) { [ticket1] }
- let(:hidden_tickets) { [ticket2, ticket3, ticket4] }
- it_behaves_like 'showing a warning'
- end
- end
- context 'with permission level user' do
- let(:attributes) { ['title'] }
- context 'with matching attributes shows a warning and accessible tickets only' do
- let(:title) { '123' }
- let(:shown_tickets) { [ticket1] }
- let(:hidden_tickets) { [ticket2, ticket3, ticket4] }
- it_behaves_like 'showing a warning'
- end
- end
- context 'with customer user' do
- let(:current_user) { customer }
- let(:role_ids) { [Role.find_by(name: 'Customer').id] }
- let(:route) { 'customer_ticket_new' }
- context 'with matching attributes shows a warning and accessible tickets only' do
- let(:title) { '123' }
- let(:group) { permitted_group1 }
- let(:shown_tickets) { [ticket1] }
- let(:hidden_tickets) { [ticket2, ticket3, ticket4] }
- it_behaves_like 'showing a warning'
- end
- end
- context 'with custom object attribute', db_strategy: :reset do
- let(:attributes) { ['text_attribute'] }
- let(:ticket1) { create(:ticket, customer: customer, group: permitted_group1, title: '123', text_attribute: text_attribute) }
- let(:ticket2) { create(:ticket, customer: customer, group: permitted_group2, title: 'ABC', text_attribute: 'baz qux') }
- let(:ticket3) { create(:ticket, group: non_permitted_group, title: '123', text_attribute: text_attribute) }
- let(:ticket4) { create(:ticket, group: non_permitted_group, title: '123', text_attribute: text_attribute) }
- def create_text_attribute
- create(:object_manager_attribute_text, :required_screen, name: 'text_attribute', display: 'Text Attribute', data_option: {
- 'type' => 'text',
- 'maxlength' => 255,
- 'null' => true,
- 'translate' => false,
- 'default' => '',
- 'options' => {},
- 'relation' => '',
- })
- ObjectManager::Attribute.migration_execute
- end
- context 'with matching attributes shows a warning and accessible tickets only' do
- let(:text_attribute) { 'foobar' }
- let(:shown_tickets) { [ticket1] }
- let(:hidden_tickets) { [ticket2, ticket3, ticket4] }
- it_behaves_like 'showing a warning'
- end
- end
- end
|