next.js/test/e2e/app-dir/metadata/app/cache-deduping/page.tsx
page.tsx33 lines727 B
import React, { cache } from 'react'

const getRandomMemoized = cache(() => Math.random().toString())

async function getRandomMemoizedByFetch() {
  const res = await fetch(
    'https://next-data-api-endpoint.vercel.app/api/random'
  )
  return res.text()
}

export default async function Page(props) {
  const val = getRandomMemoized()
  const val2 = await getRandomMemoizedByFetch()
  return (
    <>
      <p id="value">{val}</p>
      <p id="value2">{val2}</p>
    </>
  )
}

export async function generateMetadata(props, parent) {
  const val = getRandomMemoized()
  const val2 = await getRandomMemoizedByFetch()

  return {
    title: {
      default: JSON.stringify({ page: 'cache-deduping', val, val2 }),
    },
  }
}
Quest for Codev2.0.0
/
SIGN IN