From 1f60647885df0d74bcaa671da332fd02f3a757ae Mon Sep 17 00:00:00 2001 From: gtmnayan <50981692+gtm-nayan@users.noreply.github.com> Date: Thu, 30 May 2024 13:35:41 +0545 Subject: [PATCH] fix: prevent unhandledRejection if `--open` fails (#16726) --- packages/vite/src/node/server/openBrowser.ts | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/packages/vite/src/node/server/openBrowser.ts b/packages/vite/src/node/server/openBrowser.ts index 666a86dd4d4ef4..740df255c70c4a 100644 --- a/packages/vite/src/node/server/openBrowser.ts +++ b/packages/vite/src/node/server/openBrowser.ts @@ -34,7 +34,7 @@ export function openBrowser( const browserArgs = process.env.BROWSER_ARGS ? process.env.BROWSER_ARGS.split(' ') : [] - startBrowserProcess(browser, browserArgs, url) + startBrowserProcess(browser, browserArgs, url, logger) } } @@ -72,6 +72,7 @@ async function startBrowserProcess( browser: string | undefined, browserArgs: string[], url: string, + logger: Logger, ) { // If we're on OS X, the user hasn't specifically // requested a different browser, we can try opening @@ -122,7 +123,17 @@ async function startBrowserProcess( const options: open.Options = browser ? { app: { name: browser, arguments: browserArgs } } : {} - open(url, options).catch(() => {}) // Prevent `unhandledRejection` error. + + new Promise((_, reject) => { + open(url, options) + .then((subprocess) => { + subprocess.on('error', reject) + }) + .catch(reject) + }).catch((err) => { + logger.error(err.stack || err.message) + }) + return true } catch (err) { return false