From 2eeebacb4c99c5f1e4a22a721a7c8a3dc9538e60 Mon Sep 17 00:00:00 2001 From: Bertrand Marron Date: Mon, 3 Sep 2018 01:40:21 +0200 Subject: [PATCH] Keep chunks filenames in production mode (#5029) * Keep chunks filenames in production mode * Add test for new `[name]` behavior * Rename static/dll to static/development/dll --- build/webpack.js | 4 ++-- .../webpack/plugins/build-manifest-plugin.js | 2 +- .../basic/components/hello-chunkfilename.js | 1 + .../basic/pages/dynamic/chunkfilename.js | 5 +++++ test/integration/basic/test/dynamic.js | 20 +++++++++++++++++++ 5 files changed, 29 insertions(+), 3 deletions(-) create mode 100644 test/integration/basic/components/hello-chunkfilename.js create mode 100644 test/integration/basic/pages/dynamic/chunkfilename.js diff --git a/build/webpack.js b/build/webpack.js index d3611186..b2b4d7ab 100644 --- a/build/webpack.js +++ b/build/webpack.js @@ -181,7 +181,7 @@ export default async function getBaseWebpackConfig (dir: string, {dev = false, i hotUpdateChunkFilename: 'static/webpack/[id].[hash].hot-update.js', hotUpdateMainFilename: 'static/webpack/[hash].hot-update.json', // This saves chunks with the name given via `import()` - chunkFilename: isServer ? `${dev ? '[name]' : '[contenthash]'}.js` : `static/chunks/${dev ? '[name]' : '[contenthash]'}.js`, + chunkFilename: isServer ? `${dev ? '[name]' : '[name].[contenthash]'}.js` : `static/chunks/${dev ? '[name]' : '[name].[contenthash]'}.js`, strictModuleExceptionHandling: true }, performance: { hints: false }, @@ -213,7 +213,7 @@ export default async function getBaseWebpackConfig (dir: string, {dev = false, i // Precompile react / react-dom for development, speeding up webpack dev && !isServer && new AutoDllPlugin({ filename: '[name]_[hash].js', - path: './static/dll', + path: './static/development/dll', context: dir, entry: { dll: [ diff --git a/build/webpack/plugins/build-manifest-plugin.js b/build/webpack/plugins/build-manifest-plugin.js index e6ab06f5..2139b6c3 100644 --- a/build/webpack/plugins/build-manifest-plugin.js +++ b/build/webpack/plugins/build-manifest-plugin.js @@ -15,7 +15,7 @@ export default class BuildManifestPlugin { for (const filePath of Object.keys(compilation.assets)) { const path = filePath.replace(/\\/g, '/') - if (/^static\/dll\//.test(path)) { + if (/^static\/development\/dll\//.test(path)) { assetMap.devFiles.push(path) } } diff --git a/test/integration/basic/components/hello-chunkfilename.js b/test/integration/basic/components/hello-chunkfilename.js new file mode 100644 index 00000000..9b1412df --- /dev/null +++ b/test/integration/basic/components/hello-chunkfilename.js @@ -0,0 +1 @@ +export default () =>
test chunkfilename
diff --git a/test/integration/basic/pages/dynamic/chunkfilename.js b/test/integration/basic/pages/dynamic/chunkfilename.js new file mode 100644 index 00000000..87d12af5 --- /dev/null +++ b/test/integration/basic/pages/dynamic/chunkfilename.js @@ -0,0 +1,5 @@ +import dynamic from 'next/dynamic' + +const Hello = dynamic(import(/* webpackChunkName: 'hello-world' */'../../components/hello-chunkfilename')) + +export default Hello diff --git a/test/integration/basic/test/dynamic.js b/test/integration/basic/test/dynamic.js index 8ce01510..1114fdf1 100644 --- a/test/integration/basic/test/dynamic.js +++ b/test/integration/basic/test/dynamic.js @@ -63,6 +63,26 @@ export default (context, render) => { }) }) + describe('custom chunkfilename', () => { + it('should render the correct filename', async () => { + const $ = await get$('/dynamic/chunkfilename') + expect($('body').text()).toMatch(/test chunkfilename/) + expect($('html').html()).toMatch(/hello-world\.js/) + }) + + it('should render the component on client side', async () => { + let browser + try { + browser = await webdriver(context.appPort, '/dynamic/chunkfilename') + await check(() => browser.elementByCss('body').text(), /test chunkfilename/) + } finally { + if (browser) { + browser.close() + } + } + }) + }) + describe('custom loading', () => { it('should render custom loading on the server side when `ssr:false` and `loading` is provided', async () => { const $ = await get$('/dynamic/no-ssr-custom-loading')