aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorShpuld Shpludson <shp@cock.li>2021-02-22 15:01:05 +0000
committerShpuld Shpludson <shp@cock.li>2021-02-22 15:01:05 +0000
commit589ab6510c1effc909ee9f6b64cd7791d3f55ee7 (patch)
tree0018c6e6dc200dbe9c09f331b5af7c70873431d1 /test
parente8b8c3cc49171a7372bf49ee29930fd55c95ce98 (diff)
parent67f3532ac95b2a8740ccbde581e74ac65eb20a9a (diff)
Merge branch 'feat/keep-chat-perf-up' into 'develop'
Optimize chat perf in long run See merge request pleroma/pleroma-fe!1350
Diffstat (limited to 'test')
-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)
+ })
+ })
})