123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe Whatsapp::Webhook::Message::Status::Sent, :aggregate_failures, current_user_id: 1 do
- describe '#process' do
- let(:channel) { create(:whatsapp_channel) }
- let(:from) do
- {
- phone: Faker::PhoneNumber.cell_phone_in_e164.delete('+'),
- name: Faker::Name.unique.name,
- }
- end
- let(:json) do
- {
- object: 'whatsapp_business_account',
- entry: [
- {
- id: '260895230431646',
- changes: [
- {
- value: {
- messaging_product: 'whatsapp',
- metadata: {
- display_phone_number: '15551340563',
- phone_number_id: channel.options[:phone_number_id],
- },
- statuses: [
- {
- id: message_id,
- status: 'sent',
- timestamp: '1709577872',
- recipient_id: '15551340563',
- conversation: {
- id: '2f3568fab8879aa0194e66aac1a0618e',
- origin: {
- type: 'service'
- }
- },
- pricing: {
- billable: true,
- pricing_model: 'CBP',
- category: 'service'
- }
- }
- ]
- },
- field: 'messages'
- }
- ]
- }
- ]
- }.to_json
- end
- let(:data) { JSON.parse(json).deep_symbolize_keys }
- let(:article) { create(:whatsapp_article, :inbound, ticket: ticket) }
- let(:ticket) { create(:whatsapp_ticket, channel: channel) }
- let(:message_id) { article.message_id }
- context 'when all data is valid' do
- before { article }
- it 'updates the ticket and article preferences accordingly' do
- described_class.new(data:, channel:).process
- expect(Ticket.last.preferences).to include(
- whatsapp: include(
- timestamp_outgoing: '1709577872',
- )
- )
- expect(Ticket::Article.last.preferences).to include(
- whatsapp: include(
- timestamp_sent: '1709577872',
- ),
- )
- end
- end
- context 'when no related article exists' do
- before { article }
- let(:message_id) { "wamid.#{Faker::Number.unique.number}" }
- it 'raises an error' do
- expect { described_class.new(data:, channel:).process }
- .to raise_error(
- an_instance_of(Whatsapp::Webhook::Payload::ProcessableError)
- .and(
- having_attributes(
- reason: 'No related article found to process the status message on.'
- )
- )
- )
- end
- end
- end
- end
|