chore: Move Whatsapp template sync to cron (#4858)
syncing WhatsApp templates job is moved to a cron job for a better user experience. The Templates are synced at 15-minute intervals now.
This commit is contained in:
20
spec/jobs/channels/whatsapp/templates_sync_job_spec.rb
Normal file
20
spec/jobs/channels/whatsapp/templates_sync_job_spec.rb
Normal file
@@ -0,0 +1,20 @@
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe Channels::Whatsapp::TemplatesSyncJob, type: :job do
|
||||
let(:channel_whatsapp) { create(:channel_whatsapp, sync_templates: false) }
|
||||
|
||||
it 'enqueues the job' do
|
||||
stub_request(:post, 'https://waba.360dialog.io/v1/configs/webhook')
|
||||
expect { described_class.perform_later(channel_whatsapp) }.to have_enqueued_job(described_class)
|
||||
.on_queue('low')
|
||||
end
|
||||
|
||||
context 'when called' do
|
||||
it 'calls sync_templates' do
|
||||
whatsapp_channel = double
|
||||
allow(whatsapp_channel).to receive(:sync_templates).and_return(true)
|
||||
expect(whatsapp_channel).to receive(:sync_templates)
|
||||
described_class.perform_now(whatsapp_channel)
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -0,0 +1,27 @@
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe Channels::Whatsapp::TemplatesSyncSchedulerJob, type: :job do
|
||||
it 'enqueues the job' do
|
||||
expect { described_class.perform_later }.to have_enqueued_job(described_class)
|
||||
.on_queue('low')
|
||||
end
|
||||
|
||||
context 'when called' do
|
||||
it 'schedules templates_sync_jobs for channels where templates need to be updated' do
|
||||
stub_request(:post, 'https://waba.360dialog.io/v1/configs/webhook')
|
||||
non_synced = create(:channel_whatsapp, sync_templates: false, message_templates_last_updated: nil)
|
||||
synced_recently = create(:channel_whatsapp, sync_templates: false, message_templates_last_updated: Time.zone.now)
|
||||
synced_old = create(:channel_whatsapp, sync_templates: false, message_templates_last_updated: 16.minutes.ago)
|
||||
described_class.perform_now
|
||||
expect(Channels::Whatsapp::TemplatesSyncJob).not_to(
|
||||
have_been_enqueued.with(synced_recently).on_queue('low')
|
||||
)
|
||||
expect(Channels::Whatsapp::TemplatesSyncJob).to(
|
||||
have_been_enqueued.with(synced_old).on_queue('low')
|
||||
)
|
||||
expect(Channels::Whatsapp::TemplatesSyncJob).to(
|
||||
have_been_enqueued.with(non_synced).on_queue('low')
|
||||
)
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -66,9 +66,9 @@ RSpec.describe SendReplyJob, type: :job do
|
||||
described_class.perform_now(message.id)
|
||||
end
|
||||
|
||||
it 'calls ::Whatsapp:SendOnWhatsappService when its line message' do
|
||||
it 'calls ::Whatsapp:SendOnWhatsappService when its whatsapp message' do
|
||||
stub_request(:post, 'https://waba.360dialog.io/v1/configs/webhook')
|
||||
whatsapp_channel = create(:channel_whatsapp)
|
||||
whatsapp_channel = create(:channel_whatsapp, sync_templates: false)
|
||||
message = create(:message, conversation: create(:conversation, inbox: whatsapp_channel.inbox))
|
||||
allow(::Whatsapp::SendOnWhatsappService).to receive(:new).with(message: message).and_return(process_service)
|
||||
expect(::Whatsapp::SendOnWhatsappService).to receive(:new).with(message: message)
|
||||
|
||||
@@ -30,5 +30,10 @@ RSpec.describe TriggerScheduledItemsJob, type: :job do
|
||||
expect(Account::ConversationsResolutionSchedulerJob).to receive(:perform_later).once
|
||||
described_class.perform_now
|
||||
end
|
||||
|
||||
it 'triggers Channels::Whatsapp::TemplatesSyncSchedulerJob' do
|
||||
expect(Channels::Whatsapp::TemplatesSyncSchedulerJob).to receive(:perform_later).once
|
||||
described_class.perform_now
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user