Analyzing Bundles
You can analyze webpack’s generated bundles using webpack-bundle-analyzer.
- require
BundleAnalyzerPlugin
at the top of yourember-cli-build.js
file:
const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');
- Configure webpack to use this plugin through embroider’s
webpackConfig
option:
return require('@embroider/compat').compatBuild(app, Webpack, {
packagerOptions: {
webpackConfig: {
plugins: [new BundleAnalyzerPlugin()]
}
}
});
Note this step modifies the snippet as described in step 2 in the README.md.
Analyzer server
Webpack Bundle Analyzer will spin up an additional server which serves a page that you can visit in the browser to see the results. That server is started no matter if one runs ember build
or ember serve
. To disable the server pass the following config to the instantiation of BundleAnalyzerPlugin()
in the snippet above.
//...
new BundleAnalyzerPlugin({
generateStatsFile: true,
openAnalyzer: false,
statsFilename: path.join(
process.cwd(),
'concat-stats-for',
'my-stats.json',
),
})
//...
With that configuration the results will be written to a json file in your projects directory.
Include legacy addons in analyzation
The results will not show the contents of vendor.js, which provides legacy support for addons that import things into script context and doesn’t go through webpack. To see what is contributing to the size of vendor.js, set the environment variable EMBROIDER_CONCAT_STATS=true
like:
EMBROIDER_CONCAT_STATS=true ember build
Which will cause your build to print output like:
Concatenated assets/vendor.js:
./node_modules/@embroider/synthesized-vendor/vendor/ember/ember.debug.js: 1.76 MB
./node_modules/@embroider/synthesized-vendor/vendor/jquery/jquery.js: 265.38 KB
./node_modules/@embroider/synthesized-vendor/vendor/hammerjs/hammer.js: 72.1 KB
./node_modules/@embroider/synthesized-vendor/vendor/loader/loader.js: 8.75 KB
./node_modules/@embroider/synthesized-vendor/vendor/propagating-hammerjs/propagating.js: 7.34 KB
in-memory: 85 B
./node_modules/@embroider/synthesized-vendor/vendor/ember-paper/register-version.js: 57 B
Concatenated assets/test-support.js:
./node_modules/@embroider/synthesized-vendor/vendor/qunit/qunit.js: 148.2 KB
./node_modules/@embroider/synthesized-vendor/vendor/ember/ember-testing.js: 76.44 KB
./node_modules/@embroider/synthesized-vendor/vendor/qunit-dom.js: 37.67 KB
./node_modules/@embroider/synthesized-vendor/vendor/monkey-patches.js: 1.32 KB
./node_modules/@embroider/synthesized-vendor/vendor/ember-qunit/qunit-configuration.js: 491 B
./node_modules/@embroider/synthesized-vendor/vendor/overwrite-qunit-dom-root-element.js: 181 B
./node_modules/@embroider/synthesized-vendor/vendor/define-dummy-module.js: 54 B
Concatenated assets/test-support.css:
./node_modules/@embroider/synthesized-vendor/vendor/qunit/qunit.css: 7.69 KB
./node_modules/@embroider/synthesized-vendor/vendor/ember-qunit/test-container-styles.css: 544 B