-
-
Notifications
You must be signed in to change notification settings - Fork 17
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
Deleted file does not affect project #84
Comments
Interesting! thank you so much for reproducing with a test. I honestly though we already had this dialed in. I will take a look as soon as I have the time, which unfortunately is on the low end right now. Leo. |
Hey all! I've been taking a look at this and I've found the culprit, still don't know how we are gonna fix it but wanted to provide an update. This is happening since we introduced MSBuild Predictions to determine a project's inputs. It is not an MSBuild.Predictions bug, but it is in how we use it. dotnet-affected/src/DotnetAffected.Core/Prediction/PredictionChangedProjectsProvider.cs Lines 62 to 91 in 2de16bc
You can see here how we use MSBuild.Predictions to determine which files belongs to which project. However, since the file is deleted, it is not predicted as a project input. This wouldn't have been an issue with the old behavior before predictions, where we simply checked if the file path was a subpath of the project path, but references outside of the project's directory were ignored.. Not sure what the fix is yet.. but that is why it is broken. |
Yeah I just took a crack at this too. I guess one option is to walk all the commits here and get a list of all files ever being in that project across the commit range; that should detect files being removed at least. But that might have other bad side effects. |
Hi @tanordheim , deleted files are already being discovered by git diff, however, we fail to map them to a project due to the project not having the deleted file predicted as an input. I think doing the path contains thing may be enough for now, at least as a workaround. |
Yeah, what I meant is if we walk all the commits to detect any files that have been present in the project at any given time we would then find a project that referenced the deleted file in one of the commits before the file was deleted and pick up on the affected project that way. Your way sounds simpler to implement though, maybe its the way to go. I guess that leaves a bug where deleted files in a project that was referenced outside of the project root will not cause the project to be affected. As far as I understand, the reason for using MSBuild Predictions is to cover cases where files are referenced outside the project root. That is still a fairly minor thing I guess, I have no use cases like that personally. |
That is correct yep. I think it is hard to fix it in a performant way. Still need to think about it. v4 will get released today with net8 support and we'll leave this one for a feature release soon. |
Hi, The However, the constructor we need to use to provide the custom file system is currently internal, dotnet/msbuild#9678 (comment) |
I've noticed that if file deletion is the only change,
dotnet-affected
does not include the project in the list of affected.File deletion can break compilation of the project, so it must be returned as affected.
Repro:
I've created a test to show the issue (test fails):
The text was updated successfully, but these errors were encountered: