2023-11-09 00:20:43 +03:00
|
|
|
import { describe, expect, it } from 'vitest'
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
import { PeersIndex, TelegramClient } from '@mtcute/client'
|
2021-04-23 22:35:37 +03:00
|
|
|
|
2023-10-16 19:23:53 +03:00
|
|
|
import { Dispatcher, PropagationAction } from '../src/index.js'
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-04-23 22:35:37 +03:00
|
|
|
describe('Dispatcher', () => {
|
|
|
|
// todo: replace with proper mocked TelegramClient
|
|
|
|
const client = new TelegramClient({ apiId: 0, apiHash: '' })
|
2022-06-30 16:32:56 +03:00
|
|
|
const emptyPeers = new PeersIndex()
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
describe('Raw updates', () => {
|
|
|
|
it('registers and unregisters handlers for raw updates', async () => {
|
2023-10-26 23:54:04 +03:00
|
|
|
const dp = Dispatcher.for(client)
|
2021-04-23 22:35:37 +03:00
|
|
|
const log: string[] = []
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
2022-06-30 16:32:56 +03:00
|
|
|
log.push(`(first) received ${upd._}`)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2021-04-23 22:35:37 +03:00
|
|
|
})
|
2022-06-30 16:32:56 +03:00
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push(`(second) received ${upd._}`)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
return PropagationAction.Continue
|
2021-04-23 22:35:37 +03:00
|
|
|
})
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
dp.removeUpdateHandler('raw')
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
2023-09-24 01:32:22 +03:00
|
|
|
expect(log).eql(['(first) received updateConfig', '(second) received updateConfig'])
|
2021-04-23 22:35:37 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
it('supports filters for raw updates', async () => {
|
2023-10-26 23:54:04 +03:00
|
|
|
const dp = Dispatcher.for(client)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
const log: string[] = []
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(no) received ' + upd._)
|
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2021-04-23 22:35:37 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
dp.onRawUpdate(
|
|
|
|
() => true,
|
|
|
|
(cl, upd) => {
|
|
|
|
log.push('(true) received ' + upd._)
|
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2023-06-05 03:30:48 +03:00
|
|
|
},
|
2021-04-23 22:35:37 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
dp.onRawUpdate(
|
|
|
|
() => false,
|
|
|
|
(cl, upd) => {
|
|
|
|
log.push('(false) received ' + upd._)
|
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2023-06-05 03:30:48 +03:00
|
|
|
},
|
2021-04-23 22:35:37 +03:00
|
|
|
)
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
2023-09-24 01:32:22 +03:00
|
|
|
expect(log).eql(['(no) received updateConfig', '(true) received updateConfig'])
|
2021-04-23 22:35:37 +03:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
// todo: other update types
|
|
|
|
|
|
|
|
describe('Filter groups', () => {
|
|
|
|
it('does separate propagation for filter groups', async () => {
|
2023-10-26 23:54:04 +03:00
|
|
|
const dp = Dispatcher.for(client)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
const log: string[] = []
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp0) received ' + upd._)
|
|
|
|
}, 0)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp0 2) received ' + upd._)
|
|
|
|
}, 0)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp1) received ' + upd._)
|
|
|
|
}, 1)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp2) received ' + upd._)
|
|
|
|
}, 2)
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
expect(log).eql([
|
|
|
|
'(grp0) received updateConfig',
|
|
|
|
'(grp1) received updateConfig',
|
|
|
|
'(grp2) received updateConfig',
|
|
|
|
])
|
|
|
|
})
|
|
|
|
|
|
|
|
it('allows continuing propagation in the same group with ContinuePropagation', async () => {
|
2023-10-26 23:54:04 +03:00
|
|
|
const dp = Dispatcher.for(client)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
const log: string[] = []
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp0) received ' + upd._)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2021-04-23 22:35:37 +03:00
|
|
|
}, 0)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp0 2) received ' + upd._)
|
|
|
|
}, 0)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp1) received ' + upd._)
|
|
|
|
}, 1)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp1 2) received ' + upd._)
|
|
|
|
}, 1)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp2) received ' + upd._)
|
|
|
|
}, 2)
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
expect(log).eql([
|
|
|
|
'(grp0) received updateConfig',
|
|
|
|
'(grp0 2) received updateConfig',
|
|
|
|
'(grp1) received updateConfig',
|
|
|
|
'(grp2) received updateConfig',
|
|
|
|
])
|
|
|
|
})
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
it('allows stopping any further propagation with Stop', async () => {
|
2023-10-26 23:54:04 +03:00
|
|
|
const dp = Dispatcher.for(client)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
const log: string[] = []
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp0) received ' + upd._)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2021-04-23 22:35:37 +03:00
|
|
|
}, 0)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp0 2) received ' + upd._)
|
|
|
|
}, 0)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp1) received ' + upd._)
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
return PropagationAction.Stop
|
2021-04-23 22:35:37 +03:00
|
|
|
}, 1)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp1 2) received ' + upd._)
|
|
|
|
}, 1)
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(grp2) received ' + upd._)
|
|
|
|
}, 2)
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
expect(log).eql([
|
|
|
|
'(grp0) received updateConfig',
|
|
|
|
'(grp0 2) received updateConfig',
|
|
|
|
'(grp1) received updateConfig',
|
|
|
|
])
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('Children', () => {
|
|
|
|
it('should call children handlers after own handlers', async () => {
|
2023-10-26 23:54:04 +03:00
|
|
|
const dp = Dispatcher.for(client)
|
|
|
|
const child = Dispatcher.child()
|
2021-04-23 22:35:37 +03:00
|
|
|
dp.addChild(child)
|
|
|
|
|
|
|
|
const log: string[] = []
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(parent) received ' + upd._)
|
|
|
|
})
|
|
|
|
|
|
|
|
child.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(child) received ' + upd._)
|
|
|
|
})
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
2023-09-24 01:32:22 +03:00
|
|
|
expect(log).eql(['(parent) received updateConfig', '(child) received updateConfig'])
|
2021-04-23 22:35:37 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
it('should have separate handler groups for children', async () => {
|
2023-10-26 23:54:04 +03:00
|
|
|
const dp = Dispatcher.for(client)
|
|
|
|
const child = Dispatcher.child()
|
2021-04-23 22:35:37 +03:00
|
|
|
dp.addChild(child)
|
|
|
|
|
|
|
|
const log: string[] = []
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(parent 0) received ' + upd._)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2021-04-23 22:35:37 +03:00
|
|
|
}, 0)
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(parent 1) received ' + upd._)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Stop
|
2021-04-23 22:35:37 +03:00
|
|
|
}, 1)
|
|
|
|
|
|
|
|
dp.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(parent 2) received ' + upd._)
|
|
|
|
}, 1)
|
|
|
|
|
|
|
|
child.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(child 0) received ' + upd._)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Continue
|
2021-04-23 22:35:37 +03:00
|
|
|
}, 0)
|
|
|
|
|
|
|
|
child.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(child 1) received ' + upd._)
|
2023-06-05 03:30:48 +03:00
|
|
|
|
2021-07-03 16:42:41 +03:00
|
|
|
return PropagationAction.Stop
|
2021-04-23 22:35:37 +03:00
|
|
|
}, 1)
|
|
|
|
|
|
|
|
child.onRawUpdate((cl, upd) => {
|
|
|
|
log.push('(child 2) received ' + upd._)
|
|
|
|
}, 1)
|
|
|
|
|
2022-06-30 16:32:56 +03:00
|
|
|
await dp.dispatchRawUpdateNow({ _: 'updateConfig' }, emptyPeers)
|
2021-04-23 22:35:37 +03:00
|
|
|
|
|
|
|
expect(log).eql([
|
|
|
|
'(parent 0) received updateConfig',
|
|
|
|
'(parent 1) received updateConfig',
|
|
|
|
'(child 0) received updateConfig',
|
|
|
|
'(child 1) received updateConfig',
|
|
|
|
])
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|