first commit
Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled

This commit is contained in:
Arian Tron
2026-03-10 19:37:31 +03:30
commit 61f56f997c
27684 changed files with 2784175 additions and 0 deletions

View File

@@ -0,0 +1 @@
module.exports = {}

View File

@@ -0,0 +1,11 @@
import { NextResponse } from 'next/server'
export const config = {
runtime: 'nodejs',
}
export default function () {
const response = NextResponse.next()
response.headers.set('X-From-Src-Middleware', 'true')
return response
}

View File

@@ -0,0 +1,11 @@
import { NextResponse } from 'next/server'
export const config = {
runtime: 'nodejs',
}
export default function () {
const response = NextResponse.next()
response.headers.set('X-From-Src-Middleware-TS', 'true')
return response
}

View File

@@ -0,0 +1,2 @@
const Page = () => <h1>Hi from SRC</h1>
export default Page

View File

@@ -0,0 +1,139 @@
import fs from 'fs-extra'
import { join } from 'path'
import {
fetchViaHTTP,
File,
findPort,
launchApp,
killApp,
nextBuild,
} from 'next-test-utils'
let app
let appPort
const appDir = join(__dirname, '../')
const nextConfig = new File(join(appDir, 'next.config.js'))
const srcHeader = 'X-From-Src-Middleware'
const rootHeader = 'X-From-Root-Middleware'
const rootMiddlewareJSFile = join(appDir, 'middleware.js')
const rootMiddlewareTSFile = join(appDir, 'middleware.ts')
function runSingleMiddlewareTests() {
it('loads an runs src middleware', async () => {
const response = await fetchViaHTTP(appPort, '/post-1')
expect(response.headers.has(srcHeader)).toBe(false)
expect(response.headers.has(`${srcHeader}-TS`)).toBe(true)
})
}
function runDoubleMiddlewareTests() {
it('loads and runs only root middleware', async () => {
const response = await fetchViaHTTP(appPort, '/post-1')
expect(response.headers.has(srcHeader)).toBe(false)
expect(response.headers.has(`${srcHeader}-TS`)).toBe(false)
expect(response.headers.has(rootHeader)).toBe(false)
expect(response.headers.has(`${rootHeader}-TS`)).toBe(true)
})
}
async function writeRootMiddleware() {
await fs.copy(join(appDir, 'src/pages'), join(appDir, 'pages'), {
// @ts-expect-error
force: true,
recursive: true,
})
await fs.writeFile(
rootMiddlewareJSFile,
`
import { NextResponse } from 'next/server'
export default function () {
const response = NextResponse.next()
response.headers.set('${rootHeader}', 'true')
return response
}`
)
await fs.writeFile(
rootMiddlewareTSFile,
`
import { NextResponse } from 'next/server'
export default function () {
const response = NextResponse.next()
response.headers.set('${rootHeader}-TS', 'true')
return response
}`
)
}
async function removeRootMiddleware() {
await fs.remove(rootMiddlewareJSFile, {
// @ts-expect-error
force: true,
})
await fs.remove(rootMiddlewareTSFile, {
// @ts-expect-error
force: true,
})
await fs.remove(join(appDir, 'pages'), {
// @ts-expect-error
force: true,
recursive: true,
})
}
describe.each([
{
title: 'Middleware in src/ folder',
setup() {},
teardown() {},
runTest: runSingleMiddlewareTests,
},
{
title: 'Middleware in src/ and / folders',
setup: writeRootMiddleware,
teardown: removeRootMiddleware,
runTest: runDoubleMiddlewareTests,
},
])('$title', ({ setup, teardown, runTest }) => {
beforeAll(() => setup())
afterAll(() => teardown())
;(process.env.TURBOPACK_BUILD ? describe.skip : describe)(
'development mode',
() => {
beforeAll(async () => {
appPort = await findPort()
app = await launchApp(appDir, appPort)
})
afterAll(() => killApp(app))
runTest()
}
)
;(process.env.TURBOPACK_DEV ? describe.skip : describe)(
'production mode',
() => {
let exportOutput = ''
beforeAll(async () => {
nextConfig.write(`module.exports = { output: 'export' }`)
const result = await nextBuild(appDir, [], {
stderr: true,
stdout: true,
})
const outdir = join(__dirname, '..', 'out')
await fs.remove(outdir).catch(() => {})
exportOutput = result.stderr + result.stdout
})
afterAll(() => nextConfig.restore())
it('should warn about middleware on export', async () => {
expect(exportOutput).toContain(
'Statically exporting a Next.js application via `next export` disables API routes and middleware.'
)
})
}
)
})