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 53b527dbbe
refactor(graphile-worker): update terminology, clearer capabilities approach for setup (#12203)
* rename legacy references to queue to more appropriate worker terminology

* rename startJobsConsumer -> startGraphileWorker, no-op refactor

* add back enqueue success and failure metrics

* fix mock import

* fix test for good
2022-10-12 10:24:22 -03:00

87 lines
2.7 KiB
TypeScript

import Piscina from '@posthog/piscina'
import { KafkaQueue } from '../../src/main/ingestion-queues/kafka-queue'
import { startQueues } from '../../src/main/ingestion-queues/queue'
import { startGraphileWorker } from '../../src/main/jobs/worker-setup'
import { Hub, LogLevel } from '../../src/types'
import { createHub } from '../../src/utils/db/hub'
jest.mock('../../src/main/ingestion-queues/kafka-queue')
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() } 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(KafkaQueue),
})
})
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 bufferJob handler if ingestion is on', async () => {
hub.graphileWorker.start = jest.fn()
hub.capabilities.ingestion = true
hub.capabilities.processPluginJobs = false
await startGraphileWorker(hub, piscina)
expect(hub.graphileWorker.start).toHaveBeenCalledWith({
bufferJob: expect.anything(),
})
})
it('sets up pluginJob handler if processPluginJobs is on', async () => {
hub.graphileWorker.start = jest.fn()
hub.capabilities.ingestion = false
hub.capabilities.processPluginJobs = true
await startGraphileWorker(hub, piscina)
expect(hub.graphileWorker.start).toHaveBeenCalledWith({
pluginJob: expect.anything(),
})
})
it('sets up bufferJob and pluginJob handlers if ingestion and processPluginJobs are on', async () => {
hub.graphileWorker.start = jest.fn()
hub.capabilities.ingestion = true
hub.capabilities.processPluginJobs = true
await startGraphileWorker(hub, piscina)
expect(hub.graphileWorker.start).toHaveBeenCalledWith({
bufferJob: expect.anything(),
pluginJob: expect.anything(),
})
})
})
})