fix: No longer displays edited on all messages and fix Disconnected from signaling server on multiple clients
All checks were successful
Queue Release Build / prepare (push) Successful in 19s
Deploy Web Apps / deploy (push) Successful in 8m19s
Queue Release Build / build-windows (push) Successful in 27m48s
Queue Release Build / build-linux (push) Successful in 47m35s
Queue Release Build / build-android (push) Successful in 21m15s
Queue Release Build / finalize (push) Successful in 2m30s

This commit is contained in:
2026-06-07 15:05:12 +02:00
parent 83456c018c
commit 80d7728e66
11 changed files with 175 additions and 20 deletions

View File

@@ -0,0 +1,59 @@
import {
describe,
it,
expect
} from 'vitest';
import type { Message } from '../../../../shared-kernel';
import { shouldShowMessageEditedLabel } from './message.rules';
function createMessage(overrides: Partial<Message> = {}): Message {
return {
id: 'message-1',
roomId: 'room-1',
senderId: 'user-1',
senderName: 'User 1',
content: 'hello',
timestamp: 1_000,
reactions: [],
isDeleted: false,
...overrides
};
}
describe('message.rules', () => {
describe('shouldShowMessageEditedLabel', () => {
it('returns false for newly created messages without an edit revision', () => {
expect(shouldShowMessageEditedLabel(createMessage())).toBe(false);
});
it('returns false when editedAt equals the original timestamp (legacy create rows)', () => {
expect(shouldShowMessageEditedLabel(createMessage({
editedAt: 1_000,
timestamp: 1_000,
revision: 0
}))).toBe(false);
});
it('returns true when a message has an edit revision', () => {
expect(shouldShowMessageEditedLabel(createMessage({
editedAt: 2_000,
revision: 1
}))).toBe(true);
});
it('returns true for legacy edited messages with editedAt after timestamp', () => {
expect(shouldShowMessageEditedLabel(createMessage({
editedAt: 2_000,
timestamp: 1_000
}))).toBe(true);
});
it('returns false for deleted messages even when editedAt is set', () => {
expect(shouldShowMessageEditedLabel(createMessage({
editedAt: 2_000,
revision: 1,
isDeleted: true
}))).toBe(false);
});
});
});