trabajo-afectivo/spec/requests/tickets_mass_spec.rb
2022-01-01 14:38:12 +01:00

90 lines
3.2 KiB
Ruby

# Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/
require 'rails_helper'
RSpec.describe 'TicketsMass', type: :request, authenticated_as: :user do
let(:user) { create(:agent, groups: [group_a, group_b]) }
let(:owner) { create(:agent) }
let(:group_a) { create(:group) }
let(:group_b) { create(:group) }
let(:group_c) { create(:group) }
let(:ticket_a) { create(:ticket, group: group_a, owner: owner) }
let(:ticket_b) { create(:ticket, group: group_b, owner: owner) }
let(:ticket_c) { create(:ticket, group: group_c, owner: owner) }
let(:core_workflow) do
create(:core_workflow, :active_and_screen, :condition_group, :perform_action, group: group_b)
end
describe 'POST /tickets/mass_macro' do
let(:macro_perform) do
{
'ticket.priority_id': { pre_condition: 'specific', value: 3.to_s }
}
end
let(:macro) { create :macro, perform: macro_perform }
let(:macro_groups) { create :macro, groups: [group_a], perform: macro_perform }
it 'applies macro' do
post '/api/v1/tickets/mass_macro', params: { macro_id: macro.id, ticket_ids: [ticket_a.id] }
expect(ticket_a.reload.priority_id).to eq 3
end
it 'does not apply changes if one of ticket updates fail' do
core_workflow
post '/api/v1/tickets/mass_macro', params: { macro_id: macro.id, ticket_ids: [ticket_a.id, ticket_b.id] }, as: :json
expect(ticket_a.reload.articles).not_to eq 3
end
it 'returns error if macro not applicable to at least one ticket' do
post '/api/v1/tickets/mass_macro', params: { macro_id: macro_groups.id, ticket_ids: [ticket_a.id, ticket_b.id] }
expect(response).to have_http_status(:unprocessable_entity)
end
it 'checks if user has write access to tickets' do
post '/api/v1/tickets/mass_macro', params: { macro_id: macro_groups.id, ticket_ids: [ticket_a.id, ticket_c.id] }
expect(response).to have_http_status(:unprocessable_entity)
end
end
describe 'POST /tickets/mass_update' do
it 'applies changes' do
post '/api/v1/tickets/mass_update', params: { attributes: { priority_id: 3 }, ticket_ids: [ticket_a.id] }
expect(ticket_a.reload.priority_id).to eq 3
end
it 'does not apply changes' do
post '/api/v1/tickets/mass_update', params: { attributes: { priority_id: 3 }, ticket_ids: [ticket_c.id] }
expect(ticket_c.reload.priority_id).not_to eq 3
end
it 'adds note' do
post '/api/v1/tickets/mass_update', params: { attributes: {}, article: { body: 'test mass update body' }, ticket_ids: [ticket_a.id] }
expect(ticket_a.reload.articles.last).to have_attributes(body: 'test mass update body')
end
it 'does not apply changes if one of ticket updates fail' do
core_workflow
post '/api/v1/tickets/mass_update', params: { attributes: { priority_id: 3 }, ticket_ids: [ticket_a.id, ticket_b.id] }
expect(ticket_a.reload.priority_id).not_to eq 3
end
it 'checks if user has write access to tickets' do
post '/api/v1/tickets/mass_update', params: { attributes: { priority_id: 3 }, ticket_ids: [ticket_a.id, ticket_c.id] }
expect(response).to have_http_status(:unprocessable_entity)
end
end
end