From 69fed413ca80d3c39687ebb7ba70ff9b59837d70 Mon Sep 17 00:00:00 2001 From: eps1lon Date: Wed, 23 Oct 2024 20:56:01 +0200 Subject: [PATCH] Ensure expando properties are copied --- packages/next/src/server/patch-error-inspect.ts | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/packages/next/src/server/patch-error-inspect.ts b/packages/next/src/server/patch-error-inspect.ts index b81e89df734b38..a89ed1bde88d8c 100644 --- a/packages/next/src/server/patch-error-inspect.ts +++ b/packages/next/src/server/patch-error-inspect.ts @@ -197,6 +197,14 @@ export function patchErrorInspect() { // TODO: Ensure `class MyError extends Error {}` prints `MyError` as the name newError.stack = parseAndSourceMap(this) + for (const key in this) { + if (!Object.prototype.hasOwnProperty.call(newError, key)) { + // @ts-expect-error -- We're copying all enumerable properties. + // So they definitely exist on `this` and obviously have no type on `newError` (yet) + newError[key] = this[key] + } + } + const originalCustomInspect = (newError as any)[inspectSymbol] // Prevent infinite recursion. // { customInspect: false } would result in `error.cause` not using our inspect.