mirror of
https://github.com/vitest-dev/vitest.git
synced 2025-12-08 18:26:03 +00:00
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Vladimir Sheremet <sleuths.slews0s@icloud.com>
88 lines
2.3 KiB
TypeScript
88 lines
2.3 KiB
TypeScript
import { fileURLToPath } from 'node:url'
|
|
import { basename, resolve } from 'pathe'
|
|
import sirv from 'sirv'
|
|
import type { Plugin } from 'vite'
|
|
import { coverageConfigDefaults } from 'vitest/config'
|
|
import type { Vitest } from 'vitest'
|
|
import { toArray } from '@vitest/utils'
|
|
|
|
export default (ctx: Vitest): Plugin => {
|
|
return <Plugin>{
|
|
name: 'vitest:ui',
|
|
apply: 'serve',
|
|
configureServer(server) {
|
|
const uiOptions = ctx.config
|
|
const base = uiOptions.uiBase
|
|
const coverageFolder = resolveCoverageFolder(ctx)
|
|
const coveragePath = coverageFolder ? coverageFolder[1] : undefined
|
|
if (coveragePath && base === coveragePath) {
|
|
throw new Error(
|
|
`The ui base path and the coverage path cannot be the same: ${base}, change coverage.reportsDirectory`,
|
|
)
|
|
}
|
|
|
|
if (coverageFolder) {
|
|
server.middlewares.use(
|
|
coveragePath!,
|
|
sirv(coverageFolder[0], {
|
|
single: true,
|
|
dev: true,
|
|
setHeaders: (res) => {
|
|
res.setHeader(
|
|
'Cache-Control',
|
|
'public,max-age=0,must-revalidate',
|
|
)
|
|
},
|
|
}),
|
|
)
|
|
}
|
|
|
|
const clientDist = resolve(fileURLToPath(import.meta.url), '../client')
|
|
server.middlewares.use(
|
|
base,
|
|
sirv(clientDist, {
|
|
single: true,
|
|
dev: true,
|
|
}),
|
|
)
|
|
},
|
|
}
|
|
}
|
|
|
|
function resolveCoverageFolder(ctx: Vitest) {
|
|
const options = ctx.config
|
|
const htmlReporter
|
|
= options.api?.port && options.coverage?.enabled
|
|
? toArray(options.coverage.reporter).find((reporter) => {
|
|
if (typeof reporter === 'string') {
|
|
return reporter === 'html'
|
|
}
|
|
|
|
return reporter[0] === 'html'
|
|
})
|
|
: undefined
|
|
|
|
if (!htmlReporter) {
|
|
return undefined
|
|
}
|
|
|
|
// reportsDirectory not resolved yet
|
|
const root = resolve(
|
|
ctx.config?.root || options.root || process.cwd(),
|
|
options.coverage.reportsDirectory || coverageConfigDefaults.reportsDirectory,
|
|
)
|
|
|
|
const subdir
|
|
= Array.isArray(htmlReporter)
|
|
&& htmlReporter.length > 1
|
|
&& 'subdir' in htmlReporter[1]
|
|
? htmlReporter[1].subdir
|
|
: undefined
|
|
|
|
if (!subdir || typeof subdir !== 'string') {
|
|
return [root, `/${basename(root)}/`]
|
|
}
|
|
|
|
return [resolve(root, subdir), `/${basename(root)}/${subdir}/`]
|
|
}
|