0
0
mirror of https://github.com/PostHog/posthog.git synced 2024-11-25 11:17:50 +01:00
posthog/plugin-server/tests/main/capabilities.test.ts
Yakko Majuri 469057b905
refactor(plugin-server): rename KafkaQueue to IngestionConsumer (#12540)
* refactor(plugin-server): rename KafkaQueue to IngestionConsumer

* fix

* final fix

* welp
2022-11-08 13:44:29 -03:00

117 lines
3.9 KiB
TypeScript

import Piscina from '@posthog/piscina'
import { GraphileWorker } from '../../src/main/graphile-worker/graphile-worker'
import { startGraphileWorker } from '../../src/main/graphile-worker/worker-setup'
import { IngestionConsumer } from '../../src/main/ingestion-queues/kafka-queue'
import { startQueues } from '../../src/main/ingestion-queues/queue'
import { Hub, LogLevel } from '../../src/types'
import { createHub } from '../../src/utils/db/hub'
jest.mock('../../src/main/ingestion-queues/kafka-queue')
jest.mock('../../src/main/graphile-worker/schedule')
describe('capabilities', () => {
let hub: Hub
let piscina: Piscina
let closeHub: () => Promise<void>
beforeEach(async () => {
;[hub, closeHub] = await createHub({
LOG_LEVEL: LogLevel.Warn,
})
piscina = { run: jest.fn(), on: jest.fn() } as any
})
afterEach(async () => {
await closeHub()
})
describe('queue', () => {
it('starts ingestion queue by default', async () => {
const queues = await startQueues(hub, piscina)
expect(queues).toEqual({
ingestion: expect.any(IngestionConsumer),
})
})
it('handles ingestion being turned off', async () => {
hub.capabilities.ingestion = false
hub.capabilities.processAsyncHandlers = false
const queues = await startQueues(hub, piscina)
expect(queues).toEqual({
ingestion: null,
})
})
})
describe('startGraphileWorker()', () => {
it('sets up pluginJob handler if processPluginJobs is on', async () => {
const graphileWorker = new GraphileWorker(hub)
jest.spyOn(graphileWorker, 'start').mockImplementation(jest.fn())
hub.capabilities.ingestion = false
hub.capabilities.processPluginJobs = true
hub.capabilities.pluginScheduledTasks = false
await startGraphileWorker(hub, graphileWorker, piscina)
expect(graphileWorker.start).toHaveBeenCalledWith(
{
pluginJob: expect.anything(),
},
[]
)
})
it('sets up scheduled task handlers if pluginScheduledTasks is on', async () => {
const graphileWorker = new GraphileWorker(hub)
jest.spyOn(graphileWorker, 'start').mockImplementation(jest.fn())
hub.capabilities.ingestion = false
hub.capabilities.processPluginJobs = false
hub.capabilities.pluginScheduledTasks = true
await startGraphileWorker(hub, graphileWorker, piscina)
expect(graphileWorker.start).toHaveBeenCalledWith(
{
runEveryMinute: expect.anything(),
runEveryHour: expect.anything(),
runEveryDay: expect.anything(),
},
[
{
identifier: 'runEveryMinute',
options: {
backfillPeriod: 0,
maxAttempts: 1,
},
pattern: '* * * * *',
task: 'runEveryMinute',
},
{
identifier: 'runEveryHour',
options: {
backfillPeriod: 0,
maxAttempts: 5,
},
pattern: '0 * * * *',
task: 'runEveryHour',
},
{
identifier: 'runEveryDay',
options: {
backfillPeriod: 0,
maxAttempts: 10,
},
pattern: '0 0 * * *',
task: 'runEveryDay',
},
]
)
})
})
})