migrate-dotnet10-to-dotnet11
.NET 10 → .NET 11 Migration
Migrate a .NET 10 project or solution to .NET 11, systematically resolving all breaking changes. The outcome is a project targeting net11.0 that builds cleanly, passes tests, and accounts for every behavioral, source-incompatible, and binary-incompatible change introduced in .NET 11.
Note: .NET 11 is currently in preview. This skill covers breaking changes documented through Preview 1. It will be updated as additional previews ship.
When to Use
- Upgrading
TargetFrameworkfromnet10.0tonet11.0 - Resolving build errors or new warnings after updating the .NET 11 SDK
- Adapting to behavioral changes in .NET 11 runtime, ASP.NET Core 11, or EF Core 11
- Updating CI/CD pipelines, Dockerfiles, or deployment scripts for .NET 11
- Fixing C# 15 compiler breaking changes after SDK upgrade
When Not to Use
- The project already targets
net11.0and builds cleanly — migration is done - Upgrading from .NET 9 or earlier — address the .NET 9→10 breaking changes first
- Migrating from .NET Framework — that is a separate, larger effort
- Greenfield projects that start on .NET 11 (no migration needed)
Inputs
| Input | Required | Description |
|---|---|---|
| Project or solution path | Yes | The .csproj, .sln, or .slnx entry point to migrate |
| Build command | No | How to build (e.g., dotnet build, a repo build script). Auto-detect if not provided |
| Test command | No | How to run tests (e.g., dotnet test). Auto-detect if not provided |
| Project type hints | No | Whether the project uses ASP.NET Core, EF Core, Cosmos DB, etc. Auto-detect from PackageReferences and SDK attributes if not provided |
Workflow
Answer directly from the loaded reference documents for information about .NET 11 breaking changes. You may inspect the local repository (project/solution files, source code, configuration, build/test scripts) as needed to determine which changes apply. Do not fetch web pages or other external sources for breaking change information — the loaded references are the authoritative source. Focus on identifying which breaking changes apply and providing concrete fixes.
Commit strategy: Commit at each logical boundary — after updating the TFM (Step 2), after resolving build errors (Step 3), after addressing behavioral changes (Step 4), and after updating infrastructure (Step 5). This keeps each commit focused and reviewable.
Step 1: Assess the project
- Identify how the project is built and tested. Look for build scripts,
.sln/.slnxfiles, or individual.csprojfiles. - Run
dotnet --versionto confirm the .NET 11 SDK is installed. If it is not, stop and inform the user. - Determine which technology areas the project uses by examining:
- SDK attribute:
Microsoft.NET.Sdk.Web→ ASP.NET Core;Microsoft.NET.Sdk.WindowsDesktopwith<UseWPF>or<UseWindowsForms>→ WPF/WinForms - PackageReferences:
Microsoft.EntityFrameworkCore.*→ EF Core;Microsoft.EntityFrameworkCore.Cosmos→ Cosmos DB provider - Dockerfile presence → Container changes relevant
- Cryptography API usage → DSA on macOS affected
- Compression API usage → DeflateStream/GZipStream/ZipArchive changes relevant
- TAR API usage → Header checksum validation change relevant
NamedPipeClientStreamusage withSafePipeHandle→ SYSLIB0063 constructor obsoletion relevant
- SDK attribute:
- Record which reference documents are relevant (see the reference loading table in Step 3).
- Do a clean build (
dotnet build --no-incrementalor deletebin/obj) on the currentnet10.0target to establish a clean baseline. Record any pre-existing warnings.
Step 2: Update the Target Framework
-
In each
.csproj(orDirectory.Build.propsif centralized), change:<TargetFramework>net10.0</TargetFramework>to:
<TargetFramework>net11.0</TargetFramework>For multi-targeted projects, add
net11.0to<TargetFrameworks>or replacenet10.0. -
Update all
Microsoft.Extensions.*,Microsoft.AspNetCore.*,Microsoft.EntityFrameworkCore.*, and other Microsoft package references to their 11.0.x versions. If using Central Package Management (Directory.Packages.props), update versions there. -
Run
dotnet restore. Fix any restore errors before continuing. -
Run
dotnet build. Capture all errors and warnings — these will be addressed in Step 3.
Step 3: Fix source-breaking and compilation changes
Load reference documents based on the project's technology areas:
| Reference file | When to load |
|---|---|
references/csharp-compiler-dotnet10to11.md |
Always (C# 15 compiler breaking changes) |
references/core-libraries-dotnet10to11.md |
Always (applies to all .NET 11 projects) |
references/sdk-msbuild-dotnet10to11.md |
Always (SDK and build tooling changes) |
references/efcore-dotnet10to11.md |
Project uses Entity Framework Core (especially Cosmos DB provider) |
references/cryptography-dotnet10to11.md |
Project uses cryptography APIs or targets macOS |
references/runtime-jit-dotnet10to11.md |
Deploying to older hardware or embedded devices |
Work through each build error systematically. Common patterns:
-
C# 15 Span collection expression safe-context — Collection expressions of
Span<T>/ReadOnlySpan<T>type now havedeclaration-blocksafe-context. Code assigning span collection expressions to variables in outer scopes will error. Use array type or move the expression to the correct scope. -
ref readonlydelegates/local functions needInAttribute— If synthesizing delegates fromref readonly-returning methods or usingref readonlylocal functions, ensureSystem.Runtime.InteropServices.InAttributeis available. -
nameof(this.)in attributes — Removethis.qualifier; usenameof(P)instead ofnameof(this.P). -
with()in collection expressions (C# 15) —with(...)is now treated as constructor arguments, not a method call. Use@with(...)to call a method namedwith. -
Dynamic
&&/||with interface operand — Interface types as left operand of&&/||withdynamicright operand now errors at compile time. Cast to concrete type ordynamic. -
EF Core Cosmos sync I/O removal —
ToList(),SaveChanges(), etc. on Cosmos provider always throw. Convert to async equivalents. -
SYSLIB0063:
NamedPipeClientStreamisConnectedparameter obsoleted — The constructor overload takingbool isConnectedis obsoleted. Remove theisConnectedargument and use the new 3-parameter constructor. Projects withTreatWarningsAsErrorswill fail to build. -
whenswitch-expression-arm parsing —(X.Y) whenis now parsed as a constant pattern with awhenclause instead of a cast expression, which can cause existing code to fail to compile or change meaning. Review switch expressions usingwhenand adjust syntax as needed.
Step 4: Address behavioral changes
These changes compile successfully but alter runtime behavior. Review each one and determine impact:
-
DeflateStream/GZipStream empty payload — Now writes headers and footers even for empty payloads. If your code checks for zero-length output, update the check.
-
MemoryStream maximum capacity — Maximum capacity updated and exception behavior changed. Review code that creates large MemoryStreams or relies on specific exception types.
-
TAR header checksum validation — TAR-reading APIs now verify checksums. Corrupted or hand-crafted TAR files may now fail to read.
-
ZipArchive.CreateAsync eager loading —
ZipArchive.CreateAsynceagerly loads entries. May affect memory usage for large archives. -
Environment.TickCount consistency — Made consistent with Windows timeout behavior. Code relying on specific tick count behavior may need adjustment.
-
DSA removed from macOS — DSA cryptographic operations throw on macOS. Use a different algorithm (RSA, ECDSA).
-
Japanese Calendar minimum date — Minimum supported date corrected. Code using very early Japanese Calendar dates may be affected.
-
Minimum hardware requirements — x86/x64 baseline moved to
x86-64-v2; Windows Arm64 requiresLSE. Verify deployment targets meet requirements. -
Mono launch target for .NET Framework — No longer set automatically. If using Mono for .NET Framework apps on Linux, specify explicitly.
Step 5: Update infrastructure
-
Dockerfiles: Update base images from 10.0 to 11.0:
# Before FROM mcr.microsoft.com/dotnet/sdk:10.0 AS build FROM mcr.microsoft.com/dotnet/aspnet:10.0 # After FROM mcr.microsoft.com/dotnet/sdk:11.0 AS build FROM mcr.microsoft.com/dotnet/aspnet:11.0 -
CI/CD pipelines: Update SDK version references. If using
global.json, update thesdk.versionin your existing file while preserving other keys (such asrollForwardand test configuration):{ "sdk": { - "version": "10.0.100", - "rollForward": "latestFeature" + "version": "11.0.100-preview.1", + "rollForward": "latestFeature" }, "otherSettings": { "...": "..." } } -
Hardware deployment targets: Verify all deployment targets meet the updated minimum hardware requirements (x86-64-v2 for x86/x64, LSE for Windows Arm64).
Step 6: Verify
- Run a full clean build:
dotnet build --no-incremental - Run all tests:
dotnet test - If the application is containerized, build and test the container image
- Smoke-test the application, paying special attention to:
- Compression behavior with empty streams
- TAR file reading
- EF Core Cosmos DB operations (must be async)
- DSA usage on macOS
- Memory-intensive MemoryStream usage
- Span collection expression assignments
- Review the diff and ensure no unintended behavioral changes were introduced
Reference Documents
The references/ folder contains detailed breaking change information organized by technology area. Load only the references relevant to the project being migrated:
| Reference file | When to load |
|---|---|
references/csharp-compiler-dotnet10to11.md |
Always (C# 15 compiler breaking changes) |
references/core-libraries-dotnet10to11.md |
Always (applies to all .NET 11 projects) |
references/sdk-msbuild-dotnet10to11.md |
Always (SDK and build tooling changes) |
references/efcore-dotnet10to11.md |
Project uses Entity Framework Core (especially Cosmos DB provider) |
references/cryptography-dotnet10to11.md |
Project uses cryptography APIs or targets macOS |
references/runtime-jit-dotnet10to11.md |
Deploying to older hardware or embedded devices |
More from dotnet/skills
analyzing-dotnet-performance
>-
470optimizing-ef-core-queries
Optimize Entity Framework Core queries by fixing N+1 problems, choosing correct tracking modes, using compiled queries, and avoiding common performance traps. Use when EF Core queries are slow, generating excessive SQL, or causing high database load.
398csharp-scripts
Run single-file C# programs as scripts (file-based apps) for quick experimentation, prototyping, and concept testing. Use when the user wants to write and execute a small C# program without creating a full project.
394run-tests
>
365msbuild-antipatterns
Catalog of MSBuild anti-patterns with detection rules and fix recipes. Only activate in MSBuild/.NET build context. USE FOR: reviewing, auditing, or cleaning up .csproj, .vbproj, .fsproj, .props, .targets, or .proj files. Each anti-pattern has a symptom, explanation, and concrete BAD→GOOD transformation. Covers Exec-instead-of-built-in-task, unquoted conditions, hardcoded paths, restating SDK defaults, scattered package versions, and more. DO NOT USE FOR: non-MSBuild build systems (npm, Maven, CMake, etc.), project migration to SDK-style (use msbuild-modernization).
325msbuild-modernization
Guide for modernizing and migrating MSBuild project files to SDK-style format. Only activate in MSBuild/.NET build context. USE FOR: converting legacy .csproj/.vbproj with verbose XML to SDK-style, migrating packages.config to PackageReference, removing Properties/AssemblyInfo.cs in favor of auto-generation, eliminating explicit <Compile Include> lists via implicit globbing, consolidating shared settings into Directory.Build.props. Indicators of legacy projects: ToolsVersion attribute, <Import Project=\"$(MSBuildToolsPath)\">, .csproj files > 50 lines for simple projects. DO NOT USE FOR: projects already in SDK-style format, non-.NET build systems (npm, Maven, CMake), .NET Framework projects that cannot move to SDK-style. INVOKES: dotnet try-convert, upgrade-assistant tools.
319