8ea0660862
- Add reauthorization prompt for Whatsapp Channel fixes: #5782
151 lines
6.1 KiB
Ruby
151 lines
6.1 KiB
Ruby
require 'rails_helper'
|
|
|
|
RSpec.describe Webhooks::WhatsappEventsJob, type: :job do
|
|
subject(:job) { described_class }
|
|
|
|
let(:channel) { create(:channel_whatsapp, provider: 'whatsapp_cloud', sync_templates: false, validate_provider_config: false) }
|
|
let(:params) { { phone_number: channel.phone_number } }
|
|
let(:process_service) { double }
|
|
|
|
before do
|
|
allow(process_service).to receive(:perform)
|
|
end
|
|
|
|
it 'enqueues the job' do
|
|
expect { job.perform_later(params) }.to have_enqueued_job(described_class)
|
|
.with(params)
|
|
.on_queue('default')
|
|
end
|
|
|
|
context 'when whatsapp_cloud provider' do
|
|
it 'enques Whatsapp::IncomingMessageWhatsappCloudService' do
|
|
allow(Whatsapp::IncomingMessageWhatsappCloudService).to receive(:new).and_return(process_service)
|
|
expect(Whatsapp::IncomingMessageWhatsappCloudService).to receive(:new)
|
|
job.perform_now(params)
|
|
end
|
|
|
|
it 'will not enques Whatsapp::IncomingMessageWhatsappCloudService if channel reauthorization required' do
|
|
channel.prompt_reauthorization!
|
|
allow(Whatsapp::IncomingMessageWhatsappCloudService).to receive(:new).and_return(process_service)
|
|
expect(Whatsapp::IncomingMessageWhatsappCloudService).not_to receive(:new)
|
|
job.perform_now(params)
|
|
end
|
|
end
|
|
|
|
context 'when default provider' do
|
|
it 'enques Whatsapp::IncomingMessageService' do
|
|
stub_request(:post, 'https://waba.360dialog.io/v1/configs/webhook')
|
|
channel.update(provider: 'default')
|
|
allow(Whatsapp::IncomingMessageService).to receive(:new).and_return(process_service)
|
|
expect(Whatsapp::IncomingMessageService).to receive(:new)
|
|
job.perform_now(params)
|
|
end
|
|
end
|
|
|
|
context 'when whatsapp business params' do
|
|
it 'enques Whatsapp::IncomingMessageWhatsappCloudService based on the number in payload' do
|
|
other_channel = create(:channel_whatsapp, phone_number: '+1987654', provider: 'whatsapp_cloud', sync_templates: false,
|
|
validate_provider_config: false)
|
|
wb_params = {
|
|
phone_number: channel.phone_number,
|
|
object: 'whatsapp_business_account',
|
|
entry: [
|
|
{
|
|
changes: [
|
|
{
|
|
value: {
|
|
metadata: {
|
|
phone_number_id: other_channel.provider_config['phone_number_id'],
|
|
display_phone_number: other_channel.phone_number.delete('+')
|
|
}
|
|
}
|
|
}
|
|
]
|
|
}
|
|
]
|
|
}
|
|
allow(Whatsapp::IncomingMessageWhatsappCloudService).to receive(:new).and_return(process_service)
|
|
expect(Whatsapp::IncomingMessageWhatsappCloudService).to receive(:new).with(inbox: other_channel.inbox, params: wb_params)
|
|
job.perform_now(wb_params)
|
|
end
|
|
|
|
it 'Ignore reaction type message and stop raising error' do
|
|
other_channel = create(:channel_whatsapp, phone_number: '+1987654', provider: 'whatsapp_cloud', sync_templates: false,
|
|
validate_provider_config: false)
|
|
wb_params = {
|
|
phone_number: channel.phone_number,
|
|
object: 'whatsapp_business_account',
|
|
entry: [{
|
|
changes: [{
|
|
value: {
|
|
contacts: [{ profile: { name: 'Test Test' }, wa_id: '1111981136571' }],
|
|
messages: [{
|
|
from: '1111981136571', reaction: { emoji: '👍' }, timestamp: '1664799904', type: 'reaction'
|
|
}],
|
|
metadata: {
|
|
phone_number_id: other_channel.provider_config['phone_number_id'],
|
|
display_phone_number: other_channel.phone_number.delete('+')
|
|
}
|
|
}
|
|
}]
|
|
}]
|
|
}.with_indifferent_access
|
|
expect do
|
|
Whatsapp::IncomingMessageWhatsappCloudService.new(inbox: other_channel.inbox, params: wb_params).perform
|
|
end.not_to change(Message, :count)
|
|
end
|
|
|
|
it 'Ignore contacts type message and stop raising error' do
|
|
other_channel = create(:channel_whatsapp, phone_number: '+1987654', provider: 'whatsapp_cloud', sync_templates: false,
|
|
validate_provider_config: false)
|
|
wb_params = {
|
|
phone_number: channel.phone_number,
|
|
object: 'whatsapp_business_account',
|
|
entry: [{
|
|
changes: [{
|
|
value: {
|
|
contacts: [{ profile: { name: 'Test Test' }, wa_id: '1111981136571' }],
|
|
messages: [{ from: '1111981136571',
|
|
contacts: [{ phones: [{ phone: '+1987654' }], name: { first_name: 'contact name' } }],
|
|
timestamp: '1664799904',
|
|
type: 'contacts' }],
|
|
metadata: {
|
|
phone_number_id: other_channel.provider_config['phone_number_id'],
|
|
display_phone_number: other_channel.phone_number.delete('+')
|
|
}
|
|
}
|
|
}]
|
|
}]
|
|
}.with_indifferent_access
|
|
expect do
|
|
Whatsapp::IncomingMessageWhatsappCloudService.new(inbox: other_channel.inbox, params: wb_params).perform
|
|
end.not_to change(Message, :count)
|
|
end
|
|
|
|
it 'will not enque Whatsapp::IncomingMessageWhatsappCloudService when invalid phone number id' do
|
|
other_channel = create(:channel_whatsapp, phone_number: '+1987654', provider: 'whatsapp_cloud', sync_templates: false,
|
|
validate_provider_config: false)
|
|
wb_params = {
|
|
phone_number: channel.phone_number,
|
|
object: 'whatsapp_business_account',
|
|
entry: [
|
|
{
|
|
changes: [
|
|
{
|
|
value: {
|
|
metadata: {
|
|
phone_number_id: 'random phone number id',
|
|
display_phone_number: other_channel.phone_number.delete('+')
|
|
}
|
|
}
|
|
}
|
|
]
|
|
}
|
|
]
|
|
}
|
|
allow(Whatsapp::IncomingMessageWhatsappCloudService).to receive(:new).and_return(process_service)
|
|
expect(Whatsapp::IncomingMessageWhatsappCloudService).not_to receive(:new).with(inbox: other_channel.inbox, params: wb_params)
|
|
job.perform_now(wb_params)
|
|
end
|
|
end
|
|
end
|