From a8089258f2647055b51846cf909e73c7a3fdb82d Mon Sep 17 00:00:00 2001 From: fi3ework Date: Fri, 9 Aug 2024 00:56:23 +0800 Subject: [PATCH] fix(modern-module): correct use bailout reason --- .../src/modern_module_library_plugin.rs | 15 ++- .../tests/__snapshots__/Config.test.js.snap | 93 +++++++++++++++++++ .../modern-module-force-concaten/f/bar.cjs | 3 + .../modern-module-force-concaten/f/foo.js | 1 + .../modern-module-force-concaten/f/index.js | 6 ++ .../rspack.config.js | 7 +- 6 files changed, 119 insertions(+), 6 deletions(-) create mode 100644 packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/bar.cjs create mode 100644 packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/foo.js create mode 100644 packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/index.js diff --git a/crates/rspack_plugin_library/src/modern_module_library_plugin.rs b/crates/rspack_plugin_library/src/modern_module_library_plugin.rs index a750d465e03..edb487e7278 100644 --- a/crates/rspack_plugin_library/src/modern_module_library_plugin.rs +++ b/crates/rspack_plugin_library/src/modern_module_library_plugin.rs @@ -75,12 +75,17 @@ impl ModernModuleLibraryPlugin { .iter() .filter(|id| !concatenated_module_ids.contains(id)) .filter(|id| { - let module = module_graph - .module_by_identifier(id) + let mgm = module_graph + .module_graph_module_by_identifier(id) .expect("should have module"); - module - .get_concatenation_bailout_reason(&module_graph, &compilation.chunk_graph) - .is_none() + let reasons = &mgm.optimization_bailout; + reasons + .iter() + // We did want force concatenate entry point here. + // TODO: use constant variable to identify the reason. + .filter(|r| !r.contains("Module is an entry point")) + .collect::>() + .is_empty() }) .collect::>(); diff --git a/packages/rspack-test-tools/tests/__snapshots__/Config.test.js.snap b/packages/rspack-test-tools/tests/__snapshots__/Config.test.js.snap index 68c74e2437e..d937cf09dc5 100644 --- a/packages/rspack-test-tools/tests/__snapshots__/Config.test.js.snap +++ b/packages/rspack-test-tools/tests/__snapshots__/Config.test.js.snap @@ -458,6 +458,99 @@ const d = 'd' " `; +exports[`config config/library/modern-module-force-concaten step should pass: external module should bail out when bundling 1`] = ` +"import { createRequire as __WEBPACK_EXTERNAL_createRequire } from \\"module\\"; +var __webpack_modules__ = ({ +\\"17\\": (function (module) { +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)(\\"path\\"); + +}), +\\"441\\": (function (module, __unused_webpack_exports, __webpack_require__) { +const path = __webpack_require__(17) + +module.exports = path.sep + + +}), + +}); +/************************************************************************/ +// The module cache +var __webpack_module_cache__ = {}; + +// The require function +function __webpack_require__(moduleId) { + +// Check if module is in cache +var cachedModule = __webpack_module_cache__[moduleId]; +if (cachedModule !== undefined) { +return cachedModule.exports; +} +// Create a new module (and put it into the cache) +var module = (__webpack_module_cache__[moduleId] = { +exports: {} +}); +// Execute the module function +__webpack_modules__[moduleId](module, module.exports, __webpack_require__); + +// Return the exports of the module +return module.exports; + +} + +/************************************************************************/ +// webpack/runtime/compat_get_default_export +(() => { +// getDefaultExport function for compatibility with non-harmony modules +__webpack_require__.n = function (module) { + var getter = module && module.__esModule ? + function () { return module['default']; } : + function () { return module; }; + __webpack_require__.d(getter, { a: getter }); + return getter; +}; + + + + +})(); +// webpack/runtime/define_property_getters +(() => { +__webpack_require__.d = function(exports, definition) { + for(var key in definition) { + if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { + Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); + } + } +}; +})(); +// webpack/runtime/has_own_property +(() => { +__webpack_require__.o = function (obj, prop) { + return Object.prototype.hasOwnProperty.call(obj, prop); +}; + +})(); +/************************************************************************/ + +// EXTERNAL MODULE: ./f/bar.cjs +var bar = __webpack_require__(\\"441\\"); +var bar_default = /*#__PURE__*/__webpack_require__.n(bar); +;// CONCATENATED MODULE: ./f/foo.js +const foo = 'foo' + +;// CONCATENATED MODULE: ./f/index.js + + + +const value = foo + (bar_default()) + + + +export { value }; +" +`; + exports[`config config/library/modern-module-force-concaten step should pass: harmony export should concat 1`] = ` " ;// CONCATENATED MODULE: ./a.js diff --git a/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/bar.cjs b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/bar.cjs new file mode 100644 index 00000000000..3cc5ba41107 --- /dev/null +++ b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/bar.cjs @@ -0,0 +1,3 @@ +const path = require('path') + +module.exports = path.sep diff --git a/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/foo.js b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/foo.js new file mode 100644 index 00000000000..cb356468240 --- /dev/null +++ b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/foo.js @@ -0,0 +1 @@ +export const foo = 'foo' diff --git a/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/index.js b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/index.js new file mode 100644 index 00000000000..8c7e2d15918 --- /dev/null +++ b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/f/index.js @@ -0,0 +1,6 @@ +import bar from './bar.cjs' +import { foo } from './foo' + +const value = foo + bar + +export { value } diff --git a/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/rspack.config.js b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/rspack.config.js index faeec85c0d6..32266e35d00 100644 --- a/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/rspack.config.js +++ b/packages/rspack-test-tools/tests/configCases/library/modern-module-force-concaten/rspack.config.js @@ -5,7 +5,11 @@ module.exports = { "b": "./b.cjs", "c": "./c.js", "d": "./d.mjs", - "e": "./e/index.js" + "e": "./e/index.js", + "f": "./f/index.js" + }, + externals: { + path: 'node-commonjs path', }, output: { filename: `[name].js`, @@ -34,6 +38,7 @@ module.exports = { expect(assets['c.js']._value).toMatchSnapshot("unambiguous should bail out"); expect(assets['d.js']._value).toMatchSnapshot(".mjs should concat"); expect(assets['e.js']._value).toMatchSnapshot(".cjs should bail out when bundling"); + expect(assets['f.js']._value).toMatchSnapshot("external module should bail out when bundling"); }); }; this.hooks.compilation.tap("testcase", handler);