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

This commit is contained in:
Madison Grubb
2026-02-17 11:17:52 -05:00
parent 1a566e2d80
commit c8d37c98f4
14 changed files with 357 additions and 321 deletions

View File

@@ -19,13 +19,15 @@ vi.mock('../../server/utils/mediasoup.js', () => {
})
describe('webrtcSignaling', () => {
let sessionId
const testState = {
sessionId: null,
}
const userId = 'test-user'
beforeEach(async () => {
clearSessions()
const session = await createSession(userId, 'Test')
sessionId = session.id
testState.sessionId = session.id
})
it('returns error when session not found', async () => {
@@ -34,35 +36,35 @@ describe('webrtcSignaling', () => {
})
it('returns Forbidden when userId does not match session', async () => {
const res = await handleWebSocketMessage('other-user', sessionId, 'create-transport', {})
const res = await handleWebSocketMessage('other-user', testState.sessionId, 'create-transport', {})
expect(res).toEqual({ error: 'Forbidden' })
})
it('returns error for unknown message type', async () => {
const res = await handleWebSocketMessage(userId, sessionId, 'unknown-type', {})
const res = await handleWebSocketMessage(userId, testState.sessionId, 'unknown-type', {})
expect(res).toEqual({ error: 'Unknown message type: unknown-type' })
})
it('returns transportId and dtlsParameters required for connect-transport', async () => {
const res = await handleWebSocketMessage(userId, sessionId, 'connect-transport', {})
const res = await handleWebSocketMessage(userId, testState.sessionId, 'connect-transport', {})
expect(res?.error).toContain('transportId')
})
it('get-router-rtp-capabilities returns router RTP capabilities', async () => {
const res = await handleWebSocketMessage(userId, sessionId, 'get-router-rtp-capabilities', {})
const res = await handleWebSocketMessage(userId, testState.sessionId, 'get-router-rtp-capabilities', {})
expect(res?.type).toBe('router-rtp-capabilities')
expect(res?.data).toEqual({ codecs: [] })
})
it('create-transport returns transport params', async () => {
const res = await handleWebSocketMessage(userId, sessionId, 'create-transport', {})
const res = await handleWebSocketMessage(userId, testState.sessionId, 'create-transport', {})
expect(res?.type).toBe('transport-created')
expect(res?.data).toBeDefined()
})
it('connect-transport connects with valid params', async () => {
await handleWebSocketMessage(userId, sessionId, 'create-transport', {})
const res = await handleWebSocketMessage(userId, sessionId, 'connect-transport', {
await handleWebSocketMessage(userId, testState.sessionId, 'create-transport', {})
const res = await handleWebSocketMessage(userId, testState.sessionId, 'connect-transport', {
transportId: 'mock-transport',
dtlsParameters: { role: 'client', fingerprints: [] },
})
@@ -76,8 +78,8 @@ describe('webrtcSignaling', () => {
id: 'mock-transport',
connect: vi.fn().mockRejectedValue(new Error('Connection failed')),
})
await handleWebSocketMessage(userId, sessionId, 'create-transport', {})
const res = await handleWebSocketMessage(userId, sessionId, 'connect-transport', {
await handleWebSocketMessage(userId, testState.sessionId, 'create-transport', {})
const res = await handleWebSocketMessage(userId, testState.sessionId, 'connect-transport', {
transportId: 'mock-transport',
dtlsParameters: { role: 'client', fingerprints: [] },
})