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

Investigate if uninstall have more than 1 restore problem for reference type projects. #9932

Closed
erdembayar opened this issue Aug 24, 2020 · 6 comments
Assignees
Labels
Functionality:Restore Functionality:VisualStudioUI Package Manager UI et al Priority:2 Issues for the current backlog. Product:VS.Client Tenet:Performance Performance issues

Comments

@erdembayar
Copy link
Contributor

Details about Problem

It's follow up for Nuget Solution Package manager UI is slow because restore is run for every project instead of after all projects are updated #6010 task. I solved install/upgrade/downgrade cases, but my changes doesn't cover uninstall case. For 2-3 sample solutions I tried doesn't have multi restore problem, but just in case need to check all code path to make sure.

@nkolev92
Copy link
Member

I think a good test case for this is;

Project 1 -> Project 2 -> Project 3, where 2 & 3, have Package A.
Uninstall Package A and see how many restores happen.

Quick test on my end, uninstall does have a problem.

Restoring packages for C:\Users\Roki2\Documents\Code\test\uninstall\P3\P3.csproj...
Restoring packages for C:\Users\Roki2\Documents\Code\test\uninstall\P2\P2.csproj...
Committing restore...
Writing assets file to disk. Path: C:\Users\Roki2\Documents\Code\test\uninstall\P3\obj\project.assets.json
Successfully uninstalled 'Newtonsoft.Json 12.0.3' from P3
Committing restore...
Assets file has not changed. Skipping assets file writing. Path: C:\Users\Roki2\Documents\Code\test\uninstall\P1\obj\project.assets.json
Restored C:\Users\Roki2\Documents\Code\test\uninstall\P1\P1.csproj (in 0.7 ms).

NuGet Config files used:
    C:\Users\Roki2\Documents\Code\NuGet.Config
    C:\Users\Roki2\AppData\Roaming\NuGet\NuGet.Config
    C:\Program Files (x86)\NuGet\Config\Microsoft.VisualStudio.Offline.config

Feeds used:
    https://api.nuget.org/v3/index.json
Executing nuget actions took 143 ms
Restoring packages for C:\Users\Roki2\Documents\Code\test\uninstall\P2\P2.csproj...
Committing restore...
Writing assets file to disk. Path: C:\Users\Roki2\Documents\Code\test\uninstall\P2\obj\project.assets.json

NuGet Config files used:
    C:\Users\Roki2\Documents\Code\NuGet.Config
    C:\Users\Roki2\AppData\Roaming\NuGet\NuGet.Config
    C:\Program Files (x86)\NuGet\Config\Microsoft.VisualStudio.Offline.config

Feeds used:
    https://api.nuget.org/v3/index.json
Restoring packages for C:\Users\Roki2\Documents\Code\test\uninstall\P1\P1.csproj...
Committing restore...
Writing assets file to disk. Path: C:\Users\Roki2\Documents\Code\test\uninstall\P1\obj\project.assets.json

NuGet Config files used:
    C:\Users\Roki2\Documents\Code\NuGet.Config
    C:\Users\Roki2\AppData\Roaming\NuGet\NuGet.Config
    C:\Program Files (x86)\NuGet\Config\Microsoft.VisualStudio.Offline.config

Feeds used:
    https://api.nuget.org/v3/index.json
Executing nuget actions took 187 ms
Time Elapsed: 00:00:00.3942751

See how P2 is restored twice!

@zkat zkat added the Priority:2 Issues for the current backlog. label Aug 27, 2020
@erdembayar
Copy link
Contributor Author

erdembayar commented Aug 27, 2020

It looks you got this log from public VS2019. I got similar duplicate restore on my TestRepo:
https://gist.github.com/erdembayar/d96a2f5cb45b92bec8e598f45484194b
ConsoleApp2.csproj was restored 2 times.

I didn't really target uninstall scenarios but it looks already solved.
Below is log from experimental instance with my changes:
https://gist.github.com/erdembayar/772db3f51d191b9068f691671abbe293
Both ConsoleApp1.csproj and ConsoleApp2.csproj was restored only once.

https://gist.github.com/erdembayar/1a97b3d2853c5af432e0117392a01303
All projects was restored only once.

@erdembayar
Copy link
Contributor Author

It looks both install and uninstall actions share same code path NugetPackageManager#Line2601 where code optimization change was made. So now uninstall scenario also benefit from my change too.

@nkolev92
Copy link
Member

t looks both install and uninstall actions share same code path NugetPackageManager

Can you please add tests for it then?

A scenario like the one I called out in #9932 (comment), would be great!

Assigning to you given that your change is already addressing it.

@nkolev92 nkolev92 added this to the Sprint 175 - 2020.08.17 milestone Aug 27, 2020
erdembayar added a commit to NuGet/NuGet.Client that referenced this issue Aug 28, 2020
@erdembayar
Copy link
Contributor Author

erdembayar commented Aug 28, 2020

