Some checks failed
Lock Threads / action (push) Has been cancelled
Mark stale issues and pull requests / stale (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot EE docker images / merge (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot CE docker images / merge (push) Has been cancelled
Run Chatwoot CE spec / lint-backend (push) Has been cancelled
Run Chatwoot CE spec / lint-frontend (push) Has been cancelled
Run Chatwoot CE spec / frontend-tests (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (0, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (1, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (10, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (11, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (12, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (13, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (14, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (15, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (2, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (3, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (4, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (5, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (6, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (7, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (8, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (9, 16) (push) Has been cancelled
Run Linux nightly installer / nightly (push) Has been cancelled
- Add Logistics component with progress tracking - Add OrderDetail component for order information - Support data-driven steps and actions - Add blue color scale to widget SCSS - Fix node overflow and progress bar rendering issues - Add English translations for dashboard components Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
67 lines
2.8 KiB
Ruby
67 lines
2.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
shared_examples_for 'assignment_handler' do
|
|
describe '#update_team' do
|
|
let(:conversation) { create(:conversation, assignee: create(:user)) }
|
|
let(:agent) do
|
|
create(:user, email: 'agent@example.com', account: conversation.account, role: :agent, auto_offline: false)
|
|
end
|
|
let(:team) do
|
|
create(:team, account: conversation.account, allow_auto_assign: false)
|
|
end
|
|
|
|
context 'when agent is current user' do
|
|
before do
|
|
Current.user = agent
|
|
create(:team_member, team: team, user: agent)
|
|
create(:inbox_member, user: agent, inbox: conversation.inbox)
|
|
conversation.inbox.reload
|
|
end
|
|
|
|
it 'creates team assigned and unassigned message activity' do
|
|
expect(conversation.update(team: team)).to be true
|
|
expect(conversation.update(team: nil)).to be true
|
|
expect(Conversations::ActivityMessageJob).to(have_been_enqueued.at_least(:once)
|
|
.with(conversation, { account_id: conversation.account_id, inbox_id: conversation.inbox_id, message_type: :activity,
|
|
content: "Assigned to #{team.name} by #{agent.name}" }))
|
|
expect(Conversations::ActivityMessageJob).to(have_been_enqueued.at_least(:once)
|
|
.with(conversation, { account_id: conversation.account_id, inbox_id: conversation.inbox_id, message_type: :activity,
|
|
content: "Unassigned from #{team.name} by #{agent.name}" }))
|
|
end
|
|
|
|
it 'changes assignee to nil if they doesnt belong to the team and allow_auto_assign is false' do
|
|
expect(team.allow_auto_assign).to be false
|
|
|
|
conversation.update(team: team)
|
|
|
|
expect(conversation.reload.assignee).to be_nil
|
|
end
|
|
|
|
it 'changes assignee to a team member if allow_auto_assign is enabled' do
|
|
team.update!(allow_auto_assign: true)
|
|
|
|
conversation.update(team: team)
|
|
|
|
expect(conversation.reload.assignee).to eq agent
|
|
expect(Conversations::ActivityMessageJob).to(have_been_enqueued.at_least(:once)
|
|
.with(conversation, { account_id: conversation.account_id, inbox_id: conversation.inbox_id, message_type: :activity,
|
|
content: "Assigned to #{conversation.assignee.name} via #{team.name} by #{agent.name}" }))
|
|
end
|
|
|
|
it 'wont change assignee if he is already a team member' do
|
|
team.update!(allow_auto_assign: true)
|
|
assignee = create(:user, account: conversation.account, role: :agent)
|
|
create(:inbox_member, user: assignee, inbox: conversation.inbox)
|
|
create(:team_member, team: team, user: assignee)
|
|
conversation.update(assignee: assignee)
|
|
|
|
conversation.update(team: team)
|
|
|
|
expect(conversation.reload.assignee).to eq assignee
|
|
end
|
|
end
|
|
end
|
|
end
|