aboutsummaryrefslogtreecommitdiff
path: root/test/unit/specs/services
diff options
context:
space:
mode:
authorShpuld Shpuldson <shp@cock.li>2021-02-17 10:53:38 +0200
committerShpuld Shpuldson <shp@cock.li>2021-02-17 10:53:38 +0200
commit7834ff52b1df539f27fd4f30efc0181fcc3d9995 (patch)
treef8f339ebdf59f9355d99f325b7bb08b6ed9aac0d /test/unit/specs/services
parent47770ed7151ad0ba1cd8b77eb52590edd9ce9737 (diff)
add test
Diffstat (limited to 'test/unit/specs/services')
-rw-r--r--test/unit/specs/services/chat_service/chat_service.spec.js17
1 files changed, 17 insertions, 0 deletions
diff --git a/test/unit/specs/services/chat_service/chat_service.spec.js b/test/unit/specs/services/chat_service/chat_service.spec.js
index 0251cae7..fbbca436 100644
--- a/test/unit/specs/services/chat_service/chat_service.spec.js
+++ b/test/unit/specs/services/chat_service/chat_service.spec.js
@@ -88,4 +88,21 @@ describe('chatService', () => {
expect(view.map(i => i.type)).to.eql(['date', 'message', 'message', 'date', 'message'])
})
})
+
+ describe('.cullOlderMessages', () => {
+ it('keeps 50 newest messages and idIndex matches', () => {
+ const chat = chatService.empty()
+
+ for (let i = 100; i > 0; i--) {
+ // Use decimal values with toFixed to hack together constant length predictable strings
+ chatService.add(chat, { messages: [{ ...message1, id: 'a' + (i / 1000).toFixed(3), idempotency_key: i }] })
+ }
+ chatService.cullOlderMessages(chat)
+ expect(chat.messages.length).to.eql(50)
+ expect(chat.messages[0].id).to.eql('a0.051')
+ expect(chat.minId).to.eql('a0.051')
+ expect(chat.messages[49].id).to.eql('a0.100')
+ expect(Object.keys(chat.idIndex).length).to.eql(50)
+ })
+ })
})