Skip to content

Commit

Permalink
test(tests): added even more tests; reached 100% coverage
Browse files Browse the repository at this point in the history
  • Loading branch information
GeorgeCht committed Oct 23, 2024
1 parent 3724e2c commit a58d9de
Show file tree
Hide file tree
Showing 3 changed files with 121 additions and 1 deletion.
88 changes: 88 additions & 0 deletions tests/edge.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
import { z } from 'zod'
import { EventController } from '../src'

describe('EventController Advanced Scenarios and Edge Cases', () => {
test('should handle high-frequency event dispatches', async () => {
const schema = z.object({ value: z.number() })
const controller = new EventController(schema, 'testEvent')
const listener = jest.fn()
controller.subscribe(listener)

const dispatches = Array.from({ length: 1000 }, (_, i) => ({ value: i }))
await Promise.all(dispatches.map((payload) => controller.dispatch(payload)))

expect(listener).toHaveBeenCalledTimes(1000)
})

test('should handle concurrent dispatches from multiple controllers', async () => {
const schema = z.object({ value: z.number() })
const controller1 = new EventController(schema, 'testEvent1')
const controller2 = new EventController(schema, 'testEvent2')

const listener1 = jest.fn()
const listener2 = jest.fn()

controller1.subscribe(listener1)
controller2.subscribe(listener2)

await Promise.all([
controller1.dispatch({ value: 1 }),
controller2.dispatch({ value: 2 }),
controller1.dispatch({ value: 3 }),
controller2.dispatch({ value: 4 }),
])

expect(listener1).toHaveBeenCalledTimes(2)
expect(listener2).toHaveBeenCalledTimes(2)
})

test('should handle recursive schema', async () => {
type TreeNode = { value: number; children?: TreeNode[] }
const treeSchema: z.ZodType<TreeNode> = z.lazy(() =>
z.object({
value: z.number(),
children: z.array(treeSchema).optional(),
}),
)

const controller = new EventController(treeSchema, 'treeEvent')
const listener = jest.fn()
controller.subscribe(listener)

await controller.dispatch({
value: 1,
children: [{ value: 2 }, { value: 3, children: [{ value: 4 }] }],
})

expect(listener).toHaveBeenCalled()
})

test('should handle error in middleware without breaking the system', async () => {
const schema = z.object({ value: z.number() })
const controller = new EventController(schema, 'testEvent')

controller.use(() => {
throw new Error('Middleware error')
})

const listener = jest.fn()
controller.subscribe(listener)

await expect(controller.dispatch({ value: 1 })).rejects.toThrow(
'Middleware error',
)
expect(listener).not.toHaveBeenCalled()
})

test('should prevent multiple calls to next() in middleware', async () => {
const schema = z.object({ value: z.number() })
const controller = new EventController(schema, 'testEvent')

controller.use(async (_, next) => {
await next()
await expect(next()).rejects.toThrow('next() called multiple times')
})

await controller.dispatch({ value: 1 })
})
})
2 changes: 1 addition & 1 deletion tests/middleware.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { createPipeline } from '../src/middleware'

import type { Middleware, Pipeline } from '../src/middleware'

describe('createPipeline', () => {
describe('Middleware Pipeline', () => {
const TestSchema = z.object({
id: z.number(),
name: z.string(),
Expand Down
32 changes: 32 additions & 0 deletions tests/refine.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
import { z } from 'zod'
import { EventController } from '../src'

describe('EventController Refinement', () => {
const schema = z.object({ value: z.number() })
let controller: EventController<typeof schema>

beforeEach(() => {
controller = new EventController(schema, 'testEvent')
})

afterEach(() => {
controller.unsubscribe()
controller.update({})
})

test('should apply refinement condition', async () => {
controller.refine((payload) => payload.value > 0)
const listener = jest.fn()
controller.subscribe(listener)
await controller.dispatch({ value: 10 })
await controller.dispatch({ value: -5 })
expect(listener).toHaveBeenCalledTimes(1)
})

test('should execute refinement callback when condition is not met', async () => {
const callback = jest.fn()
controller.refine((payload) => payload.value > 0, callback)
await controller.dispatch({ value: -5 })
expect(callback).toHaveBeenCalled()
})
})

0 comments on commit a58d9de

Please sign in to comment.