feat: allow auto resolve waiting option (#11436)
This commit is contained in:
@@ -190,6 +190,7 @@ RSpec.describe 'Accounts API', type: :request do
|
||||
support_email: 'care@example.com',
|
||||
auto_resolve_after: 40,
|
||||
auto_resolve_message: 'Auto resolved',
|
||||
auto_resolve_ignore_waiting: false,
|
||||
timezone: 'Asia/Kolkata',
|
||||
industry: 'Technology',
|
||||
company_size: '1-10'
|
||||
@@ -207,7 +208,7 @@ RSpec.describe 'Accounts API', type: :request do
|
||||
expect(account.reload.domain).to eq(params[:domain])
|
||||
expect(account.reload.support_email).to eq(params[:support_email])
|
||||
|
||||
%w[auto_resolve_after auto_resolve_message].each do |attribute|
|
||||
%w[auto_resolve_after auto_resolve_message auto_resolve_ignore_waiting].each do |attribute|
|
||||
expect(account.reload.settings[attribute]).to eq(params[attribute.to_sym])
|
||||
end
|
||||
|
||||
|
||||
@@ -17,18 +17,40 @@ RSpec.describe Conversations::ResolutionJob do
|
||||
expect(conversation.reload.status).to eq('open')
|
||||
end
|
||||
|
||||
it 'resolves the issue if time of inactivity is more than the auto resolve duration' do
|
||||
account.update(auto_resolve_after: 14_400) # 10 days in minutes
|
||||
conversation.update(last_activity_at: 13.days.ago, waiting_since: nil)
|
||||
described_class.perform_now(account: account)
|
||||
expect(conversation.reload.status).to eq('resolved')
|
||||
context 'when auto_resolve_ignore_waiting is true' do
|
||||
it 'resolves non-waiting conversations if time of inactivity is more than auto resolve duration' do
|
||||
account.update(auto_resolve_after: 14_400, auto_resolve_ignore_waiting: true) # 10 days in minutes
|
||||
conversation.update(last_activity_at: 13.days.ago, waiting_since: nil)
|
||||
described_class.perform_now(account: account)
|
||||
expect(conversation.reload.status).to eq('resolved')
|
||||
end
|
||||
|
||||
it 'does not resolve waiting conversations even if time of inactivity is more than auto resolve duration' do
|
||||
account.update(auto_resolve_after: 14_400, auto_resolve_ignore_waiting: true) # 10 days in minutes
|
||||
conversation.update(last_activity_at: 13.days.ago, waiting_since: 13.days.ago)
|
||||
described_class.perform_now(account: account)
|
||||
expect(conversation.reload.status).to eq('open')
|
||||
end
|
||||
end
|
||||
|
||||
it 'resolved only a limited number of conversations in a single execution' do
|
||||
context 'when auto_resolve_ignore_waiting is false' do
|
||||
it 'resolves all conversations if time of inactivity is more than auto resolve duration' do
|
||||
account.update(auto_resolve_after: 14_400, auto_resolve_ignore_waiting: false) # 10 days in minutes
|
||||
# Create one waiting conversation and one non-waiting conversation
|
||||
waiting_conversation = create(:conversation, account: account, last_activity_at: 13.days.ago, waiting_since: 13.days.ago)
|
||||
non_waiting_conversation = create(:conversation, account: account, last_activity_at: 13.days.ago, waiting_since: nil)
|
||||
|
||||
described_class.perform_now(account: account)
|
||||
|
||||
expect(waiting_conversation.reload.status).to eq('resolved')
|
||||
expect(non_waiting_conversation.reload.status).to eq('resolved')
|
||||
end
|
||||
end
|
||||
|
||||
it 'resolves only a limited number of conversations in a single execution' do
|
||||
stub_const('Limits::BULK_ACTIONS_LIMIT', 2)
|
||||
account.update(auto_resolve_after: 14_400) # 10 days in minutes
|
||||
conversations = create_list(:conversation, 3, account: account, last_activity_at: 13.days.ago)
|
||||
conversations.each { |conversation| conversation.update(waiting_since: nil) }
|
||||
account.update(auto_resolve_after: 14_400, auto_resolve_ignore_waiting: false) # 10 days in minutes
|
||||
create_list(:conversation, 3, account: account, last_activity_at: 13.days.ago)
|
||||
described_class.perform_now(account: account)
|
||||
expect(account.conversations.resolved.count).to eq(Limits::BULK_ACTIONS_LIMIT)
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user