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

[Bug Bash] There will be a duplicated package source when modifying the name of source “Microsoft Visual Studio Offline Packages” #13057

Open
v-luzh opened this issue Nov 30, 2023 · 6 comments
Assignees
Labels
Area:Settings NuGet.Config and related issues Category:Quality Week Issues that should be considered for quality week Found:ManualTests Functionality:VSOptions Priority:1 High priority issues that must be resolved in the current sprint. Product:VS.Client RegressionFromPreviousRTM A regression from the last RTM. Example: worked in 6.2, doesn't work in 6.3 Type:Bug

Comments

@v-luzh
Copy link

v-luzh commented Nov 30, 2023

NuGet Product Used

Visual Studio Package Management UI

Product Version

Dev\6.9.0.45

Worked before?

It doesn’t repro on 17.6 (D17.6\34302.98) and 16.11 (D16.11\34301.259).

Impact

None

Repro Steps & Context

Repro Steps:

1.Create a C# Console App (.NET Core 8.0) project in VS and open the PM UI or PMC window.
2.Click the settings button (gear button) on PM UI or PMC window.
3.Click the NuGet Package Manager->Package Sources in the opened “Options” window.
4.Select the source “Microsoft Visual Studio Offline Packages” in the "Package sources" list -- not the one in "Machine-wide package sources:" section, modify the name in the “Name” textbox and click the OK button.
5.Click the settings button (gear button) on PM UI or PMC window and click the “Package Sources” node again.

Expected Results:

There should not be a duplicated package source in step5. Or the source “Microsoft Visual Studio Offline Packages” should not be modified in step4. The same source cannot be modified (as below screenshot) in the auto-created offline package source after deleting the default “nuget.config” file.
image

Actual Results:

There will be a duplicated package source as below screenshot.
image

Notes:

Repro rate: 100%.

Verbose Logs

No response

@jgonz120 jgonz120 added Area:HttpCaching http caching by all tools Product:VS.Client and removed Area:HttpCaching http caching by all tools labels Dec 2, 2023
@zivkan zivkan added Area:Settings NuGet.Config and related issues and removed Triage:Untriaged labels Dec 4, 2023
@zivkan
Copy link
Member

zivkan commented Dec 4, 2023

I'd also like to point out that the source "moved" from a "machine wide" package source, into the user's own nuget.config, which is not desirable. It might not have the same root cause as the duplicate issue, but if possible it would be nice to avoid if not too much extra work.

@nkolev92 nkolev92 added Priority:1 High priority issues that must be resolved in the current sprint. RegressionFromPreviousRTM A regression from the last RTM. Example: worked in 6.2, doesn't work in 6.3 Category:Quality Week Issues that should be considered for quality week labels Dec 11, 2023
@donnie-msft donnie-msft removed the Category:Quality Week Issues that should be considered for quality week label Jan 3, 2024
@donnie-msft
Copy link
Contributor

I am not able to edit the Name since the textbox field is correctly marked as readonly.
I thought last week I was able to do this. Can someone help identify how to get into this situation? Perhaps there was a VS or a .NET Framework bug or something?
image

@v-luzh
Copy link
Author

v-luzh commented Jan 10, 2024

Hi @donnie-msft, the offline package source is read-only if it locates in "Machine-wide package sources:" section as your screenshot above [it seems a by-design scenario].

You can close VS, reopen the project again and reopen the "Options->NuGet Package Manager->Package Sources", and then you will find it go upstairs (in the "Package sources:" section as below). And you can modify the name now.
image

@donnie-msft
Copy link
Contributor

donnie-msft commented Jan 10, 2024

I think I understand the problem now, but let me know if anything below is inaccurate based on what you're seeing.
I'm not blocked, but just wanted to point out some subtle clarifications and make sure you agree....

Readonly is working properly

✅ Ok, I understand you better, now. I misunderstood the original screenshot with the cursor inside the readonly Name field, here:
image

Recapping your repro steps

So, I believe these are the key parts of your repro steps:

  1. First, you cause the "Microsoft Visual Studio Offline Packages" to become marked as a regular (not machine-wide) package source.
  2. Next, you edit the feed's name and are seeing it create duplicate entries.

You can close VS, reopen the project again and reopen the "Options->NuGet Package Manager->Package Sources", and then you will find it go upstairs (in the "Package sources:" section as below).

I'm not seeing this happen when I follow your steps.
I wonder if when you are selecting the machine-wide feed, are you actually unchecking the checkbox as well?
Apparently, simply clicking the feed in the list by default unchecks the checkbox. This disables the package source.

Question: is your repro disabling the machine-wide package source?

You can check by looking at your applicable nuget.config for a disabledPackageSources node containing "Microsoft Visual Studio Offline Packages".

Only when I disable the "Microsoft Visual Studio Offline Packages", by clicking on the machine-wide source list item (which unchecks the checkbox), does it seem to move up to become a regular package source.
image

Therefore, this bug appears to be with how VS Options is working with <disabledPackageSources> in the nuget.config.

I'll see if I can find the bug. That's likely not a recent regression, but I'll update the thread once I know more.
From my %appdata%\NuGet\NuGet.Config
image

@v-luzh
Copy link
Author

v-luzh commented Jan 27, 2024

Hi @donnie-msft, thanks for your detailed verification. No, I didn't disable the machine-wide package source intentionally.

I think it is not related to the enabling/disabling this checkbox before modifying the Name in step4. I have verified these two scenarios, they both repro.

@donnie-msft donnie-msft added the Category:Quality Week Issues that should be considered for quality week label Mar 4, 2024
@SueSu01
Copy link

SueSu01 commented Aug 23, 2024

It still reproes on VS Main\35222.175 + NuGet Client Dev\6.12.0.82.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area:Settings NuGet.Config and related issues Category:Quality Week Issues that should be considered for quality week Found:ManualTests Functionality:VSOptions Priority:1 High priority issues that must be resolved in the current sprint. Product:VS.Client RegressionFromPreviousRTM A regression from the last RTM. Example: worked in 6.2, doesn't work in 6.3 Type:Bug
Projects
None yet
Development

No branches or pull requests

6 participants