123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- # Copyright (C) 2012-2025 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
|