I added 2 unit tests for this uninstall case:
NetCorePackageReferenceProjectTests#L2156
NetCorePackageReferenceProjectTests#L2325

erdembayar added a commit to NuGet/NuGet.Client that referenced this issue Sep 3, 2020
…for every project instead of after all projects are updated (#3559)

* Added relationship table to hold ancesstors and descendents relationship for target projects.

* Now 1065 is solved because we pass correct update PackageSpec of child before parent restores.

* Remove RelationshipTree for now.

* Add unshipped public api.

* Remove unused item and add initial value to dictionary to prevent from null exception.

* More streamline package reference type code restore.

* Revert "More streamline package reference type code restore."

This reverts commit 875968b.

* Restore NugetBuiltIntegrated restore works only in 1 pass.

* Minor refactoring for naming.

* Explicit clearing of cache.

* Initial refactoring of moving caching of updated PackageSpec near to usage, make it run parellel not finished yet.

* Made BuiltIntegratedProject project upgrade/downgrade parallel run for faster run.

* Fix minor typos.

* Remove unused methods and variables.

* Remove more unused item.

* Revert "Remove more unused item."

This reverts commit efa1782.

* Patching in memory works.

* Cleanup

* Minor text change

* More code cleanup.

* Rename PreviewBuildIntegratedProjectActionsParallelAsync method to PreviewBuildIntegratedProjectsActionsAsync

* Add unit tests for covering PreviewBuildIntegratedProjectsActionsAsync method in NuGetPackageManager.

* Add more unit tests for BuildIntegratedTests

* Address Andy's code review comment.

* Add unit test for DependencyGraphSpec>>WithReplacedPackageSpecs new method I created.

* Get Andy's advise for reduce runtime time complexity.

* Change package versions because it's failing on .NetCore unit tests.

* Check if Newtonsoft version matches.

* Try different pacakge for unit test.

* Test

* Address comment about foreach loop variable name.

* Remove 'parallel' word from comment. Because actual parallel code is called thown the line different method.

* PackageReference/SDK style unit tests start working.

* Making source works for unit tests.

* Fixed problem of Unit test project not picking up my custom PackageSource.

* Revert LegacyPackageReferenceProject related changes, maybe I don't need it for now.

* Git clean up and fix added unit tests with new PackSource logic.

* Fix typo.

* Add NU1065 and new PackageSource handling to some unit test I forgot to add.

* Fix formatting recommendation in code review.

* Remove parallel wording from method comment, because actual parallelization happend down the line another called method here.

* Fix typo.

* Refactor code after Andy's code review.
thinking about API design:

	Why does this method only accept BuildIntegratedNuGetProject?
	Why can't this method be made internal, and the existing public API PreviewInstallPackageAsync calls it for compatible project types?

* Fix small typo.

* After refactoring code PreviewBuildIntegratedProjectActionsAsync and PreviewBuildIntegratedProjectActionsAsync share same logic via PreviewBuildIntegratedProjectsActionsAsync
method.

* All PreviewProjectsInstallPackageAsync related unit test for NugetPackageManager are ported to NetCorePackageReferenceProject(reference) type unit test from project json type unit tests.

* Remove the spaces and correct comments.

* Revert changes to BuildIntegratedTests.cs since we already ported all new unit tests to NetCorePackageReferenceProjectTests.cs

* Fix typo.

* Revert changes to LegacyPackageReferenceProjectTests.cs

* Revert back unneeded changes to NuGetPackageManagerTests.cs

* Remove unneeded change.

* Add missing copy right notice for new file GetPackageReferenceUtility.cs

* Add missing copyright notice for ProjectInstalledPackages.cs

* Remove wrong file.

* Revert unneeded changes.

* Fix typos.

* Address code review comments and clean up.

* Now also remembers we evaluated the parents too.

* Rename method name after nkolve92 code review.

* Address Nikolche code review comment about parent projects.

* Remove method PreviewResolveActionsForBuildIntegratedProjectsAsync method since it's so simple.

* Make sure restore happens only once during uninstall process for chain referenced projects.  Address: NuGet/Home#9932 (comment)

* Changed install package to all projects that it check for restore only happens once per project.

* Clean up unused items.

* Replace StringComparer.OrdinalIgnoreCase with PathUtility.GetStringComparerBasedOnOS() for other OS compatibility.

* Refactor the unit tests after Nikolche's code review.

* Change unit test names.

* Fix formatting.

* Fix with dot net formatting.

* Add comment why we're separating BuildIntegratedNuGetProject vs packages.config projects.

* Address more code review comments by Cristina.

* Address Svet's code review comment.

* Fix formatting.

* Address Andy's latest code review.

* Refactor unit test after Andy's code review.

* Fix unit test after Nikolche review.

* Fix formatting.

Co-authored-by: Erick Yondon <eryondon@microsoft.com>
@nkolev92
Copy link
Member

nkolev92 commented Sep 3, 2020

Closing per NuGet/NuGet.Client@53a7cf2

@nkolev92 nkolev92 closed this as completed Sep 3, 2020
dtivel pushed a commit to NuGet/NuGet.Client that referenced this issue Sep 14, 2020
…for every project instead of after all projects are updated (#3559)

* Added relationship table to hold ancesstors and descendents relationship for target projects.

* Now 1065 is solved because we pass correct update PackageSpec of child before parent restores.

* Remove RelationshipTree for now.

* Add unshipped public api.

* Remove unused item and add initial value to dictionary to prevent from null exception.

* More streamline package reference type code restore.

* Revert "More streamline package reference type code restore."

This reverts commit 875968b.

* Restore NugetBuiltIntegrated restore works only in 1 pass.

* Minor refactoring for naming.

* Explicit clearing of cache.

* Initial refactoring of moving caching of updated PackageSpec near to usage, make it run parellel not finished yet.

* Made BuiltIntegratedProject project upgrade/downgrade parallel run for faster run.

* Fix minor typos.

* Remove unused methods and variables.

* Remove more unused item.

* Revert "Remove more unused item."

This reverts commit efa1782.

* Patching in memory works.

* Cleanup

* Minor text change

* More code cleanup.

* Rename PreviewBuildIntegratedProjectActionsParallelAsync method to PreviewBuildIntegratedProjectsActionsAsync

* Add unit tests for covering PreviewBuildIntegratedProjectsActionsAsync method in NuGetPackageManager.

* Add more unit tests for BuildIntegratedTests

* Address Andy's code review comment.

* Add unit test for DependencyGraphSpec>>WithReplacedPackageSpecs new method I created.

* Get Andy's advise for reduce runtime time complexity.

* Change package versions because it's failing on .NetCore unit tests.

* Check if Newtonsoft version matches.

* Try different pacakge for unit test.

* Test

* Address comment about foreach loop variable name.

* Remove 'parallel' word from comment. Because actual parallel code is called thown the line different method.

* PackageReference/SDK style unit tests start working.

* Making source works for unit tests.

* Fixed problem of Unit test project not picking up my custom PackageSource.

* Revert LegacyPackageReferenceProject related changes, maybe I don't need it for now.

* Git clean up and fix added unit tests with new PackSource logic.

* Fix typo.

* Add NU1065 and new PackageSource handling to some unit test I forgot to add.

* Fix formatting recommendation in code review.

* Remove parallel wording from method comment, because actual parallelization happend down the line another called method here.

* Fix typo.

* Refactor code after Andy's code review.
thinking about API design:

	Why does this method only accept BuildIntegratedNuGetProject?
	Why can't this method be made internal, and the existing public API PreviewInstallPackageAsync calls it for compatible project types?

* Fix small typo.

* After refactoring code PreviewBuildIntegratedProjectActionsAsync and PreviewBuildIntegratedProjectActionsAsync share same logic via PreviewBuildIntegratedProjectsActionsAsync
method.

* All PreviewProjectsInstallPackageAsync related unit test for NugetPackageManager are ported to NetCorePackageReferenceProject(reference) type unit test from project json type unit tests.

* Remove the spaces and correct comments.

* Revert changes to BuildIntegratedTests.cs since we already ported all new unit tests to NetCorePackageReferenceProjectTests.cs

* Fix typo.

* Revert changes to LegacyPackageReferenceProjectTests.cs

* Revert back unneeded changes to NuGetPackageManagerTests.cs

* Remove unneeded change.

* Add missing copy right notice for new file GetPackageReferenceUtility.cs

* Add missing copyright notice for ProjectInstalledPackages.cs

* Remove wrong file.

* Revert unneeded changes.

* Fix typos.

* Address code review comments and clean up.

* Now also remembers we evaluated the parents too.

* Rename method name after nkolve92 code review.

* Address Nikolche code review comment about parent projects.

* Remove method PreviewResolveActionsForBuildIntegratedProjectsAsync method since it's so simple.

* Make sure restore happens only once during uninstall process for chain referenced projects.  Address: NuGet/Home#9932 (comment)

* Changed install package to all projects that it check for restore only happens once per project.

* Clean up unused items.

* Replace StringComparer.OrdinalIgnoreCase with PathUtility.GetStringComparerBasedOnOS() for other OS compatibility.

* Refactor the unit tests after Nikolche's code review.

* Change unit test names.

* Fix formatting.

* Fix with dot net formatting.

* Add comment why we're separating BuildIntegratedNuGetProject vs packages.config projects.

* Address more code review comments by Cristina.

* Address Svet's code review comment.

* Fix formatting.

* Address Andy's latest code review.

* Refactor unit test after Andy's code review.

* Fix unit test after Nikolche review.

* Fix formatting.

Co-authored-by: Erick Yondon <eryondon@microsoft.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Functionality:Restore Functionality:VisualStudioUI Package Manager UI et al Priority:2 Issues for the current backlog. Product:VS.Client Tenet:Performance Performance issues
Projects
None yet
Development

No branches or pull requests

4 participants