Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix EPERM errors on Windows when using the --save-bundle and --clean-dir CLI arguments #364

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

aryaemami59
Copy link
Contributor

Overview

When using the --save-bundle and --clean-dir CLI arguments, we can get intermittent EPERM errors on Windows. My assumption is that there is probably some sort of race condition involved. The issue originates from the before function of the '@size-limit/webpack' plugin. I'm not sure if there is potential for more errors, I will try and take a closer look later but for now, adding the maxRetries option to the fs.rm and fs.rmdir functions seems to resolve this issue.

This PR:

  • Adds the maxRetries option to fs.rm and fs.rmdir functions to mitigate EPERM errors on Windows when using the --save-bundle and --clean-dir CLI arguments.

@ai
Copy link
Owner

ai commented May 26, 2024

I'm really afraid to solve issues by trying multiple times. It could make even worse.

Also releasing new versions is hard. I prefer to wait for proper solution.

@aryaemami59
Copy link
Contributor Author

@ai This is definitely a big part of the solution. I just tried it, I used to get the EPERM error every other run, Now I ran the command size-limit --save-bundle build --clean-dir about 40 times, did not get a single error. No need to release a new version just for this, but it would be great if it was eventually included at somepoint.

@ai
Copy link
Owner

ai commented May 26, 2024

I’m afraid that we are hiding some dangerous error, which could lead to something bad (instead of looking for it and fixing it).

If you want a quick solution, maybe try to add setTimeout before removing the folder (but you need to find that exact rm() call has issue).

@aryaemami59
Copy link
Contributor Author

@ai I did a bunch of console.trace calls inside try-catch blocks to get to the issue, and I can confidently say this is the exact location where the problem occurs. If you take that one line and replace it with await fs.rm(config.saveBundle, { force: true, maxRetries: 3, recursive: true }) the issue will go away for good.

@ai
Copy link
Owner

ai commented May 26, 2024

Maybe this core runs in the same time?

let modifyConfig = check.modifyWebpackConfig
check.modifyWebpackConfig = function modifyWebpackConfig(webpackConfig) {
addStatoscope(config, check, webpackConfig)
if (modifyConfig) {
return modifyConfig(webpackConfig) || webpackConfig
}
return webpackConfig
}

Try to replace before in webpack-why to step1 or something.

@aryaemami59
Copy link
Contributor Author

aryaemami59 commented May 26, 2024

@ai Interesting... Let me look into it and see. I'm only using @size-limit/webpack, not using @size-limit/webpack-why, does webpack-why still run?

@aryaemami59
Copy link
Contributor Author

I tried a bunch of things, nothing else seems to fix it but this, though I'm open to suggestions :)

@ai
Copy link
Owner

ai commented Jun 6, 2024

Very likely that it is not a Size Limit issue, but Linux one.

Linux has option to set maximum open files limit. Sometimes this limit is too small.

@ai
Copy link
Owner

ai commented Jun 6, 2024

Try to find a way to increase the limit and increase it. There is an option, I am just on the way and can't give exact line.

@aryaemami59
Copy link
Contributor Author

Not sure I understand, the issue I'm experiencing is happening on Windows, not Linux. And as far as there being a limit on how many files can be opened at the same time, wouldn't it be easier to figure out a way to workaround/fix it from within the library than fiddle with the internal settings of the OS?

@ai
Copy link
Owner

ai commented Jun 6, 2024

  1. Very likely that you are using Linux emulation on Windows because I saw that exact error in Docker
  2. It is webpack who opens so much files (and very likely it does it to improve performance). You need to ask webpack team (try to look in their GitHub).

@aryaemami59 aryaemami59 force-pushed the fix-windows-EPERM-error branch from fa5ba94 to 6a6d526 Compare October 2, 2024 08:05
@aryaemami59 aryaemami59 force-pushed the fix-windows-EPERM-error branch 2 times, most recently from dccf975 to 7653bc8 Compare October 26, 2024 22:35
@aryaemami59 aryaemami59 force-pushed the fix-windows-EPERM-error branch from 7653bc8 to 1cf74ef Compare November 12, 2024 14:20
- When using the `--save-bundle` and `--clean-dir` CLI arguments, we can get intermittent `EPERM` errors on Windows. Passing in the `maxRetries` option to `fs.rm` and `fs.rmdir` functions seems to resolve this issue.
@aryaemami59 aryaemami59 force-pushed the fix-windows-EPERM-error branch from 1cf74ef to 5acb798 Compare January 8, 2025 11:49
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants