1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147 |
- RSpec.shared_examples 'Ticket::Escalation' do
- describe '#update_escalation_information callback' do
- context 'with standard incoming email with active SLA' do
- subject(:ticket) { create(:ticket, created_at: '2013-03-21 09:30:00 UTC', updated_at: '2013-03-21 09:30:00 UTC') }
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['08:00', '18:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['08:00', '18:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['08:00', '18:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['08:00', '18:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['08:00', '18:00'] ]
- },
- sat: {
- active: false,
- timeframes: [ ['08:00', '17:00'] ]
- },
- sun: {
- active: false,
- timeframes: [ ['08:00', '17:00'] ]
- },
- })
- end
- let(:sla) { create(:sla, calendar: calendar, first_response_time: 60, update_time: 120, solution_time: 180) }
- let(:article) { create(:'ticket/article', :inbound_email, ticket: ticket, created_at: '2013-03-21 09:30:00 UTC', updated_at: '2013-03-21 09:30:00 UTC') }
- before do
- sla
- ticket
- article
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 10:30:00 UTC')
- expect(ticket.first_response_escalation_at.gmtime.to_s).to eq('2013-03-21 10:30:00 UTC')
- expect(ticket.first_response_at).to be_nil
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2013-03-21 11:30:00 UTC')
- expect(ticket.update_in_min).to be_nil
- expect(ticket.update_diff_in_min).to be_nil
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- context 'with first response time resolved by answer + state pending reminder' do
- before do
- ticket.update(state: Ticket::State.find_by(name: 'pending reminder'))
- create(:'ticket/article', :outbound_email, ticket: ticket, created_at: '2013-03-21 09:45:00 UTC', updated_at: '2013-03-21 09:45:00 UTC')
- end
- it 'does set first_response_diff_in_min' do
- expect(ticket.reload.first_response_diff_in_min).to eq(45)
- end
- end
- context 'with first response in time' do
- before do
- ticket.update!(
- first_response_at: '2013-03-21 10:00:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 11:30:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 10:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(30)
- expect(ticket.first_response_diff_in_min).to eq(30)
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2013-03-21 11:30:00 UTC')
- expect(ticket.update_in_min).to be_nil
- expect(ticket.update_diff_in_min).to be_nil
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- end
- context 'with first response over time' do
- before do
- ticket.update!(
- first_response_at: '2013-03-21 14:00:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 11:30:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 14:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(270)
- expect(ticket.first_response_diff_in_min).to eq(-210)
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2013-03-21 11:30:00 UTC')
- expect(ticket.update_in_min).to be_nil
- expect(ticket.update_diff_in_min).to be_nil
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- end
- context 'with first response over time and update time in time' do
- before do
- # set first response over time
- ticket.update!(
- first_response_at: '2013-03-21 14:00:00 UTC',
- )
- ticket.reload
- # set update time in time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 11:00:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 14:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(270)
- expect(ticket.first_response_diff_in_min).to eq(-210)
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.update_in_min).to eq(90)
- expect(ticket.update_diff_in_min).to eq(30)
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- end
- context 'with first response over time and update time over time' do
- before do
- # set first response over time
- ticket.update!(
- first_response_at: '2013-03-21 14:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:00:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 14:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(270)
- expect(ticket.first_response_diff_in_min).to eq(-210)
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.update_in_min).to eq(150)
- expect(ticket.update_diff_in_min).to eq(-30)
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- end
- context 'with first response over time and update time over time and customer reply' do
- before do
- # set first response over time
- ticket.update!(
- first_response_at: '2013-03-21 14:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_customer_at: '2013-03-21 12:05:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 14:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(270)
- expect(ticket.first_response_diff_in_min).to eq(-210)
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2013-03-21 14:05:00 UTC')
- expect(ticket.update_in_min).to eq(150)
- expect(ticket.update_diff_in_min).to eq(-30)
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- end
- context 'with first response over time and update time over time and customer reply with agent response' do
- before do
- # set first response over time
- ticket.update!(
- first_response_at: '2013-03-21 14:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_customer_at: '2013-03-21 12:05:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:10:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 14:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(270)
- expect(ticket.first_response_diff_in_min).to eq(-210)
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.update_in_min).to eq(150)
- expect(ticket.update_diff_in_min).to eq(-30)
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 12:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- end
- context 'with first response over time and update time over time and customer reply with agent response and closed in time' do
- before do
- # set first response over time
- ticket.update!(
- first_response_at: '2013-03-21 14:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_customer_at: '2013-03-21 12:05:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:10:00 UTC',
- )
- ticket.reload
- # set close time in time
- ticket.update!(
- close_at: '2013-03-21 11:30:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- # straight escalation after closing
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 14:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(270)
- expect(ticket.first_response_diff_in_min).to eq(-210)
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.update_in_min).to eq(150)
- expect(ticket.update_diff_in_min).to eq(-30)
- expect(ticket.close_escalation_at).to be_nil
- expect(ticket.close_in_min).to eq(120)
- expect(ticket.close_diff_in_min).to eq(60)
- end
- end
- context 'with first response over time and update time over time and customer reply with agent response and closed over time' do
- before do
- # set first response over time
- ticket.update!(
- first_response_at: '2013-03-21 14:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:00:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_customer_at: '2013-03-21 12:05:00 UTC',
- )
- ticket.reload
- # set update time over time
- ticket.update!(
- last_contact_agent_at: '2013-03-21 12:10:00 UTC',
- )
- ticket.reload
- # set close time over time
- ticket.update!(
- close_at: '2013-03-21 13:00:00 UTC',
- )
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at.gmtime.to_s).to eq('2013-03-21 14:00:00 UTC')
- expect(ticket.first_response_in_min).to eq(270)
- expect(ticket.first_response_diff_in_min).to eq(-210)
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.update_in_min).to eq(150)
- expect(ticket.update_diff_in_min).to eq(-30)
- expect(ticket.close_escalation_at).to be_nil
- expect(ticket.close_in_min).to eq(210)
- expect(ticket.close_diff_in_min).to eq(-30)
- end
- end
- end
- context 'when SLA no longer matches' do
- subject(:ticket) { create(:ticket, priority: priorty_matching, created_at: '2013-03-21 09:30:00 UTC', updated_at: '2013-03-21 09:30:00 UTC') }
- let(:priorty_matching) { create(:'ticket/priority') }
- let(:priorty_not_matching) { create(:'ticket/priority') }
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['09:00', '17:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['09:00', '17:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['09:00', '17:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['09:00', '17:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['09:00', '17:00'] ]
- },
- sat: {
- active: false,
- timeframes: [ ['08:00', '17:00'] ]
- },
- sun: {
- active: false,
- timeframes: [ ['08:00', '17:00'] ]
- },
- })
- end
- let(:sla) do
- create(:sla,
- calendar: calendar,
- condition: {
- 'ticket.priority_id' => {
- operator: 'is',
- value: priorty_matching.id.to_s,
- },
- },
- first_response_time: 60,
- update_time: 180,
- solution_time: 240)
- end
- it 'removes/resets the escalation attributes' do
- sla
- ticket.reload # read as: ticket; ticket.reload
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-03-21 10:30:00 UTC')
- expect(ticket.first_response_escalation_at.gmtime.to_s).to eq('2013-03-21 10:30:00 UTC')
- expect(ticket.first_response_at).to be_nil
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.update_in_min).to be_nil
- expect(ticket.update_diff_in_min).to be_nil
- expect(ticket.close_escalation_at.gmtime.to_s).to eq('2013-03-21 13:30:00 UTC')
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- ticket.update!(priority: priorty_not_matching)
- ticket.reload
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_at).to be_nil
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.update_in_min).to be_nil
- expect(ticket.update_diff_in_min).to be_nil
- expect(ticket.close_escalation_at).to be_nil
- expect(ticket.close_in_min).to be_nil
- expect(ticket.close_diff_in_min).to be_nil
- end
- end
- context 'when Ticket state changes (escalation suspense)' do
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sat: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sun: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- })
- end
- let(:sla) { create(:sla, calendar: calendar, first_response_time: 120, update_time: 180, solution_time: 250) }
- context 'when Ticket is reopened' do
- subject(:ticket) { create(:ticket, created_at: '2013-06-04 09:00:00 UTC', updated_at: '2013-06-04 09:00:00 UTC') }
- before do
- # set ticket at 09:30 to pending
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o: ticket,
- id_from: Ticket::State.lookup(name: 'open').id,
- id_to: Ticket::State.lookup(name: 'pending reminder').id,
- value_from: 'open',
- value_to: 'pending reminder',
- created_at: '2013-06-04 09:30:00 UTC',
- updated_at: '2013-06-04 09:30:00 UTC',)
- # set ticket at 09:45 to open
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o: ticket,
- id_from: Ticket::State.lookup(name: 'pending reminder').id,
- id_to: Ticket::State.lookup(name: 'open').id,
- value_from: 'pending reminder',
- value_to: 'open',
- created_at: '2013-06-04 09:45:00 UTC',
- updated_at: '2013-06-04 09:45:00 UTC',)
- # set ticket at 10:00 to closed
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o: ticket,
- id_from: Ticket::State.lookup(name: 'open').id,
- id_to: Ticket::State.lookup(name: 'closed').id,
- value_from: 'open',
- value_to: 'closed',
- created_at: '2013-06-04 10:00:00 UTC',
- updated_at: '2013-06-04 10:00:00 UTC',)
- # set ticket at 10:30 to open
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o: ticket,
- id_from: Ticket::State.lookup(name: 'closed').id,
- id_to: Ticket::State.lookup(name: 'open').id,
- value_from: 'closed',
- value_to: 'open',
- created_at: '2013-06-04 10:30:00 UTC',
- updated_at: '2013-06-04 10:30:00 UTC',)
- sla
- ticket.escalation_calculation
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-06-04 11:45:00 UTC')
- expect(ticket.first_response_escalation_at.gmtime.to_s).to eq('2013-06-04 11:45:00 UTC')
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- end
- end
- context 'when Ticket transitions from pending to open' do
- subject(:ticket) { create(:ticket, created_at: '2013-06-04 09:00:00 UTC', updated_at: '2013-06-04 09:00:00 UTC') }
- before do
- sla
- # set ticket at 10:00 to pending
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_from: Ticket::State.lookup(name: 'open').id,
- id_to: Ticket::State.lookup(name: 'pending reminder').id,
- value_from: 'open',
- value_to: 'pending reminder',
- created_at: '2013-06-04 10:00:00 UTC',
- updated_at: '2013-06-04 10:00:00 UTC',)
- # set ticket at 15:00 to open
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_from: Ticket::State.lookup(name: 'pending reminder').id,
- id_to: Ticket::State.lookup(name: 'open').id,
- value_from: 'pending reminder',
- value_to: 'open',
- created_at: '2013-06-04 15:00:00 UTC',
- updated_at: '2013-06-04 15:00:00 UTC',)
- ticket.escalation_calculation
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at.gmtime.to_s).to eq('2013-06-05 07:00:00 UTC')
- expect(ticket.first_response_escalation_at.gmtime.to_s).to eq('2013-06-05 07:00:00 UTC')
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- end
- end
- context 'when Ticket transitions from open to pending to open, response and close' do
- subject(:ticket) { create(:ticket, created_at: '2013-06-04 09:00:00 UTC', updated_at: '2013-06-04 09:00:00 UTC') }
- # set sla's for timezone "Europe/Berlin" summertime (+2), so UTC times are 7:00-16:00
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sat: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sun: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- })
- end
- let(:sla) { create(:sla, condition: {}, calendar: calendar, first_response_time: 120, update_time: 180, solution_time: 250) }
- before do
- sla
- # set ticket at 10:00 to pending
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 3,
- id_from: 2,
- value_from: 'open',
- value_to: 'pending reminder',
- created_at: '2013-06-04 10:00:00 UTC',
- updated_at: '2013-06-04 10:00:00 UTC',)
- # set ticket at 10:30 to open
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 2,
- id_from: 3,
- value_from: 'pending reminder',
- value_to: 'open',
- created_at: '2013-06-04 10:30:00 UTC',
- updated_at: '2013-06-04 10:30:00 UTC')
- # set update time
- ticket.update!(
- last_contact_agent_at: '2013-06-04 10:15:00 UTC',
- )
- # set first response time
- ticket.update!(
- first_response_at: '2013-06-04 10:45:00 UTC',
- )
- # set ticket from 11:30 to closed
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 3,
- id_from: 2,
- value_from: 'open',
- value_to: 'closed',
- created_at: '2013-06-04 12:00:00 UTC',
- updated_at: '2013-06-04 12:00:00 UTC')
- ticket.update!(
- close_at: '2013-06-04 12:00:00 UTC',
- )
- ticket.escalation_calculation
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_in_min).to eq(75)
- expect(ticket.first_response_diff_in_min).to eq(45)
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.close_escalation_at).to be_nil
- expect(ticket.close_in_min).to eq(150)
- expect(ticket.close_diff_in_min).to eq(100)
- end
- end
- context 'when Ticket is created in state pending and closed without reopen or state change' do
- subject(:ticket) { create(:ticket, state: Ticket::State.lookup(name: 'pending reminder'), created_at: '2013-06-04 09:00:00 UTC', updated_at: '2013-06-04 09:00:00 UTC') }
- # set sla's for timezone "Europe/Berlin" summertime (+2), so UTC times are 7:00-16:00
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sat: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sun: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- })
- end
- let(:sla) { create(:sla, condition: {}, calendar: calendar, first_response_time: 120, update_time: 180, solution_time: 240) }
- before do
- sla
- # set ticket from 11:30 to closed
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 4,
- id_from: 3,
- value_from: 'pending reminder',
- value_to: 'closed',
- created_at: '2013-06-04 12:00:00 UTC',
- updated_at: '2013-06-04 12:00:00 UTC',)
- ticket.update!(
- close_at: '2013-06-04 12:00:00 UTC',
- )
- ticket.escalation_calculation
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.close_escalation_at).to be_nil
- expect(ticket.close_in_min).to eq(0)
- expect(ticket.close_diff_in_min).to eq(240)
- end
- end
- context 'when Ticket created in state pending, changed state to openen, back to pending and closed' do
- subject(:ticket) { create(:ticket, state: Ticket::State.lookup(name: 'pending reminder'), created_at: '2013-06-04 09:00:00 UTC', updated_at: '2013-06-04 09:00:00 UTC') }
- # set sla's for timezone "Europe/Berlin" summertime (+2), so UTC times are 7:00-16:00
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sat: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sun: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- })
- end
- let(:sla) { create(:sla, condition: {}, calendar: calendar, first_response_time: 120, update_time: 180, solution_time: 240) }
- before do
- sla
- # state change to open 10:30
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 2,
- id_from: 3,
- value_from: 'pending reminder',
- value_to: 'open',
- created_at: '2013-06-04 10:30:00 UTC',
- updated_at: '2013-06-04 10:30:00 UTC',)
- # state change to pending 11:00
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 3,
- id_from: 2,
- value_from: 'open',
- value_to: 'pending reminder',
- created_at: '2013-06-04 11:00:00 UTC',
- updated_at: '2013-06-04 11:00:00 UTC',)
- # set ticket from 12:00 to closed
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 4,
- id_from: 3,
- value_from: 'pending reminder',
- value_to: 'closed',
- created_at: '2013-06-04 12:00:00 UTC',
- updated_at: '2013-06-04 12:00:00 UTC',)
- ticket.update!(
- close_at: '2013-06-04 12:00:00 UTC',
- )
- ticket.escalation_calculation
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.close_escalation_at).to be_nil
- expect(ticket.close_in_min).to eq(30)
- expect(ticket.close_diff_in_min).to eq(210)
- end
- end
- context 'when Test Ticket created in state pending, changed state to openen, back to pending and back to open then - close ticket' do
- subject(:ticket) { create(:ticket, state: Ticket::State.lookup(name: 'pending reminder'), created_at: '2013-06-04 09:00:00 UTC', updated_at: '2013-06-04 09:00:00 UTC') }
- # set sla's for timezone "Europe/Berlin" summertime (+2), so UTC times are 7:00-16:00
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sat: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- sun: {
- active: true,
- timeframes: [ ['09:00', '18:00'] ]
- },
- })
- end
- let(:sla) { create(:sla, condition: {}, calendar: calendar, first_response_time: 120, update_time: 180, solution_time: 240) }
- before do
- sla
- # state change to open from pending
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 2,
- id_from: 3,
- value_from: 'pending reminder',
- value_to: 'open',
- created_at: '2013-06-04 10:30:00 UTC',
- updated_at: '2013-06-04 10:30:00 UTC',)
- # state change to pending from open 11:00
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 3,
- id_from: 2,
- value_from: 'open',
- value_to: 'pending reminder',
- created_at: '2013-06-04 11:00:00 UTC',
- updated_at: '2013-06-04 11:00:00 UTC',)
- # state change to open 11:30
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 2,
- id_from: 3,
- value_from: 'pending reminder',
- value_to: 'open',
- created_at: '2013-06-04 11:30:00 UTC',
- updated_at: '2013-06-04 11:30:00 UTC',)
- # set ticket from open to closed 12:00
- create(:history,
- history_type: 'updated',
- history_attribute: 'state',
- o_id: ticket.id,
- id_to: 4,
- id_from: 3,
- value_from: 'open',
- value_to: 'closed',
- created_at: '2013-06-04 12:00:00 UTC',
- updated_at: '2013-06-04 12:00:00 UTC',)
- ticket.update!(
- close_at: '2013-06-04 12:00:00 UTC',
- )
- ticket.escalation_calculation
- ticket.reload
- end
- it 'calculates escalation_at attributes' do
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.first_response_in_min).to be_nil
- expect(ticket.first_response_diff_in_min).to be_nil
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.close_escalation_at).to be_nil
- expect(ticket.close_in_min).to eq(60)
- expect(ticket.close_diff_in_min).to eq(180)
- end
- end
- end
- context 'when SLA has Calendar with holidays' do
- subject(:ticket) { create(:ticket, created_at: '2016-11-01 13:56:21 UTC', updated_at: '2016-11-01 13:56:21 UTC') }
- # set sla's for timezone "Europe/Berlin" wintertime (+1), so UTC times are 7:00-18:00
- let(:calendar) do
- create(:calendar,
- business_hours: {
- mon: {
- active: true,
- timeframes: [ ['08:00', '20:00'] ]
- },
- tue: {
- active: true,
- timeframes: [ ['08:00', '20:00'] ]
- },
- wed: {
- active: true,
- timeframes: [ ['08:00', '20:00'] ]
- },
- thu: {
- active: true,
- timeframes: [ ['08:00', '20:00'] ]
- },
- fri: {
- active: true,
- timeframes: [ ['08:00', '20:00'] ]
- },
- sat: {
- active: false,
- timeframes: [ ['08:00', '17:00'] ]
- },
- sun: {
- active: false,
- timeframes: [ ['08:00', '17:00'] ]
- },
- },
- public_holidays: {
- '2016-11-01' => {
- 'active' => true,
- 'summary' => 'test 1',
- },
- })
- end
- let(:sla) { create(:sla, condition: {}, calendar: calendar, first_response_time: 120, update_time: 1200, solution_time: nil) }
- before do
- sla
- ticket
- end
- it 'calculates escalation_at attributes' do
- create(:'ticket/article', :inbound_web, ticket: ticket, created_at: '2016-11-01 13:56:21 UTC', updated_at: '2016-11-01 13:56:21 UTC')
- ticket.reload
- expect(ticket.escalation_at.gmtime.to_s).to eq('2016-11-02 09:00:00 UTC')
- expect(ticket.first_response_escalation_at.gmtime.to_s).to eq('2016-11-02 09:00:00 UTC')
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2016-11-03 15:00:00 UTC')
- expect(ticket.close_escalation_at).to be_nil
- ticket.update!(
- state: Ticket::State.lookup(name: 'pending reminder'),
- pending_time: '2016-11-10 07:00:00 UTC',
- updated_at: '2016-11-01 15:25:40 UTC',
- )
- create(:'ticket/article', :outbound_email, ticket: ticket, created_at: '2016-11-01 15:25:40 UTC', updated_at: '2016-11-01 15:25:40 UTC')
- ticket.reload
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.close_escalation_at).to be_nil
- ticket.update!(
- state: Ticket::State.lookup(name: 'open'),
- updated_at: '2016-11-01 15:59:14 UTC',
- )
- create(:'ticket/article', :inbound_email, ticket: ticket, created_at: '2016-11-01 15:59:14 UTC', updated_at: '2016-11-01 15:59:14 UTC')
- ticket.reload
- expect(ticket.escalation_at.gmtime.to_s).to eq('2016-11-03 15:00:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2016-11-03 15:00:00 UTC')
- expect(ticket.close_escalation_at).to be_nil
- ticket.update!(
- state: Ticket::State.lookup(name: 'pending reminder'),
- pending_time: '2016-11-18 07:00:00 UTC',
- updated_at: '2016-11-01 15:59:58 UTC',
- )
- ticket.reload
- expect(ticket.escalation_at).to be_nil
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.update_escalation_at).to be_nil
- expect(ticket.close_escalation_at).to be_nil
- ticket.update!(
- state: Ticket::State.lookup(name: 'open'),
- updated_at: '2016-11-07 13:26:36 UTC',
- )
- create(:'ticket/article', :inbound_email, ticket: ticket, created_at: '2016-11-07 13:26:36 UTC', updated_at: '2016-11-07 13:26:36 UTC')
- ticket.reload
- expect(ticket.escalation_at.gmtime.to_s).to eq('2016-11-09 09:26:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2016-11-09 09:26:00 UTC')
- expect(ticket.close_escalation_at).to be_nil
- create(:'ticket/article', :inbound_email, ticket: ticket, created_at: '2016-11-07 14:26:36 UTC', updated_at: '2016-11-07 14:26:36 UTC')
- ticket.reload
- expect(ticket.escalation_at.gmtime.to_s).to eq('2016-11-09 09:26:00 UTC')
- expect(ticket.first_response_escalation_at).to be_nil
- expect(ticket.update_escalation_at.gmtime.to_s).to eq('2016-11-09 09:26:00 UTC')
- expect(ticket.close_escalation_at).to be_nil
- end
- end
- end
- end
|