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>
102 lines
3.1 KiB
JavaScript
102 lines
3.1 KiB
JavaScript
import {
|
|
filterDuplicateSourceMessages,
|
|
getLastMessage,
|
|
getReadMessages,
|
|
getUnreadMessages,
|
|
} from '../conversationHelper';
|
|
import {
|
|
conversationData,
|
|
lastMessageData,
|
|
readMessagesData,
|
|
unReadMessagesData,
|
|
} from './fixtures/conversationFixtures';
|
|
|
|
describe('conversationHelper', () => {
|
|
describe('#filterDuplicateSourceMessages', () => {
|
|
it('returns messages without duplicate source_id and all messages without source_id', () => {
|
|
const input = [
|
|
{ source_id: null, id: 1 },
|
|
{ source_id: '', id: 2 },
|
|
{ id: 3 },
|
|
{ source_id: 'wa_1', id: 4 },
|
|
{ source_id: 'wa_1', id: 5 },
|
|
{ source_id: 'wa_1', id: 6 },
|
|
{ source_id: 'wa_2', id: 7 },
|
|
{ source_id: 'wa_2', id: 8 },
|
|
{ source_id: 'wa_3', id: 9 },
|
|
];
|
|
const expected = [
|
|
{ source_id: null, id: 1 },
|
|
{ source_id: '', id: 2 },
|
|
{ id: 3 },
|
|
{ source_id: 'wa_1', id: 4 },
|
|
{ source_id: 'wa_2', id: 7 },
|
|
{ source_id: 'wa_3', id: 9 },
|
|
];
|
|
expect(filterDuplicateSourceMessages(input)).toEqual(expected);
|
|
});
|
|
});
|
|
|
|
describe('#readMessages', () => {
|
|
it('should return read messages if conversation is passed', () => {
|
|
expect(
|
|
getReadMessages(
|
|
conversationData.messages,
|
|
conversationData.agent_last_seen_at
|
|
)
|
|
).toEqual(readMessagesData);
|
|
});
|
|
});
|
|
|
|
describe('#unReadMessages', () => {
|
|
it('should return unread messages if conversation is passed', () => {
|
|
expect(
|
|
getUnreadMessages(
|
|
conversationData.messages,
|
|
conversationData.agent_last_seen_at
|
|
)
|
|
).toEqual(unReadMessagesData);
|
|
});
|
|
});
|
|
|
|
describe('#lastMessage', () => {
|
|
it("should return last activity message if both api and store doesn't have other messages", () => {
|
|
const testConversation = {
|
|
messages: [conversationData.messages[0]],
|
|
last_non_activity_message: null,
|
|
};
|
|
expect(getLastMessage(testConversation)).toEqual(
|
|
testConversation.messages[0]
|
|
);
|
|
});
|
|
|
|
it('should return message from store if store has latest message', () => {
|
|
const testConversation = {
|
|
messages: [],
|
|
last_non_activity_message: lastMessageData,
|
|
};
|
|
expect(getLastMessage(testConversation)).toEqual(lastMessageData);
|
|
});
|
|
|
|
it('should return last non activity message from store if api value is empty', () => {
|
|
const testConversation = {
|
|
messages: [conversationData.messages[0], conversationData.messages[1]],
|
|
last_non_activity_message: null,
|
|
};
|
|
expect(getLastMessage(testConversation)).toEqual(
|
|
testConversation.messages[1]
|
|
);
|
|
});
|
|
|
|
it("should return last non activity message from store if store doesn't have any messages", () => {
|
|
const testConversation = {
|
|
messages: [conversationData.messages[1], conversationData.messages[2]],
|
|
last_non_activity_message: conversationData.messages[0],
|
|
};
|
|
expect(getLastMessage(testConversation)).toEqual(
|
|
testConversation.messages[1]
|
|
);
|
|
});
|
|
});
|
|
});
|