Skip to content

Commit

Permalink
[code-infra] Build size snapshots from installed packages (mui#43452)
Browse files Browse the repository at this point in the history
  • Loading branch information
Janpot authored and Michael-Hutchinson committed Sep 7, 2024
1 parent 5fce989 commit 9eafc1f
Show file tree
Hide file tree
Showing 4 changed files with 81 additions and 23 deletions.
27 changes: 27 additions & 0 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions pnpm-workspace.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,4 @@ packages:
- 'docs'
- 'test'
- 'apps/*'
- 'scripts/sizeSnapshot'
15 changes: 15 additions & 0 deletions scripts/sizeSnapshot/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
{
"name": "size-snapshot",
"version": "1.0.0",
"description": "Size snapshot of MUI packages",
"dependencies": {
"@mui/lab": "workspace:^",
"@mui/base": "workspace:^",
"@mui/joy": "workspace:^",
"@mui/material": "workspace:^",
"@mui/styles": "workspace:^",
"@mui/private-theming": "workspace:^",
"@mui/utils": "workspace:^",
"@mui/system": "workspace:^"
}
}
61 changes: 38 additions & 23 deletions scripts/sizeSnapshot/webpack.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,13 +21,13 @@ async function getWebpackEntries() {

return {
id: entryName,
path: path.relative(workspaceRoot, path.dirname(componentPath)),
import: `@mui/material/${componentName}`,
};
},
);

const corePackagePath = path.join(workspaceRoot, 'packages/mui-base/build');
const coreComponents = (await glob(path.join(corePackagePath, '([A-Z])*/index.js'))).map(
const baseComponents = (await glob(path.join(corePackagePath, '([A-Z])*/index.js'))).map(
(componentPath) => {
const componentName = path.basename(path.dirname(componentPath));
let entryName = componentName;
Expand All @@ -38,7 +38,7 @@ async function getWebpackEntries() {

return {
id: entryName,
path: path.relative(workspaceRoot, path.dirname(componentPath)),
import: `@mui/base/${componentName}`,
};
},
);
Expand All @@ -50,7 +50,7 @@ async function getWebpackEntries() {

return {
id: componentName,
path: path.relative(workspaceRoot, path.dirname(componentPath)),
import: `@mui/lab/${componentName}`,
};
},
);
Expand All @@ -62,7 +62,7 @@ async function getWebpackEntries() {

return {
id: `@mui/joy/${componentName}`,
path: path.relative(workspaceRoot, path.dirname(componentPath)),
import: `@mui/joy/${componentName}`,
};
},
);
Expand All @@ -72,62 +72,63 @@ async function getWebpackEntries() {
// WARNING: Changing the name will break tracking of bundle size over time
// If the name of the package changes, rename its display name in https://github.com/eps1lon/mui-contributor-dashboard/blob/main/src/pages/SizeComparison.tsx
id: '@material-ui/core',
path: path.join(path.relative(workspaceRoot, materialPackagePath), 'index.js'),
import: '@mui/material',
},
...materialComponents,
{
id: '@material-ui/lab',
path: path.join(path.relative(workspaceRoot, labPackagePath), 'index.js'),
import: '@mui/lab',
},
...labComponents,
{
id: '@material-ui/styles',
path: 'packages/mui-styles/build/index.js',
import: '@mui/styles',
},
{
id: '@material-ui/private-theming',
path: 'packages/mui-private-theming/build/index.js',
import: '@mui/private-theming',
},
{
id: '@material-ui/system',
path: 'packages/mui-system/build/index.js',
import: '@mui/system',
},
{
id: 'createBox',
path: 'packages/mui-system/build/createBox/index.js',
import: '@mui/system/createBox',
},
{
id: 'createStyled',
path: 'packages/mui-system/build/createStyled/index.js',
import: '@mui/system/createStyled',
},
{
id: '@material-ui/core/styles/createTheme',
path: 'packages/mui-material/build/styles/createTheme.js',
importName: 'createTheme',
import: '@mui/material/styles',
},
{
id: 'colorManipulator',
path: 'packages/mui-system/build/colorManipulator/index.js',
import: '@mui/system/colorManipulator',
},
{
id: 'useAutocomplete',
path: 'packages/mui-lab/build/useAutocomplete/index.js',
import: '@mui/lab/useAutocomplete',
},
{
id: '@material-ui/core/useMediaQuery',
path: 'packages/mui-material/build/useMediaQuery/index.js',
import: '@mui/material/useMediaQuery',
},
{
id: '@material-ui/core/useScrollTrigger',
path: 'packages/mui-material/build/useScrollTrigger/index.js',
import: '@mui/material/useScrollTrigger',
},
{
id: '@material-ui/unstyled',
path: path.join(path.relative(workspaceRoot, corePackagePath), 'index.js'),
import: '@mui/base',
},
...coreComponents,
...baseComponents,
{
id: '@material-ui/utils',
path: 'packages/mui-utils/build/esm/index.js',
import: '@mui/utils',
},
// TODO: Requires webpack v5
// Resolution of webpack/acorn to 7.x is blocked by nextjs (https://github.com/vercel/next.js/issues/11947)
Expand All @@ -138,7 +139,7 @@ async function getWebpackEntries() {
// },
{
id: '@mui/joy',
path: path.join(path.relative(workspaceRoot, joyPackagePath), 'index.js'),
import: '@mui/joy',
},
...joyComponents,
];
Expand All @@ -148,6 +149,8 @@ function createWebpackConfig(entry, environment) {
const analyzerMode = environment.analyze ? 'static' : 'disabled';
const concatenateModules = !environment.accurateBundles;

const importNames = entry.importName ? `{ ${entry.importName} as foo }` : '* as foo';

/**
* @type {import('webpack').Configuration}
*/
Expand All @@ -160,7 +163,7 @@ function createWebpackConfig(entry, environment) {
concatenateModules,
minimizer: [
new TerserPlugin({
test: /\.js(\?.*)?$/i,
test: /\.m?js(\?.*)?$/i,
}),
],
},
Expand All @@ -174,6 +177,11 @@ function createWebpackConfig(entry, environment) {
},
path: path.join(__dirname, 'build'),
},
resolve: {
alias: {
'@mui/utils': '@mui/utils/esm',
},
},
plugins: [
new CompressionPlugin(),
new BundleAnalyzerPlugin({
Expand All @@ -186,7 +194,14 @@ function createWebpackConfig(entry, environment) {
reportFilename: `${entry.id}.html`,
}),
],
entry: { [entry.id]: path.join(workspaceRoot, entry.path) },
// A context to the current dir, which has a node_modules folder with workspace dependencies
context: __dirname,
entry: {
// This format is a data: url combined with inline matchResource to obtain a virtual entry.
// See https://github.com/webpack/webpack/issues/6437#issuecomment-874466638
// See https://webpack.js.org/api/loaders/#inline-matchresource
[entry.id]: `./index.js!=!data:text/javascript,import ${importNames} from '${entry.import}';console.log(foo);`,
},
// TODO: 'browserslist:modern'
// See https://github.com/webpack/webpack/issues/14203
target: 'web',
Expand Down

0 comments on commit 9eafc1f

Please sign in to comment.