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>
109 lines
3.8 KiB
Ruby
109 lines
3.8 KiB
Ruby
require 'rails_helper'
|
|
|
|
RSpec.describe Email::ReplyToBuilder do
|
|
let(:account) { create(:account, domain: 'mail.example.com', support_email: 'support@example.com') }
|
|
let(:agent) { create(:user, account: account) }
|
|
let(:conversation) { create(:conversation, account: account) }
|
|
let(:current_message) { create(:message, conversation: conversation, sender: agent, message_type: :outgoing) }
|
|
let(:inbox) { create(:inbox, account: account) }
|
|
|
|
describe '#build' do
|
|
context 'when inbox is an email channel' do
|
|
let(:channel) { create(:channel_email, email: 'care@example.com', account: account) }
|
|
let(:inbox) { create(:inbox, channel: channel, account: account) }
|
|
|
|
it 'returns the channel email with sender name formatting' do
|
|
builder = described_class.new(inbox: inbox, message: current_message)
|
|
result = builder.build
|
|
|
|
expect(result).to include('care@example.com')
|
|
end
|
|
|
|
context 'with friendly inbox' do
|
|
let(:inbox) do
|
|
create(:inbox, channel: channel, account: account, greeting_enabled: true, greeting_message: 'Hello', sender_name_type: :friendly)
|
|
end
|
|
|
|
it 'returns friendly formatted sender name' do
|
|
builder = described_class.new(inbox: inbox, message: current_message)
|
|
result = builder.build
|
|
|
|
expect(result).to include(agent.available_name)
|
|
expect(result).to include('care@example.com')
|
|
end
|
|
end
|
|
|
|
context 'with professional inbox' do
|
|
let(:inbox) { create(:inbox, channel: channel, account: account, sender_name_type: :professional) }
|
|
|
|
it 'returns professional formatted sender name' do
|
|
builder = described_class.new(inbox: inbox, message: current_message)
|
|
result = builder.build
|
|
|
|
expect(result).to include('care@example.com')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when inbox is not an email channel' do
|
|
let(:channel) { create(:channel_api, account: account) }
|
|
let(:inbox) { create(:inbox, channel: channel, account: account) }
|
|
|
|
context 'with inbound email enabled' do
|
|
before do
|
|
account.enable_features('inbound_emails')
|
|
account.update!(domain: 'mail.example.com', support_email: 'support@example.com')
|
|
end
|
|
|
|
it 'returns reply email with conversation uuid' do
|
|
builder = described_class.new(inbox: inbox, message: current_message)
|
|
result = builder.build
|
|
|
|
expect(result).to include("reply+#{conversation.uuid}@mail.example.com")
|
|
end
|
|
end
|
|
|
|
context 'when support_email has display name format and inbound emails are disabled' do
|
|
before do
|
|
account.disable_features('inbound_emails')
|
|
account.update!(support_email: 'Support <support@example.com>')
|
|
end
|
|
|
|
it 'returns account support email with display name' do
|
|
builder = described_class.new(inbox: inbox, message: current_message)
|
|
result = builder.build
|
|
|
|
expect(result).to include("#{inbox.name} <support@example.com>")
|
|
end
|
|
end
|
|
|
|
context 'when feature is disabled' do
|
|
before do
|
|
account.disable_features('inbound_emails')
|
|
end
|
|
|
|
it 'returns account support email' do
|
|
builder = described_class.new(inbox: inbox, message: current_message)
|
|
result = builder.build
|
|
|
|
expect(result).to include('support@example.com')
|
|
end
|
|
end
|
|
|
|
context 'when inbound email domain is missing' do
|
|
before do
|
|
account.enable_features('inbound_emails')
|
|
account.update!(domain: nil)
|
|
end
|
|
|
|
it 'returns account support email' do
|
|
builder = described_class.new(inbox: inbox, message: current_message)
|
|
result = builder.build
|
|
|
|
expect(result).to include('support@example.com')
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|