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,7 @@
export default function Root({ children }: { children: React.ReactNode }) {
return (
<html>
<body>{children}</body>
</html>
)
}

View File

@@ -0,0 +1,12 @@
import { randomInt } from 'node:crypto'
export default async function Page() {
return (
<dl>
<dt>require('node:crypto').randomInt(20)</dt>
<dd>{randomInt(20)}</dd>
<dt>require('node:crypto').randomInt(20, 40)</dt>
<dd>{randomInt(20, 40)}</dd>
</dl>
)
}

View File

@@ -0,0 +1,8 @@
export default async function Page() {
return (
<dl>
<dt>Random number (`Math.random()`):</dt>
<dd>{Math.random()}</dd>
</dl>
)
}

View File

@@ -0,0 +1,14 @@
export default async function Page() {
return (
<dl>
<dt>Current Date (`Date()`):</dt>
<dd>{Date()}</dd>
<dt>Current Date (`new Date().toString()`):</dt>
<dd>{new Date().toString()}</dd>
<dt>Current Timestamp (`Date.now()`):</dt>
<dd>{Date.now()}</dd>
<dt>Current Timestamp (`performance.now()`):</dt>
<dd>{performance.now()}</dd>
</dl>
)
}

View File

@@ -0,0 +1,12 @@
export default async function Page() {
const arr = new Uint8Array(16)
crypto.getRandomValues(arr)
return (
<dl>
<dt>crypto.getRandomValues():</dt>
<dd>{arr.toString()}</dd>
<dt>crypto.randomUUID():</dt>
<dd>{crypto.randomUUID()}</dd>
</dl>
)
}

View File

@@ -0,0 +1,15 @@
import { randomInt } from 'node:crypto'
import { connection } from 'next/server'
export default async function Page() {
await connection()
return (
<dl>
<dt>require('node:crypto').randomInt(20)</dt>
<dd>{randomInt(20)}</dd>
<dt>require('node:crypto').randomInt(20, 40)</dt>
<dd>{randomInt(20, 40)}</dd>
</dl>
)
}

View File

@@ -0,0 +1,11 @@
import { connection } from 'next/server'
export default async function Page() {
await connection()
return (
<dl>
<dt>Random number (`Math.random()`):</dt>
<dd>{Math.random()}</dd>
</dl>
)
}

View File

@@ -0,0 +1,17 @@
import { connection } from 'next/server'
export default async function Page() {
await connection()
return (
<dl>
<dt>Current Date (`Date()`):</dt>
<dd>{Date()}</dd>
<dt>Current Date (`new Date().toString()`):</dt>
<dd>{new Date().toString()}</dd>
<dt>Current Timestamp (`Date.now()`):</dt>
<dd>{Date.now()}</dd>
<dt>Current Timestamp (`performance.now()`):</dt>
<dd>{performance.now()}</dd>
</dl>
)
}

View File

@@ -0,0 +1,15 @@
import { connection } from 'next/server'
export default async function Page() {
await connection()
const arr = new Uint8Array(16)
crypto.getRandomValues(arr)
return (
<dl>
<dt>crypto.getRandomValues():</dt>
<dd>{arr.toString()}</dd>
<dt>crypto.randomUUID():</dt>
<dd>{crypto.randomUUID()}</dd>
</dl>
)
}

View File

@@ -0,0 +1,87 @@
import { nextTestSetup } from 'e2e-utils'
// I am temporarily deactivating these tests. We turned off the dev time warning but will reintroduce it when we add in dev-time prerendering.
// The tests will likely have to change but I'd like to keep the fixture and assertions as a starting point.
describe.skip('dynamic-requests warnings', () => {
const { next } = nextTestSetup({
files: __dirname,
})
let cliIndex = 0
it('warns on reading the current time in the prerender portion of a dev render', async () => {
await next.fetch('/platform/render/time')
expect(next.cliOutput).not.toContain(
'Route "/platform/prerender/time" used `Date()`'
)
expect(next.cliOutput).not.toContain(
'Route "/platform/prerender/time" used `new Date()`'
)
expect(next.cliOutput).not.toContain(
'Route "/platform/prerender/time" used `Date.now()`'
)
expect(next.cliOutput).not.toContain(
'Route "/platform/prerender/time" used `performance.now()`'
)
await next.fetch('/platform/prerender/time')
expect(next.cliOutput).toContain(
'Route "/platform/prerender/time" used `Date()` instead of using `performance` or without explicitly calling `await connection()` beforehand.'
)
expect(next.cliOutput).toContain(
'Route "/platform/prerender/time" used `new Date()` instead of using `performance` or without explicitly calling `await connection()` beforehand.'
)
expect(next.cliOutput).toContain(
'Route "/platform/prerender/time" used `Date.now()` instead of using `performance` or without explicitly calling `await connection()` beforehand.'
)
expect(next.cliOutput).not.toContain(
'Route "/platform/prerender/time" used `performance.now()`'
)
cliIndex = next.cliOutput.length
})
it('warns on reading the random numbers in the prerender portion of a dev render', async () => {
await next.fetch('/platform/render/random')
expect(next.cliOutput.slice(cliIndex)).not.toContain(
'Route /platform/prerender/random used `Math.random()`'
)
await next.fetch('/platform/prerender/random')
expect(next.cliOutput.slice(cliIndex)).toContain(
'Route /platform/prerender/random used `Math.random()` outside of `"use cache"` and without explicitly calling `await connection()` beforehand.'
)
cliIndex = next.cliOutput.length
})
it('warns on reading the random values from web crypto APIs in the prerender portion of a dev render', async () => {
await next.fetch('/platform/render/web-crypto')
expect(next.cliOutput.slice(cliIndex)).not.toContain(
'Route /platform/prerender/web-crypto used `crypto.getRandomValues()`'
)
expect(next.cliOutput.slice(cliIndex)).not.toContain(
'Route /platform/prerender/web-crypto used `crypto.randomUUID()`'
)
await next.fetch('/platform/prerender/web-crypto')
expect(next.cliOutput.slice(cliIndex)).toContain(
'Route /platform/prerender/web-crypto used `crypto.getRandomValues()` outside of `"use cache"` and without explicitly calling `await connection()` beforehand.'
)
expect(next.cliOutput.slice(cliIndex)).toContain(
'Route /platform/prerender/web-crypto used `crypto.randomUUID()` outside of `"use cache"` and without explicitly calling `await connection()` beforehand.'
)
cliIndex = next.cliOutput.length
})
it('warns on reading the random values from node crypto APIs in the prerender portion of a dev render', async () => {
await next.fetch('/platform/render/node-crypto')
expect(next.cliOutput.slice(cliIndex)).not.toContain(
"Route /platform/prerender/node-crypto used `require('node:crypto').randomInt(min, max)`"
)
await next.fetch('/platform/prerender/node-crypto')
expect(next.cliOutput.slice(cliIndex)).toContain(
'Route /platform/prerender/node-crypto used `require(\'node:crypto\').randomInt(min, max)` outside of `"use cache"` and without explicitly calling `await connection()` beforehand.'
)
cliIndex = next.cliOutput.length
})
})

View File

@@ -0,0 +1,3 @@
module.exports = {
cacheComponents: true,
}