next.js/test/integration/custom-server/server.js
server.js152 lines3.7 KB
// @ts-check

if (process.env.POLYFILL_FETCH) {
  // @ts-expect-error
  global.fetch = require('node-fetch').default
  // @ts-expect-error
  global.Request = require('node-fetch').Request
  // @ts-expect-error
  global.Headers = require('node-fetch').Headers
}

const { readFileSync } = require('fs')

/** @type {import('next').default} */
// @ts-ignore: missing interopDefault
const next = require('next')

const { join } = require('path')
const { parse } = require('url')

const dev = process.env.NODE_ENV !== 'production'
const dir = __dirname
const port =
  (process.env.PORT ? Number.parseInt(process.env.PORT) : undefined) || 3000
const { createServer } = require(
  process.env.USE_HTTPS === 'true' ? 'https' : 'http'
)

const app = next({ dev, hostname: 'localhost', port, dir })
const handleNextRequests = app.getRequestHandler()

const httpOptions = {
  key: readFileSync(join(__dirname, 'ssh/localhost-key.pem')),
  cert: readFileSync(join(__dirname, 'ssh/localhost.pem')),
}

process.on('unhandledRejection', (err) => {
  console.error('unhandledRejection:', err)
})

app.prepare().then(() => {
  const server = createServer(httpOptions, async (req, res) => {
    // let next.js handle assets from /_next/
    if (/\/_next\//.test(req.url)) {
      return handleNextRequests(req, res)
    }

    if (req.url === '/no-query') {
      return app.render(req, res, '/no-query')
    }

    if (req.url === '/unhandled-rejection') {
      Promise.reject(new Error('unhandled rejection'))
      return res.end('ok')
    }

    if (/setAssetPrefix/.test(req.url)) {
      app.setAssetPrefix(`http://127.0.0.1:${port}`)
    } else if (/setEmptyAssetPrefix/.test(req.url)) {
      app.setAssetPrefix('')
    } else {
      // This is to support multi-zones support in localhost
      // and may be in staging deployments
      app.setAssetPrefix('')
    }

    if (/test-index-hmr/.test(req.url)) {
      return app.render(req, res, '/index')
    }

    if (/dashboard/.test(req.url)) {
      return app.render(req, res, '/dashboard')
    }

    if (/static\/hello\.text/.test(req.url)) {
      return app.render(req, res, '/static/hello.text')
    }

    if (/no-slash/.test(req.url)) {
      try {
        await app.render(req, res, 'dashboard')
      } catch (err) {
        res.end(err.message)
      }
    }

    if (/custom-url-with-request-handler/.test(req.url)) {
      return handleNextRequests(req, res, parse('/dashboard', true))
    }

    if (/legacy-methods\/render-to-html/.test(req.url)) {
      try {
        const html = await app.renderToHTML(req, res, '/dynamic-dashboard', {
          q: '1',
        })
        res.end(html)
      } catch (err) {
        res.end(err.message)
      }
      return
    }

    if (/legacy-methods\/render404/.test(req.url)) {
      try {
        await app.render404(req, res, parse('/__non_existent__?q=1', true))
      } catch (err) {
        res.end(err.message)
      }
      return
    }

    if (/legacy-methods\/render-error/.test(req.url)) {
      try {
        res.statusCode = 500
        await app.renderError(new Error('kaboom'), req, res, '/dashboard', {
          q: '1',
        })
      } catch (err) {
        res.end(err.message)
      }
      return
    }

    if (/legacy-methods\/render-error-to-html/.test(req.url)) {
      try {
        res.statusCode = 500
        const html = await app.renderErrorToHTML(
          new Error('kaboom'),
          req,
          res,
          '/dashboard',
          { q: '1' }
        )
        res.end(html)
      } catch (err) {
        res.end(err.message)
      }
      return
    }

    handleNextRequests(req, res)
  })

  server.listen(port, (err) => {
    if (err) {
      throw err
    }

    console.log(`> Ready on http://localhost:${port}`)
  })
})
Quest for Codev2.0.0
/
SIGN IN