From e3f837574bdad9dc583028c6f9a9a2f3082d9ecb Mon Sep 17 00:00:00 2001 From: Alexander Akait <4567934+alexander-akait@users.noreply.github.com> Date: Wed, 10 Jan 2024 19:03:44 +0300 Subject: [PATCH] fix: add `ChunkLoadError` name to chunk loading error (#1073) --- src/index.js | 6 ++++-- ...55be87a9aa9996fc905c.css => 0.7f0e5fa686a9bb728e64.css} | 0 .../{55be87a9aa9996fc905c.css => 7f0e5fa686a9bb728e64.css} | 0 .../expected/webpack-5-importModule/main.js | 7 ++++--- ...4a73d63c8c2357971fc6.css => 0.100253bb7576627988e6.css} | 0 .../{4a73d63c8c2357971fc6.css => 100253bb7576627988e6.css} | 0 .../chunkFilename-fullhash/expected/webpack-5/main.js | 7 ++++--- test/cases/hmr/expected/main.js | 5 +++-- test/cases/insert-function/expected/main.js | 5 +++-- test/cases/insert-string/expected/main.js | 5 +++-- test/cases/insert-undefined/expected/main.js | 5 +++-- 11 files changed, 24 insertions(+), 16 deletions(-) rename test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/{0.55be87a9aa9996fc905c.css => 0.7f0e5fa686a9bb728e64.css} (100%) rename test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/{55be87a9aa9996fc905c.css => 7f0e5fa686a9bb728e64.css} (100%) rename test/cases/chunkFilename-fullhash/expected/webpack-5/{0.4a73d63c8c2357971fc6.css => 0.100253bb7576627988e6.css} (100%) rename test/cases/chunkFilename-fullhash/expected/webpack-5/{4a73d63c8c2357971fc6.css => 100253bb7576627988e6.css} (100%) diff --git a/src/index.js b/src/index.js index c23cc837..e47612f1 100644 --- a/src/index.js +++ b/src/index.js @@ -876,9 +876,11 @@ class MiniCssExtractPlugin { Template.indent(["resolve();"]), "} else {", Template.indent([ - "var errorType = event && (event.type === 'load' ? 'missing' : event.type);", + "var errorType = event && event.type;", "var realHref = event && event.target && event.target.href || fullhref;", - 'var err = new Error("Loading CSS chunk " + chunkId + " failed.\\n(" + realHref + ")");', + 'var err = new Error("Loading CSS chunk " + chunkId + " failed.\\n(" + errorType + ": " + realHref + ")");', + 'err.name = "ChunkLoadError";', + // TODO remove `code` in the future major release to align with webpack 'err.code = "CSS_CHUNK_LOAD_FAILED";', "err.type = errorType;", "err.request = realHref;", diff --git a/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/0.55be87a9aa9996fc905c.css b/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/0.7f0e5fa686a9bb728e64.css similarity index 100% rename from test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/0.55be87a9aa9996fc905c.css rename to test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/0.7f0e5fa686a9bb728e64.css diff --git a/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/55be87a9aa9996fc905c.css b/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/7f0e5fa686a9bb728e64.css similarity index 100% rename from test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/55be87a9aa9996fc905c.css rename to test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/7f0e5fa686a9bb728e64.css diff --git a/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/main.js b/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/main.js index 39c43626..42f7a5b2 100644 --- a/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/main.js +++ b/test/cases/chunkFilename-fullhash/expected/webpack-5-importModule/main.js @@ -73,7 +73,7 @@ __webpack_require__.r(__webpack_exports__); /******/ /******/ /* webpack/runtime/getFullHash */ /******/ (() => { -/******/ __webpack_require__.h = () => ("55be87a9aa9996fc905c") +/******/ __webpack_require__.h = () => ("7f0e5fa686a9bb728e64") /******/ })(); /******/ /******/ /* webpack/runtime/global */ @@ -187,9 +187,10 @@ __webpack_require__.r(__webpack_exports__); /******/ if (event.type === 'load') { /******/ resolve(); /******/ } else { -/******/ var errorType = event && (event.type === 'load' ? 'missing' : event.type); +/******/ var errorType = event && event.type; /******/ var realHref = event && event.target && event.target.href || fullhref; -/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + realHref + ")"); +/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + errorType + ": " + realHref + ")"); +/******/ err.name = "ChunkLoadError"; /******/ err.code = "CSS_CHUNK_LOAD_FAILED"; /******/ err.type = errorType; /******/ err.request = realHref; diff --git a/test/cases/chunkFilename-fullhash/expected/webpack-5/0.4a73d63c8c2357971fc6.css b/test/cases/chunkFilename-fullhash/expected/webpack-5/0.100253bb7576627988e6.css similarity index 100% rename from test/cases/chunkFilename-fullhash/expected/webpack-5/0.4a73d63c8c2357971fc6.css rename to test/cases/chunkFilename-fullhash/expected/webpack-5/0.100253bb7576627988e6.css diff --git a/test/cases/chunkFilename-fullhash/expected/webpack-5/4a73d63c8c2357971fc6.css b/test/cases/chunkFilename-fullhash/expected/webpack-5/100253bb7576627988e6.css similarity index 100% rename from test/cases/chunkFilename-fullhash/expected/webpack-5/4a73d63c8c2357971fc6.css rename to test/cases/chunkFilename-fullhash/expected/webpack-5/100253bb7576627988e6.css diff --git a/test/cases/chunkFilename-fullhash/expected/webpack-5/main.js b/test/cases/chunkFilename-fullhash/expected/webpack-5/main.js index c7bd9182..62e0fb02 100644 --- a/test/cases/chunkFilename-fullhash/expected/webpack-5/main.js +++ b/test/cases/chunkFilename-fullhash/expected/webpack-5/main.js @@ -73,7 +73,7 @@ __webpack_require__.r(__webpack_exports__); /******/ /******/ /* webpack/runtime/getFullHash */ /******/ (() => { -/******/ __webpack_require__.h = () => ("4a73d63c8c2357971fc6") +/******/ __webpack_require__.h = () => ("100253bb7576627988e6") /******/ })(); /******/ /******/ /* webpack/runtime/global */ @@ -187,9 +187,10 @@ __webpack_require__.r(__webpack_exports__); /******/ if (event.type === 'load') { /******/ resolve(); /******/ } else { -/******/ var errorType = event && (event.type === 'load' ? 'missing' : event.type); +/******/ var errorType = event && event.type; /******/ var realHref = event && event.target && event.target.href || fullhref; -/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + realHref + ")"); +/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + errorType + ": " + realHref + ")"); +/******/ err.name = "ChunkLoadError"; /******/ err.code = "CSS_CHUNK_LOAD_FAILED"; /******/ err.type = errorType; /******/ err.request = realHref; diff --git a/test/cases/hmr/expected/main.js b/test/cases/hmr/expected/main.js index d8fbcd52..bd36274c 100644 --- a/test/cases/hmr/expected/main.js +++ b/test/cases/hmr/expected/main.js @@ -950,9 +950,10 @@ __webpack_require__.r(__webpack_exports__); /******/ if (event.type === 'load') { /******/ resolve(); /******/ } else { -/******/ var errorType = event && (event.type === 'load' ? 'missing' : event.type); +/******/ var errorType = event && event.type; /******/ var realHref = event && event.target && event.target.href || fullhref; -/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + realHref + ")"); +/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + errorType + ": " + realHref + ")"); +/******/ err.name = "ChunkLoadError"; /******/ err.code = "CSS_CHUNK_LOAD_FAILED"; /******/ err.type = errorType; /******/ err.request = realHref; diff --git a/test/cases/insert-function/expected/main.js b/test/cases/insert-function/expected/main.js index 2fc95f59..20571243 100644 --- a/test/cases/insert-function/expected/main.js +++ b/test/cases/insert-function/expected/main.js @@ -171,9 +171,10 @@ /******/ if (event.type === 'load') { /******/ resolve(); /******/ } else { -/******/ var errorType = event && (event.type === 'load' ? 'missing' : event.type); +/******/ var errorType = event && event.type; /******/ var realHref = event && event.target && event.target.href || fullhref; -/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + realHref + ")"); +/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + errorType + ": " + realHref + ")"); +/******/ err.name = "ChunkLoadError"; /******/ err.code = "CSS_CHUNK_LOAD_FAILED"; /******/ err.type = errorType; /******/ err.request = realHref; diff --git a/test/cases/insert-string/expected/main.js b/test/cases/insert-string/expected/main.js index 77cd9b2f..9f386939 100644 --- a/test/cases/insert-string/expected/main.js +++ b/test/cases/insert-string/expected/main.js @@ -171,9 +171,10 @@ /******/ if (event.type === 'load') { /******/ resolve(); /******/ } else { -/******/ var errorType = event && (event.type === 'load' ? 'missing' : event.type); +/******/ var errorType = event && event.type; /******/ var realHref = event && event.target && event.target.href || fullhref; -/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + realHref + ")"); +/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + errorType + ": " + realHref + ")"); +/******/ err.name = "ChunkLoadError"; /******/ err.code = "CSS_CHUNK_LOAD_FAILED"; /******/ err.type = errorType; /******/ err.request = realHref; diff --git a/test/cases/insert-undefined/expected/main.js b/test/cases/insert-undefined/expected/main.js index 3d950370..8a27fc4c 100644 --- a/test/cases/insert-undefined/expected/main.js +++ b/test/cases/insert-undefined/expected/main.js @@ -171,9 +171,10 @@ /******/ if (event.type === 'load') { /******/ resolve(); /******/ } else { -/******/ var errorType = event && (event.type === 'load' ? 'missing' : event.type); +/******/ var errorType = event && event.type; /******/ var realHref = event && event.target && event.target.href || fullhref; -/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + realHref + ")"); +/******/ var err = new Error("Loading CSS chunk " + chunkId + " failed.\n(" + errorType + ": " + realHref + ")"); +/******/ err.name = "ChunkLoadError"; /******/ err.code = "CSS_CHUNK_LOAD_FAILED"; /******/ err.type = errorType; /******/ err.request = realHref;