feat: Builder for creating Campaign conversations (#2192)

- Builder for creating Campaign conversations
- Widget endpoint to fetch the campaigns
This commit is contained in:
Sojan Jose
2021-05-03 20:23:09 +05:30
committed by GitHub
parent b649516fbb
commit 98e2a9b8b5
13 changed files with 182 additions and 6 deletions

View File

@@ -0,0 +1,31 @@
require 'rails_helper'
describe ::Campaigns::CampaignConversationBuilder do
let(:account) { create(:account) }
let(:inbox) { create(:inbox, account: account) }
let(:contact) { create(:contact, account: account, identifier: '123') }
let(:contact_inbox) { create(:contact_inbox, contact: contact, inbox: inbox) }
let(:campaign) { create(:campaign, inbox: inbox, account: account) }
describe '#perform' do
it 'creates a conversation with campaign id and message with campaign message' do
campaign_conversation = described_class.new(
contact_inbox_id: contact_inbox.id,
campaign_display_id: campaign.display_id
).perform
expect(campaign_conversation.campaign_id).to eq(campaign.id)
expect(campaign_conversation.messages.first.content).to eq(campaign.message)
end
it 'will not create a conversation with campaign id if another conversation exists' do
create(:conversation, contact_inbox_id: contact_inbox.id, inbox: inbox, account: account)
campaign_conversation = described_class.new(
contact_inbox_id: contact_inbox.id,
campaign_display_id: campaign.display_id
).perform
expect(campaign_conversation).to eq(nil)
end
end
end

View File

@@ -0,0 +1,31 @@
require 'rails_helper'
RSpec.describe '/api/v1/widget/campaigns', type: :request do
let(:account) { create(:account) }
let(:web_widget) { create(:channel_widget, account: account) }
let!(:campaign_1) { create(:campaign, inbox: web_widget.inbox, enabled: true, account: account) }
let!(:campaign_2) { create(:campaign, inbox: web_widget.inbox, enabled: false, account: account) }
describe 'GET /api/v1/widget/campaigns' do
let(:params) { { website_token: web_widget.website_token } }
context 'with correct website token' do
it 'returns the list of enabled campaigns' do
get '/api/v1/widget/campaigns', params: params
expect(response).to have_http_status(:success)
json_response = JSON.parse(response.body)
expect(json_response.length).to eq 1
expect(json_response.pluck('id')).to include(campaign_1.display_id)
expect(json_response.pluck('id')).not_to include(campaign_2.display_id)
end
end
context 'with invalid website token' do
it 'returns the list of agents' do
get '/api/v1/widget/campaigns', params: { website_token: '' }
expect(response).to have_http_status(:not_found)
end
end
end
end

View File

@@ -9,7 +9,7 @@ RSpec.describe '/api/v1/widget/events', type: :request do
let(:token) { ::Widget::TokenService.new(payload: payload).generate_token }
describe 'POST /api/v1/widget/events' do
let(:params) { { website_token: web_widget.website_token, name: 'webwidget.triggered' } }
let(:params) { { website_token: web_widget.website_token, name: 'webwidget.triggered', event_info: { test_id: 'test' } } }
context 'with invalid website token' do
it 'returns unauthorized' do
@@ -32,7 +32,7 @@ RSpec.describe '/api/v1/widget/events', type: :request do
expect(response).to have_http_status(:success)
expect(Rails.configuration.dispatcher).to have_received(:dispatch)
.with(params[:name], anything, contact_inbox: contact_inbox,
event_info: { browser_language: nil, widget_language: nil, browser: anything })
event_info: { test_id: 'test', browser_language: nil, widget_language: nil, browser: anything })
end
end
end

View File

@@ -11,7 +11,7 @@ RSpec.describe '/api/v1/widget/inbox_members', type: :request do
create(:inbox_member, user: agent_2, inbox: web_widget.inbox)
end
describe 'POST /api/v1/widget/inbox_members' do
describe 'GET /api/v1/widget/inbox_members' do
let(:params) { { website_token: web_widget.website_token } }
context 'with correct website token' do

View File

@@ -0,0 +1,40 @@
require 'rails_helper'
describe CampaignListener do
let(:listener) { described_class.instance }
let(:account) { create(:account) }
let(:inbox) { create(:inbox, account: account) }
let(:contact) { create(:contact, account: account, identifier: '123') }
let(:contact_inbox) { create(:contact_inbox, contact: contact, inbox: inbox) }
let(:campaign) { create(:campaign, inbox: inbox, account: account) }
let!(:event) do
Events::Base.new('campaign_triggered', Time.zone.now,
contact_inbox: contact_inbox, event_info: { campaign_id: campaign.display_id })
end
describe '#campaign_triggered' do
let(:builder) { double }
before do
allow(Campaigns::CampaignConversationBuilder).to receive(:new).and_return(builder)
allow(builder).to receive(:perform)
end
context 'when params contain campaign id' do
it 'triggers campaign conversation builder' do
expect(Campaigns::CampaignConversationBuilder).to receive(:new)
.with({ contact_inbox: contact_inbox.id, campaign_display_id: campaign.display_id, conversation_additional_attributes: {} }).once
listener.campaign_triggered(event)
end
end
context 'when params does not contain campaign id' do
it 'does not trigger campaign conversation builder' do
event = Events::Base.new('campaign_triggered', Time.zone.now,
contact_inbox: contact_inbox, event_info: {})
expect(Campaigns::CampaignConversationBuilder).to receive(:new).exactly(0).times
listener.campaign_triggered(event)
end
end
end
end