-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
An error dialog pops up when creating the .Net Core project with the latest .NET SDK 6.0 #17515
Comments
I couldn't figure out the best area label to add to this issue. If you have write-permissions please help me learn by adding exactly one area label. |
+1 nothing works after I upgrade |
@Zheng-Li01 What version of Visual Studio is this happening with? |
I get it in 16.10.0 Preview 2.1 |
Can you try setting (You don't want to leave this permanently on, as it will disable any workloads, which in .NET 6 will include ios, android, and Blazor AOT support.) |
@dotnet/templating-engine-maintainers @wli3 @marcpopMSFT This looks like it may be a separate issue from what #17536 is trying to fix. It looks like maybe the workload template resolver hasn't been updated to handle the manifest schema change. What's the process for updating that? Is it supposed to happen with normal .NET SDK insertions or what? |
@phenning Where is logic for VS sync with optional workload templates, sounds like it needs updating? |
Specifically, I think that the template engine needs to use a version of the workload manifest reader with this change: #17329 |
If this requires a VS change to function, what does that mean for using nightly builds? |
I think it may mean you need to create projects from the command line. You could also delete or rename the SDK manifests folder: |
So nobody can update the sdk? Can we turn off the workload thing by default until there's a version of vs that works ? |
This is different from the workload resolvers where there was a flag to turn it on or off. It's in the template engine, and I don't think there's a way to turn it off. It ships in VS, so even if we wanted to turn it off we'd have to put the change in 16.10, so I think what we need to do is just fix the template engine in 16.10. We could remove the workload manifests from the SDK, but that would break a bunch of ios, android, and Blazor AoT scenarios. |
We need to remove it until there's something public and workable. I don't think it's reasonable to break like that without an ETA for when it gets resolved. Of course we have these cut over points where VS needs to be updated but this is a hard break... |
@davidfowl this shouldn't require a template engine change unless there is something broken with the API surface. SDK needs to insert a new manifest reader. We just call the API. |
FYI, the only thing we call on the locator are the following two methods:
|
Although I don't understand why the error happens so late, this error should happen when we go to display the available templates, not when we try to create one. We don't even call into the resolver at creation, and the version of template engine itself that is shipped with Visual Studio doesn't know anything about the optional workloads (it is the 3.x version of TE). We just have the layer in WebTools that grabs the template paths from the template locator and installs them into the template engine VS hive. |
OK, I see why this only seems to be happening on Create, - it actually is also happening on the enumeration of the templates as well, except NPD is handling the exception being thrown by the locator so that there isn't a problem with the template list. This is resulting in a fallback to the pre 16.9 behavior where we just see the vstemplate versions of the .net core templates - notice the (.NET Core) in the template name in the screenshot. Then when you try to create, we try to refresh the templates (since we failed earlier) and this time the exception is not caught by NPD. Separate from a fix in the TemplateLocator, I think I (VS) needs to harden the where we call into the template locator in visual studio, catching any exceptions and logging them to the activity log. By doing this, at least we'd still have the core non-optional templates available and we'd only see the templates from the optional workload not be shown. |
OK, it turns out that the change in #17329 isn't in VS 16.10 yet, but it will be there before the GA release. Until 16.10 GA, here are the workarounds you can use:
|
Still broken in latest nightly
Don't think VS 16.10 is a solution if installing the sdk breaks previous VS before even asking what version of .NET to use (e.g. this isn't trying to create a .NET6.0 app) |
Since this the only reasonable workaround, remember to undo this when you install a new version (if you did a rename), or the new installer won't remove it during the previous version uninstall. |
16.10 preview 4 will include the fix for this and the SDK will not load into 16.9 as we've updated the minimum required version for .NET 6 with preview 4 and newer. |
More info:
Version info:
NET SDK 6.0.100-preview.5.21257.10-win-x64.
Repro Steps:
Actual Results:
data:image/s3,"s3://crabby-images/4ed06/4ed0694dd5aa02407761b0d716371ca34f46e05e" alt="image"
An error dialog pops up.
Expected Results:
Creating the .Net Core project with the latest .Net 6.0 successfully.
The text was updated successfully, but these errors were encountered: