From 8760293d6836dac554d1d6f214b8b09ed97cccd4 Mon Sep 17 00:00:00 2001 From: patak <583075+patak-dev@users.noreply.github.com> Date: Wed, 11 Sep 2024 10:04:06 +0200 Subject: [PATCH] fix(preload): backport #18046, allow ignoring dep errors (#18076) Co-authored-by: Daniel Roe --- .../src/node/plugins/importAnalysisBuild.ts | 20 +++++++++++-------- .../__tests__/js-sourcemap.spec.ts | 2 +- 2 files changed, 13 insertions(+), 9 deletions(-) diff --git a/packages/vite/src/node/plugins/importAnalysisBuild.ts b/packages/vite/src/node/plugins/importAnalysisBuild.ts index 3922cee10de128..f83bdd59c4ee43 100644 --- a/packages/vite/src/node/plugins/importAnalysisBuild.ts +++ b/packages/vite/src/node/plugins/importAnalysisBuild.ts @@ -81,7 +81,8 @@ function preload( deps?: string[], importerUrl?: string, ) { - let promise: Promise = Promise.resolve() + let promise: Promise[] | void> = + Promise.resolve() // @ts-expect-error __VITE_IS_MODERN__ will be replaced with boolean later if (__VITE_IS_MODERN__ && deps && deps.length > 0) { const links = document.getElementsByTagName('link') @@ -93,7 +94,7 @@ function preload( // in that case fallback to getAttribute const cspNonce = cspNonceMeta?.nonce || cspNonceMeta?.getAttribute('nonce') - promise = Promise.all( + promise = Promise.allSettled( deps.map((dep) => { // @ts-expect-error assetsURL is declared before preload.toString() dep = assetsURL(dep, importerUrl) @@ -144,18 +145,21 @@ function preload( ) } - return promise - .then(() => baseModule()) - .catch((err) => { + return promise.then((res) => { + for (const item of res || []) { + if (item.status !== 'rejected') continue + const e = new Event('vite:preloadError', { cancelable: true, }) as VitePreloadErrorEvent - e.payload = err + e.payload = item.reason window.dispatchEvent(e) if (!e.defaultPrevented) { - throw err + throw item.reason } - }) + } + return baseModule() + }) } /** diff --git a/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts b/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts index 5bff1b8235afd9..dd1d3151603af5 100644 --- a/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts +++ b/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts @@ -140,7 +140,7 @@ describe.runIf(isBuild)('build tests', () => { expect(formatSourcemapForSnapshot(JSON.parse(map))).toMatchInlineSnapshot(` { "ignoreList": [], - "mappings": ";63BAAA,OAAO,2BAAuB,EAAC,wBAE/B,QAAQ,IAAI,uBAAuB", + "mappings": ";s8BAAA,OAAO,2BAAuB,EAAC,wBAE/B,QAAQ,IAAI,uBAAuB", "sources": [ "../../after-preload-dynamic.js", ],