pleroma-fe/test/fixtures/mock_api.js

73 lines
1.9 KiB
JavaScript
Raw Normal View History

2026-01-06 16:23:17 +02:00
import { HttpResponse, http } from 'msw'
2025-03-09 15:06:19 -04:00
import { setupWorker } from 'msw/browser'
2026-01-06 16:23:17 +02:00
import { test as testBase } from 'vitest'
2025-03-09 15:06:19 -04:00
// https://mswjs.io/docs/recipes/vitest-browser-mode
export const injectMswToTest = (defaultHandlers) => {
const worker = setupWorker(...defaultHandlers)
return testBase.extend({
worker: [
2026-01-06 18:38:00 +02:00
// biome-ignore lint: required by vitest
async ({}, use) => {
2025-03-09 15:06:19 -04:00
await worker.start()
await use(worker)
worker.resetHandlers()
worker.stop()
},
{
2026-01-06 16:22:52 +02:00
auto: true,
},
2025-03-09 15:06:19 -04:00
],
})
}
export const testServer = 'https://test.server.example'
export const authApis = [
http.post(`${testServer}/api/v1/apps`, () => {
return HttpResponse.json({
client_id: 'test-id',
2026-01-06 16:22:52 +02:00
client_secret: 'test-secret',
2025-03-09 15:06:19 -04:00
})
}),
http.get(`${testServer}/api/v1/apps/verify_credentials`, ({ request }) => {
const authHeader = request.headers.get('Authorization')
2026-01-06 16:22:52 +02:00
if (
authHeader === 'Bearer test-app-token' ||
authHeader === 'Bearer also-good-app-token'
) {
2025-03-09 15:06:19 -04:00
return HttpResponse.json({})
} else {
// Pleroma 2.9.0 gives the following respoonse upon error
2026-01-06 16:22:52 +02:00
return HttpResponse.json(
{ error: { detail: 'Internal server error' } },
{
status: 400,
},
)
2025-03-09 15:06:19 -04:00
}
}),
http.post(`${testServer}/oauth/token`, async ({ request }) => {
const data = await request.formData()
2026-01-06 16:22:52 +02:00
if (
data.get('client_id') === 'test-id' &&
data.get('client_secret') === 'test-secret' &&
data.get('grant_type') === 'client_credentials' &&
data.has('redirect_uri')
) {
2025-03-09 15:06:19 -04:00
return HttpResponse.json({ access_token: 'test-app-token' })
} else {
// Pleroma 2.9.0 gives the following respoonse upon error
2026-01-06 16:22:52 +02:00
return HttpResponse.json(
{ error: 'Invalid credentials' },
{
status: 400,
},
)
2025-03-09 15:06:19 -04:00
}
2026-01-06 16:22:52 +02:00
}),
2025-03-09 15:06:19 -04:00
]