fix tests. msw has issues on firefox with vitest isolation.
This commit is contained in:
parent
f3c77afff1
commit
9d24782cd8
11 changed files with 592 additions and 863 deletions
82
test/fixtures/mock_api.js
vendored
82
test/fixtures/mock_api.js
vendored
|
|
@ -1,73 +1,19 @@
|
|||
import { HttpResponse, http } from 'msw'
|
||||
import { setupWorker } from 'msw/browser'
|
||||
import { test as testBase } from 'vitest'
|
||||
|
||||
export const testServer = ''
|
||||
import { worker } from './worker.js'
|
||||
|
||||
// https://mswjs.io/docs/recipes/vitest-browser-mode
|
||||
export const injectMswToTest = (defaultHandlers) => {
|
||||
const worker = setupWorker(...defaultHandlers)
|
||||
export const test = testBase.extend({
|
||||
worker: [
|
||||
// biome-ignore lint: required by vitest
|
||||
async ({}, use) => {
|
||||
await worker.start()
|
||||
|
||||
return testBase.extend({
|
||||
worker: [
|
||||
// biome-ignore lint: required by vitest
|
||||
async ({}, use) => {
|
||||
await worker.start()
|
||||
await use(worker)
|
||||
|
||||
await use(worker)
|
||||
|
||||
worker.resetHandlers()
|
||||
worker.stop()
|
||||
},
|
||||
{
|
||||
auto: true,
|
||||
},
|
||||
],
|
||||
})
|
||||
}
|
||||
|
||||
export const authApis = [
|
||||
http.post('/api/v1/apps', () => {
|
||||
return HttpResponse.json({
|
||||
client_id: 'test-id',
|
||||
client_secret: 'test-secret',
|
||||
})
|
||||
}),
|
||||
http.get('/api/v1/apps/verify_credentials', ({ request }) => {
|
||||
const authHeader = request.headers.get('Authorization')
|
||||
if (
|
||||
authHeader === 'Bearer test-app-token' ||
|
||||
authHeader === 'Bearer also-good-app-token'
|
||||
) {
|
||||
return HttpResponse.json({})
|
||||
} else {
|
||||
// Pleroma 2.9.0 gives the following respoonse upon error
|
||||
return HttpResponse.json(
|
||||
{ error: { detail: 'Internal server error' } },
|
||||
{
|
||||
status: 400,
|
||||
},
|
||||
)
|
||||
}
|
||||
}),
|
||||
http.post('/oauth/token', async ({ request }) => {
|
||||
const data = await request.formData()
|
||||
|
||||
if (
|
||||
data.get('client_id') === 'test-id' &&
|
||||
data.get('client_secret') === 'test-secret' &&
|
||||
data.get('grant_type') === 'client_credentials' &&
|
||||
data.has('redirect_uri')
|
||||
) {
|
||||
return HttpResponse.json({ access_token: 'test-app-token' })
|
||||
} else {
|
||||
// Pleroma 2.9.0 gives the following respoonse upon error
|
||||
return HttpResponse.json(
|
||||
{ error: 'Invalid credentials' },
|
||||
{
|
||||
status: 400,
|
||||
},
|
||||
)
|
||||
}
|
||||
}),
|
||||
]
|
||||
worker.resetHandlers()
|
||||
},
|
||||
{
|
||||
auto: true,
|
||||
},
|
||||
],
|
||||
})
|
||||
|
|
|
|||
8
test/fixtures/worker.js
vendored
Normal file
8
test/fixtures/worker.js
vendored
Normal file
|
|
@ -0,0 +1,8 @@
|
|||
import { setupWorker } from 'msw/browser'
|
||||
|
||||
export const worker = setupWorker()
|
||||
|
||||
console.log('=============== TEST ===============')
|
||||
console.log(window.__test__)
|
||||
console.log('=============== TEST ===============')
|
||||
window.__test__ = window.__test__ || 'TEST'
|
||||
Loading…
Add table
Add a link
Reference in a new issue