next.js/test/e2e/opentelemetry/instrumentation/custom-server.ts
custom-server.ts50 lines1.2 KB
import { createServer } from 'http'
import { parse } from 'url'
import next from 'next'
import getPort from 'get-port'
import { trace } from '@opentelemetry/api'

import { register } from './instrumentation-custom-server'
register()

async function main() {
  const port = await getPort()
  const hostname = 'localhost'

  const app = next({
    dev: process.env.NODE_ENV === 'development',
    hostname,
    port,
    dir: __dirname,
  })
  const handle = app.getRequestHandler()

  await app.prepare()

  const tracer = trace.getTracer('custom-server', '1.0.0')

  createServer((req, res) => {
    // Create a local parent span to simulate custom server behavior
    tracer.startActiveSpan('custom-server-request', async (span) => {
      try {
        const parsedUrl = parse(req.url!, true)
        await handle(req, res, parsedUrl)
        span.end()
      } catch (err) {
        span.recordException(err as Error)
        span.end()
        res.statusCode = 500
        res.end('Internal Server Error')
      }
    })
  }).listen(port, undefined, (err?: Error) => {
    if (err) throw err
    console.log(`- Local: http://${hostname}:${port}`)
  })
}

main().catch((err) => {
  console.error(err)
  process.exit(1)
})
Quest for Codev2.0.0
/
SIGN IN