Skip to content

Commit

Permalink
Do not run TerserPlugin in parallel
Browse files Browse the repository at this point in the history
* especially in production mode this may lead to OOM issues on
smaller/shared build nodes

Contributed on behalf of STMicroelectronics
  • Loading branch information
jfaltermeier committed Sep 2, 2024
1 parent bef51f3 commit f3e185c
Showing 1 changed file with 24 additions and 0 deletions.
24 changes: 24 additions & 0 deletions applications/electron/webpack.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
// @ts-check
const configs = require('./gen-webpack.config.js');
const nodeConfig = require('./gen-webpack.node.config.js');
const TerserPlugin = require('terser-webpack-plugin');

/**
* Expose bundled modules on window.theia.moduleName namespace, e.g.
Expand All @@ -15,6 +16,29 @@ configs[0].module.rules.push({
loader: require.resolve('@theia/application-manager/lib/expose-loader')
}); */

/**
* Do no run TerserPlugin with parallel: true
* Each spawned node may take the full memory configured via NODE_OPTIONS / --max_old_space_size
* In total this may lead to OOM issues
*/
if (nodeConfig.config.optimization) {
nodeConfig.config.optimization.minimizer = [
new TerserPlugin({
parallel: false,
exclude: /^(lib|builtins)\//
})
];
}
for (const config of configs) {
config.optimization = {
minimizer: [
new TerserPlugin({
parallel: false
})
]
};
}

module.exports = [
...configs,
nodeConfig.config
Expand Down

0 comments on commit f3e185c

Please sign in to comment.