more functional design principles for tests
Some checks failed
ci/woodpecker/pr/pr Pipeline failed

This commit is contained in:
Madison Grubb
2026-02-17 11:21:02 -05:00
parent c8d37c98f4
commit 82bd51c3a4
3 changed files with 42 additions and 34 deletions

View File

@@ -59,7 +59,9 @@ async function waitForHealth(timeoutMs = 90000) {
}
describe('Server and CoT integration', () => {
let serverProcess = null
const testState = {
serverProcess: null,
}
beforeAll(async () => {
ensureDevCerts()
@@ -74,33 +76,35 @@ describe('Server and CoT integration', () => {
BOOTSTRAP_EMAIL: COT_AUTH_USER,
BOOTSTRAP_PASSWORD: COT_AUTH_PASS,
}
serverProcess = spawn('node', ['.output/server/index.mjs'], {
testState.serverProcess = spawn('node', ['.output/server/index.mjs'], {
cwd: projectRoot,
env,
stdio: ['ignore', 'pipe', 'pipe'],
})
serverProcess.stdout?.on('data', d => process.stdout.write(d))
serverProcess.stderr?.on('data', d => process.stderr.write(d))
testState.serverProcess.stdout?.on('data', d => process.stdout.write(d))
testState.serverProcess.stderr?.on('data', d => process.stderr.write(d))
await waitForHealth(90000)
}, 120000)
afterAll(() => {
if (serverProcess?.pid) {
serverProcess.kill('SIGTERM')
if (testState.serverProcess?.pid) {
testState.serverProcess.kill('SIGTERM')
}
})
it('serves health on port 3000', async () => {
let res
for (const protocol of ['https', 'http']) {
const tryProtocols = async (protocols) => {
if (protocols.length === 0) throw new Error('No protocol succeeded')
try {
res = await fetch(`${protocol}://localhost:${API_PORT}/health`, { method: 'GET', headers: { Accept: 'application/json' } })
if (res?.ok) break
const res = await fetch(`${protocols[0]}://localhost:${API_PORT}/health`, { method: 'GET', headers: { Accept: 'application/json' } })
if (res?.ok) return res
return tryProtocols(protocols.slice(1))
}
catch {
// try next
return tryProtocols(protocols.slice(1))
}
}
const res = await tryProtocols(['https', 'http'])
expect(res?.ok).toBe(true)
const body = await res.json()
expect(body).toHaveProperty('status', 'ok')

View File

@@ -2,23 +2,25 @@ import { describe, it, expect, beforeEach, afterEach, vi } from 'vitest'
import { registerCleanup, graceful, initShutdownHandlers, clearCleanup } from '../../server/utils/shutdown.js'
describe('shutdown integration', () => {
let originalExit
let exitCalls
let originalOn
const testState = {
originalExit: null,
exitCalls: [],
originalOn: null,
}
beforeEach(() => {
clearCleanup()
exitCalls = []
originalExit = process.exit
testState.exitCalls = []
testState.originalExit = process.exit
process.exit = vi.fn((code) => {
exitCalls.push(code)
testState.exitCalls.push(code)
})
originalOn = process.on
testState.originalOn = process.on
})
afterEach(() => {
process.exit = originalExit
process.on = originalOn
process.exit = testState.originalExit
process.on = testState.originalOn
clearCleanup()
})
@@ -30,7 +32,7 @@ describe('shutdown integration', () => {
initShutdownHandlers()
expect(process.on).toHaveBeenCalledWith('SIGTERM', expect.any(Function))
expect(process.on).toHaveBeenCalledWith('SIGINT', expect.any(Function))
process.on = originalOn
process.on = testState.originalOn
})
it('signal handler calls graceful', async () => {
@@ -42,8 +44,8 @@ describe('shutdown integration', () => {
const sigtermHandler = handlers.SIGTERM
expect(sigtermHandler).toBeDefined()
await sigtermHandler()
expect(exitCalls.length).toBeGreaterThan(0)
process.on = originalOn
expect(testState.exitCalls.length).toBeGreaterThan(0)
process.on = testState.originalOn
})
it('signal handler handles graceful error', async () => {
@@ -58,8 +60,8 @@ describe('shutdown integration', () => {
throw new Error('Force error')
})
await sigintHandler()
expect(exitCalls.length).toBeGreaterThan(0)
process.on = originalOn
expect(testState.exitCalls.length).toBeGreaterThan(0)
process.on = testState.originalOn
})
it('covers timeout path in graceful', async () => {
@@ -68,7 +70,7 @@ describe('shutdown integration', () => {
})
graceful()
await new Promise(resolve => setTimeout(resolve, 100))
expect(exitCalls.length).toBeGreaterThan(0)
expect(testState.exitCalls.length).toBeGreaterThan(0)
})
it('covers graceful catch block', async () => {
@@ -76,6 +78,6 @@ describe('shutdown integration', () => {
throw new Error('Test error')
})
await graceful()
expect(exitCalls.length).toBeGreaterThan(0)
expect(testState.exitCalls.length).toBeGreaterThan(0)
})
})