chore: Update Facebook Messenger gem (#2342)

This commit is contained in:
Sojan Jose
2021-06-07 13:58:01 +05:30
committed by GitHub
parent ae3cbf4f79
commit d1b3c7b0c2
10 changed files with 29 additions and 240 deletions

View File

@@ -1,143 +0,0 @@
require 'rails_helper'
RSpec.describe 'Facebook Indicators API', type: :request do
let(:account) { create(:account) }
let(:facebook_channel) { create(:channel_facebook_page, account: account) }
let(:inbox) { create(:inbox, account: account, channel: facebook_channel) }
let(:contact) { create(:contact, account: account) }
let(:valid_params) { { contact_id: contact.id, inbox_id: inbox.id } }
before do
allow(Facebook::Messenger::Bot).to receive(:deliver).and_return(true)
allow(Facebook::Messenger::Subscriptions).to receive(:subscribe).and_return(true)
end
describe 'POST /api/v1/accounts/{account.id}/facebook_indicators/mark_seen' do
context 'when it is an unauthenticated user' do
it 'returns unauthorized' do
post "/api/v1/accounts/#{account.id}/facebook_indicators/mark_seen"
expect(response).to have_http_status(:unauthorized)
end
end
context 'when it is an authenticated user' do
let(:agent) { create(:user, account: account, role: :agent) }
it 'marks a payload as seen' do
contact_inbox = create(:contact_inbox, contact: contact, inbox: inbox)
expect(Facebook::Messenger::Bot).to receive(:deliver).with(
{ recipient: { id: contact_inbox.source_id }, sender_action: 'mark_seen' },
access_token: inbox.channel.page_access_token
)
post "/api/v1/accounts/#{account.id}/facebook_indicators/mark_seen",
headers: agent.create_new_auth_token,
params: valid_params,
as: :json
expect(response).to have_http_status(:success)
end
it 'rescues an error' do
create(:contact_inbox, contact: contact, inbox: inbox)
allow(Facebook::Messenger::Bot).to receive(:deliver).and_raise(Facebook::Messenger::Error)
post "/api/v1/accounts/#{account.id}/facebook_indicators/mark_seen",
headers: agent.create_new_auth_token,
params: valid_params,
as: :json
expect(response).to have_http_status(:success)
end
end
end
describe 'POST /api/v1/accounts/{account.id}/facebook_indicators/typing_on' do
context 'when it is an unauthenticated user' do
it 'returns unauthorized' do
post "/api/v1/accounts/#{account.id}/facebook_indicators/typing_on"
expect(response).to have_http_status(:unauthorized)
end
end
context 'when it is an authenticated user' do
let(:agent) { create(:user, account: account, role: :agent) }
it 'marks a payload as typing_on' do
contact_inbox = create(:contact_inbox, contact: contact, inbox: inbox)
expect(Facebook::Messenger::Bot).to receive(:deliver).with(
{ recipient: { id: contact_inbox.source_id }, sender_action: 'typing_on' },
access_token: inbox.channel.page_access_token
)
post "/api/v1/accounts/#{account.id}/facebook_indicators/typing_on",
headers: agent.create_new_auth_token,
params: valid_params,
as: :json
expect(response).to have_http_status(:success)
end
it 'rescues an error' do
create(:contact_inbox, contact: contact, inbox: inbox)
allow(Facebook::Messenger::Bot).to receive(:deliver).and_raise(Facebook::Messenger::Error)
post "/api/v1/accounts/#{account.id}/facebook_indicators/typing_on",
headers: agent.create_new_auth_token,
params: valid_params,
as: :json
expect(response).to have_http_status(:success)
end
end
end
describe 'POST /api/v1/accounts/{account.id}/facebook_indicators/typing_off' do
context 'when it is an unauthenticated user' do
it 'returns unauthorized' do
post "/api/v1/accounts/#{account.id}/facebook_indicators/typing_off"
expect(response).to have_http_status(:unauthorized)
end
end
context 'when it is an authenticated user' do
let(:agent) { create(:user, account: account, role: :agent) }
it 'marks a payload as typing_off' do
contact_inbox = create(:contact_inbox, contact: contact, inbox: inbox)
expect(Facebook::Messenger::Bot).to receive(:deliver).with(
{ recipient: { id: contact_inbox.source_id }, sender_action: 'typing_off' },
access_token: inbox.channel.page_access_token
)
post "/api/v1/accounts/#{account.id}/facebook_indicators/typing_off",
headers: agent.create_new_auth_token,
params: valid_params,
as: :json
expect(response).to have_http_status(:success)
end
it 'rescues an error' do
create(:contact_inbox, contact: contact, inbox: inbox)
allow(Facebook::Messenger::Bot).to receive(:deliver).and_raise(Facebook::Messenger::Error)
post "/api/v1/accounts/#{account.id}/facebook_indicators/typing_off",
headers: agent.create_new_auth_token,
params: valid_params,
as: :json
expect(response).to have_http_status(:success)
end
end
end
end

View File

@@ -10,7 +10,7 @@ describe Facebook::SendOnFacebookService do
end
let!(:account) { create(:account) }
let(:bot) { class_double('FacebookBot::Bot').as_stubbed_const }
let(:bot) { class_double('Facebook::Messenger::Bot').as_stubbed_const }
let!(:widget_inbox) { create(:inbox, account: account) }
let!(:facebook_channel) { create(:channel_facebook_page, account: account) }
let!(:facebook_inbox) { create(:inbox, channel: facebook_channel, account: account) }
@@ -61,7 +61,7 @@ describe Facebook::SendOnFacebookService do
expect(bot).to have_received(:deliver).with({
recipient: { id: contact_inbox.source_id },
message: { text: message.content }
}, { access_token: facebook_channel.page_access_token })
}, { page_id: facebook_channel.page_id })
expect(bot).to have_received(:deliver).with({
recipient: { id: contact_inbox.source_id },
message: {
@@ -72,7 +72,7 @@ describe Facebook::SendOnFacebookService do
}
}
}
}, { access_token: facebook_channel.page_access_token })
}, { page_id: facebook_channel.page_id })
end
end
end