trabajo-afectivo/spec/models/ticket/number/increment_spec.rb

125 lines
4.4 KiB
Ruby

# Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/
require 'rails_helper'
RSpec.describe Ticket::Number::Increment do
describe '.generate' do
let(:number) { described_class.generate }
let(:system_id) { Setting.get('system_id') }
let(:ticket_count) { Ticket::Counter.find_by(generator: 'Increment').content }
it 'updates the "Increment" Ticket::Counter' do
expect { number }
.to change { Ticket::Counter.find_by(generator: 'Increment').content }
end
context 'with a "ticket_number_increment" setting with...' do
context 'min_size: 5' do
before { Setting.set('ticket_number_increment', { min_size: 5 }) }
it 'returns a 5-character string' do
expect(number).to be_a(String)
expect(number.length).to be(5)
end
context 'when "system_id" setting exceeds :min_size' do
before { Setting.set('system_id', 123_456) }
it 'still adheres to numbering pattern (and does not require padding zeroes)' do
expect(number).to match(%r{^#{system_id}#{ticket_count}$})
end
end
it 'returns a string following the pattern system_id + padding zeroes + ticket_count' do
expect(number).to match(%r{^#{system_id}0*#{ticket_count}$})
end
context '/ checksum: false (default)' do
before { Setting.set('ticket_number_increment', { min_size: 5, checksum: false }) }
it 'returns a 5-character string' do
expect(number).to be_a(String)
expect(number.length).to be(5)
end
it 'returns a string following the pattern system_id + padding zeroes + ticket_counter' do
expect(number).to match(%r{^#{system_id}0*#{ticket_count}$})
end
context 'when "system_id" setting exceeds :min_size' do
before { Setting.set('system_id', 123_456) }
it 'still adheres to numbering pattern (and does not require padding zeroes)' do
expect(number).to match(%r{^#{system_id}#{ticket_count}$})
end
end
end
context '/ checksum: true' do
before { Setting.set('ticket_number_increment', { min_size: 5, checksum: true }) }
it 'returns a 5-character string' do
expect(number).to be_a(String)
expect(number).to eq(number.to_i.to_s)
expect(number.length).to be(5)
end
it 'returns a string following the pattern system_id + padding zeroes + ticket_counter + checksum' do
expect(number).to match(%r{^#{system_id}0*#{ticket_count}\d$})
end
context 'when "system_id" setting exceeds :min_size' do
before { Setting.set('system_id', 123_456) }
it 'still adheres to numbering pattern (and does not require padding zeroes)' do
expect(number).to match(%r{^#{system_id}#{ticket_count}\d$})
end
end
end
end
end
end
describe '.check' do
context 'for tickets with increment-style numbers' do
let(:ticket) do
# There might be conflicts with the hardcoded ticket number
# and the one from the welcome ticket, so use find_by || create.
Ticket.find_by(number: ticket_number) || create(:ticket, number: ticket_number)
end
let(:ticket_number) { "#{Setting.get('system_id')}0001" }
let(:check_query) { ticket.subject_build(ticket.title) }
context 'when system_id is the same as when ticket was created' do
before do
Setting.set('system_id', 1)
ticket # create ticket
end
it 'returns the ticket matching the number in the given string' do
expect(described_class.check(check_query)).to eq(ticket)
end
end
context 'when system_id is different from when ticket was created' do
before do
Setting.set('system_id', 1)
ticket # create ticket
Setting.set('system_id', 999)
end
it 'returns nil' do
expect(described_class.check(check_query)).to be_nil
end
context 'and "ticket_number_ignore_system_id" is true' do
before { Setting.set('ticket_number_ignore_system_id', true) }
it 'returns the ticket matching the number in the given string' do
expect(described_class.check(check_query)).to eq(ticket)
end
end
end
end
end
end