diff options
| author | Shpuld Shpludson <shp@cock.li> | 2021-02-22 15:01:05 +0000 |
|---|---|---|
| committer | Shpuld Shpludson <shp@cock.li> | 2021-02-22 15:01:05 +0000 |
| commit | 589ab6510c1effc909ee9f6b64cd7791d3f55ee7 (patch) | |
| tree | 0018c6e6dc200dbe9c09f331b5af7c70873431d1 /test/unit/specs/services/chat_service/chat_service.spec.js | |
| parent | e8b8c3cc49171a7372bf49ee29930fd55c95ce98 (diff) | |
| parent | 67f3532ac95b2a8740ccbde581e74ac65eb20a9a (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/unit/specs/services/chat_service/chat_service.spec.js')
| -rw-r--r-- | test/unit/specs/services/chat_service/chat_service.spec.js | 17 |
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) + }) + }) }) |
