-
-
Notifications
You must be signed in to change notification settings - Fork 607
Description
Bug report
After some investigation I suspect that part of this is an issue in Webpack's naming of assets. A change in css-loader 6 seems to mean that inline data url images are exported as assets by webpack, but a big data url image is a really long file name; sometimes too long. I think the issue is that inline data url images shouldn't be exported as external assets, and I think that is a change in css-loader, so I have created the issue in this project.
Actual Behavior
Using css-loader version 6.2.0 webpack fails with an ENAMETOOLONG error when compiling the following css:
body {
background-image: url('');
}This is the error:
webpack-cli] [Error: ENAMETOOLONG: name too long, open '/Users/karlvr/target/frontend/.ec063434'] {
errno: -63,
code: 'ENAMETOOLONG',
syscall: 'open',
path: '/Users/karlvr/target/frontend/.ec063434'
}
ERROR Command failed with exit code 2.
Expected Behavior
With css-loader version 5.2.7 there is no error and the CSS is output with the url(data:image/svg...) intact.
How Do We Reproduce?
Here is the gist of it https://gist.github.com/karlvr/90759ad647661e9bbd3d58f7998eb14b
The key is the assetModuleFilename and css-loader 6.2.0. If you truncate the base64 image data you will get a file output with that base64 image data as its name, and the decoded images data as its body.
Please paste the results of npx webpack-cli info here, and mention other relevant information
System:
OS: macOS 11.5.2
CPU: (16) x64 Intel(R) Core(TM) i9-9900K CPU @ 3.60GHz
Memory: 17.13 MB / 64.00 GB
Binaries:
Node: 14.17.5 - ~/.nvm/versions/node/v14.17.5/bin/node
Yarn: 1.13.0 - /usr/local/bin/yarn
npm: 6.14.14 - ~/.nvm/versions/node/v14.17.5/bin/npm
Browsers:
Chrome: 92.0.4515.159
Firefox: 91.0.2
Safari: 14.1.2
Packages:
webpack: ^5.51.1 => 5.51.1
webpack-cli: ^4.8.0 => 4.8.0