Skip to content

Commit

Permalink
test: run ssr-conditions build test (vitejs#18695)
Browse files Browse the repository at this point in the history
  • Loading branch information
sapphi-red authored Nov 19, 2024
1 parent 473424e commit 7b6c59e
Show file tree
Hide file tree
Showing 5 changed files with 97 additions and 44 deletions.
31 changes: 29 additions & 2 deletions playground/ssr-conditions/__tests__/serve.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,42 @@

import path from 'node:path'
import kill from 'kill-port'
import { hmrPorts, ports, rootDir } from '~utils'
import { hmrPorts, isBuild, ports, rootDir } from '~utils'

export const port = ports['ssr-conditions']

export async function serve(): Promise<{ close(): Promise<void> }> {
if (isBuild) {
// build first
const { build } = await import('vite')
// client build
await build({
root: rootDir,
logLevel: 'silent', // exceptions are logged by Vitest
build: {
minify: false,
outDir: 'dist/client',
},
})
// server build
await build({
root: rootDir,
logLevel: 'silent',
build: {
ssr: 'src/app.js',
outDir: 'dist/server',
},
})
}

await kill(port)

const { createServer } = await import(path.resolve(rootDir, 'server.js'))
const { app, vite } = await createServer(rootDir, hmrPorts['ssr-conditions'])
const { app, vite } = await createServer(
rootDir,
isBuild,
hmrPorts['ssr-conditions'],
)

return new Promise((resolve, reject) => {
try {
Expand Down
33 changes: 17 additions & 16 deletions playground/ssr-conditions/__tests__/ssr-conditions.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,24 +11,25 @@ test('ssr.resolve.conditions affect non-externalized imports during ssr', async
)
})

test('ssr.resolve.externalConditions affect externalized imports during ssr', async () => {
await page.goto(url)
expect(await page.textContent('.external-react-server')).toMatch('edge.js')
})

// externalConditions is only used for dev
test.runIf(isServe)(
'ssr.resolve settings do not affect non-ssr imports',
'ssr.resolve.externalConditions affect externalized imports during ssr',
async () => {
await page.goto(url)
await withRetry(async () => {
expect(
await page.textContent('.browser-no-external-react-server'),
).toMatch('default.js')
})
await withRetry(async () => {
expect(await page.textContent('.browser-external-react-server')).toMatch(
'default.js',
)
})
expect(await page.textContent('.external-react-server')).toMatch('edge.js')
},
)

test('ssr.resolve settings do not affect non-ssr imports', async () => {
await page.goto(url)
await withRetry(async () => {
expect(await page.textContent('.browser-no-external-react-server')).toMatch(
'default.js',
)
})
await withRetry(async () => {
expect(await page.textContent('.browser-external-react-server')).toMatch(
'default.js',
)
})
})
6 changes: 5 additions & 1 deletion playground/ssr-conditions/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@
"type": "module",
"scripts": {
"dev": "node server",
"build": "npm run build:client && npm run build:server",
"build:client": "vite build --outDir dist/client",
"build:server": "vite build --ssr src/app.js --outDir dist/server",
"serve": "NODE_ENV=production node server",
"debug": "node --inspect-brk server"
},
Expand All @@ -13,6 +16,7 @@
"@vitejs/test-ssr-conditions-no-external": "file:./no-external"
},
"devDependencies": {
"express": "^5.0.1"
"express": "^5.0.1",
"sirv": "^3.0.0"
}
}
68 changes: 43 additions & 25 deletions playground/ssr-conditions/server.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,49 +2,67 @@ import fs from 'node:fs'
import path from 'node:path'
import { fileURLToPath } from 'node:url'
import express from 'express'
import sirv from 'sirv'

const __dirname = path.dirname(fileURLToPath(import.meta.url))

const isTest = process.env.VITEST

export async function createServer(root = process.cwd(), hmrPort) {
export async function createServer(
root = process.cwd(),
isProd = process.env.NODE_ENV === 'production',
hmrPort,
) {
const resolve = (p) => path.resolve(__dirname, p)

const indexProd = isProd
? fs.readFileSync(resolve('dist/client/index.html'), 'utf-8')
: ''

const app = express()

/**
* @type {import('vite').ViteDevServer}
*/
const vite = await (
await import('vite')
).createServer({
root,
logLevel: isTest ? 'error' : 'info',
server: {
middlewareMode: true,
watch: {
// During tests we edit the files too fast and sometimes chokidar
// misses change events, so enforce polling for consistency
usePolling: true,
interval: 100,
},
hmr: {
port: hmrPort,
let vite
if (!isProd) {
vite = await (
await import('vite')
).createServer({
root,
logLevel: isTest ? 'error' : 'info',
server: {
middlewareMode: true,
watch: {
// During tests we edit the files too fast and sometimes chokidar
// misses change events, so enforce polling for consistency
usePolling: true,
interval: 100,
},
hmr: {
port: hmrPort,
},
},
},
appType: 'custom',
})

app.use(vite.middlewares)
appType: 'custom',
})
app.use(vite.middlewares)
} else {
app.use(sirv(resolve('dist/client'), { extensions: [] }))
}

app.use('*all', async (req, res) => {
try {
const url = req.originalUrl

let template
template = fs.readFileSync(resolve('index.html'), 'utf-8')
template = await vite.transformIndexHtml(url, template)
const render = (await vite.ssrLoadModule('/src/app.js')).render
let template, render
if (!isProd) {
template = fs.readFileSync(resolve('index.html'), 'utf-8')
template = await vite.transformIndexHtml(url, template)
render = (await vite.ssrLoadModule('/src/app.js')).render
} else {
template = indexProd
render = (await import('./dist/server/app.js')).render
}

const appHtml = await render(url, __dirname)

Expand Down
3 changes: 3 additions & 0 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 7b6c59e

Please sign in to comment.