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

If a non-persistent launch profile is the last debug profile used, it will visually be selected on reopening the solution but that will be a lie:) #9536

Open
mitchcapper opened this issue Sep 22, 2024 · 2 comments
Labels
Feature-Debugging Launching an application via F5, setting debug properties and launch profiles. Triage-Investigate Reviewed and investigation needed by dev team
Milestone

Comments

@mitchcapper
Copy link

Visual Studio Version

Microsoft Visual Studio Enterprise 2022 (64-bit) - Preview
Version 17.12.0 Preview 2.0

but this has happened for quite some time, I only now had a chance to track down why my launches were often broken when opening a project. I would say probably over a year, my guess is likely since IPersistOption came into existance.

Summary

This bug sadly took me far too long to track down due to the somewhat nasty way it presents.

If you are using a non-persistent profile and visual studio csproj.user file has that profiles name as the ActiveDebugProfile, visual studio will automatically set that to the active profile whenever it is created (ie even if way delayed after load, or in reaction to a button push from the user).

The problem is, it doesn't. It shows it as the active in the drop down menu, you can go to properties see it there as well, but its not active. Instead whatever the profile active before it, is still the active profile. The only way to make it the active profile is to switch off it and switch back onto it.

I have attached a small VS extension that reproduces this effect. After the extension is installed load any multi-launch style project. You will see "VirutalGenProfile" in the possible launch profiles after the solution has fully loaded. Go ahead and launch it, the executable launched will be launched with the command line args -our -random -args. Note this profile is set to not persist.

Now close visual studio out (sorry didn't properly seem to hook the project load), this will save "VirutalGenProfile" as the default profile. Reopen the vs again, after it loads and VirutalGenProfile is created it will automatically be set active. Start debugging and you will notice the command line args will not be the above.

There is a fix, by manually calling SetActiveProfile to ourselves it truly changes to us and is fixed. Granted we would need to detect if we are automatically switched to or not , which I guess would likely just involve reading the ActiveDebugProfile from the user vs config (as calling ActiveProfile will return the actual active profile not our virtual one).

You can do some other testing with the extension, setting FORCE_ACTIVE_PROFILE_WHEN_CREATING to true will set us as active and fixes it.

WAIT_TIME_BEFORE_PROFILE_CREATE to say 10 seconds will cause the profile to not be created for 10 seconds after load. This is to emulate say the profile being created in reaction to a user hitting a button without me actually adding a button. You will see even with the delay the profile still gets set to active if it is set as ActiveDebugProfile on the csproj.user file (although not work of course).

You can manually edit the csproj.user file to have any other name for the ActiveDebugProfile and it will also fix it, as it will not due its auto-switch.

Sample extension: VSNotPersistProfileBugExtension.zip

@mitchcapper
Copy link
Author

While not the same issue this seems to be another example of the toolbar showing a launch profile that is not the actually selected launch profile:
#2967

Given launchSettingsProvider.ActiveProfile represents the true launch profile it would seem finding a way to grab the toolbar combobox value and comparing it would be an easy way to figure out is if it invalid.

@drewnoakes drewnoakes added Feature-Debugging Launching an application via F5, setting debug properties and launch profiles. Triage-Investigate Reviewed and investigation needed by dev team labels Oct 10, 2024
@drewnoakes drewnoakes added this to the Backlog milestone Oct 10, 2024
@mitchcapper
Copy link
Author

I am not sure if anything changed but that solution didn't work completely in all situations. I think the better option is:
await launchSettingsProvider.SetActiveProfileAsync(launchSettingsProvider.ActiveProfile?.Name);
in theory that would have no effect but it fixes this bug. That caveat is an unfortunate situation:

  • If virtual profiles are used
  • If the virtual profile was the active profile last time the solution was opened
  • If the virtual profile is not available on solution load

The active profile is force changed off of the virtual profile when the above code is run. Note the current behavior without the fix is the virtual profile will show as the active one in the drop down but not be active. Still fixing the bug would be best as then a user can have a virtual profile used as the last active profile and have it automatically set back to the active profile when it is re-added.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Feature-Debugging Launching an application via F5, setting debug properties and launch profiles. Triage-Investigate Reviewed and investigation needed by dev team
Projects
None yet
Development

No branches or pull requests

2 participants