-
Notifications
You must be signed in to change notification settings - Fork 258
NuGet Errors and Warnings
NuGet #4895: NET Core 2.0: Register all warnings/errors to assets file (including PackageTargetFallback)
The following user scenarios are driving this feature:
- A NuGet warning can be overridden as errors, by the developer from Project properties and/or csproj file.
- A NuGet warning can be suppressed by the developer from Project properties and/or csproj file.
- Per Package NuGet warning can be suppressed by the developer from Project properties and/or csproj file.
- NuGet warnings should follow warning-levels defined in Project just like any other warnings in the project.
All developers who use NuGet using PackageReference. .NET Core, .NET Standard and other projects (opted-in to use PackageReference).
As stated in the problem.
- All the NuGet warnings will be coded. List of all the numbered warnings can be found here - Restore errors and warnings
- These errors and warnings will be written into the assets file so that msbuild can output these errors appropriately.
NuGet supports 3 warning properties in PackageReference based projects at project wide level -
-
TreatWarningsAsErrors
- Treat all NuGet warnings as errors -<TreatWarningsAsErrors>true</TreatWarningsAsErrors>
-
WarningsAsErrors
- Treat specific warnings as errors -<WarningsAsErrors>NU1605</WarningsAsErrors>
-
NoWarn
- Hide Specific warnings -<NoWarn>NU1701</NoWarn>
NuGet also supports 1 warning property at package reference level -
-
NoWarn
- Hide Specific warnings -<PackageReference Include="NuGet.Versioning" Version=4.6.9 NoWarn="NU1603">
The Warning properties are represented in memory using the WarningProperties. ProjectRestoreMetadata
contains an instance of warning properties for the project here. The package specific NoWarn
properties are represented using PackageSpecificWarningProperties.
The cumulative warning properties are stored in WarningPropertiesCollection. During restore the warning properties collection is instantiated in RestoreCollectorLogger
here.
RestoreCollector
Scenario-1: A NuGet warning can be overridden as errors, by the developer from Project properties and/or csproj file
- User creates a new project that references
NuGet.Packaging 3.5.0
that referencesNuGet.Versioning 3.5.0
- User now another package dependency
NuGet.Commands 4.0.0
that has dependency toNuGet.Versioning 4.0.0
as shown in the dependency tree:NuGet.Commands 4.0.0 -> NuGet.Configuration 4.0.0 -> NuGet.Versioning 4.0.0
- User gets a downgrade warning (NU1605):
Detected package downgrade: NuGet.Versioning from 4.0.0 to 3.5.0
NuGet.Packaging 3.5.0 -> NuGet.Versioning 3.5.0
NuGet.Commands 4.0.0 -> NuGet.Configuration 4.0.0 -> NuGet.Versioning 4.0.0
- User now adds the warning (NU1605) as error in the Project.Properties.Build UI:
- Alternatively, user can write the following in the csproj file to treat this warning as error:
Was <TreatSpecificWarningsAsErrors>NU1605</TreatSpecificWarningsAsErrors>
New <WarningsAsErrors>NU1605</WarningsAsErrors>
based on https://github.com/dotnet/project-system/pull/2368#issuecomment-305868038
- User now sees this downgrade as an error.
Scenario-2: A NuGet warning can be suppressed by the developer from Project properties and/or csproj file.
- User creates a new NET Standard 2.0 project
- User add NuGet reference to
Microsoft.Composition
package – this gets added due to PackageTargetFallBack - User sees the following warning(NU1701) as part of each build:
Package 'Microsoft.Composition' was restored using 'net461' instead the project target framework 'netstandard2.0'. This may cause compatibility problems.
- User can suppress this warning(NU1701) totally for the project so that any warning w.r.t PackageTargetFallback is never shown for the project in Project.Properties.Build UI as follows:
- Alternatively, user can suppress this warning(NU1701) by using the following line in the csproj file:
<NoWarn>NU1701</NoWarn>
Scenario-3: Per Package NuGet warning can be suppressed by the developer from Project properties and/or csproj file.
- User creates a new NET Standard 2.0 project
- User add NuGet reference to
Microsoft.Composition
package – this gets added due to PackageTargetFallBack - User sees the following warning(NU1701) as part of each build:
Package 'Microsoft.Composition' was restored using 'net461' instead the project target framework 'netstandard2.0'. This may cause compatibility problems.
- User can suppress this warning(NU1701) specific to the package 'Microsoft.Composition' in the package dependency property:
- User can do the same by specifying the suppression in the csproj file (comma or semi-colon separated list of warnings):
<PackageReference Include="Contoso.Base.API" Version="1.0.3">
<NoWarn>NU1701</NoWarn>
</PackageReference>
Scenario-4: NuGet warnings should follow warning-levels defined in Project just like any other warnings in the project.
- User creates a new NET Standard 2.0 project
- User goes to Project.Properties.Build and sets the Warning level as 1:
- Alternatively, in the csproj file, the users sets the following to set the Warning level as 1:
<WarningLevel>1</WarningLevel>
- User now only sees severe warnings and not the other warnings. TBD Classification of warnings into levels 1 through 4.
- Package downgrades should be errors for .Net Core 2.0 projects. (As per requirements by the team)
- PackageTargetFallback warnings should be ignored for certain package dependencies if developer knows that a package is being brought into the project due to PackageTargetFallback and does not want be reminded again and again for each restore.
Scenario-1: Package downgrades should be errors for .Net Core 2.0 projects.
- User creates a new project that directly references “Microsoft.AspNetCore.Hosting” 1.0.0
- User now adds a new reference “Microsoft.AspNetCore” 1.1.0 that references “Microsoft.AspNetCore.Hosting” 1.0.0
- “Microsoft.AspNetCore.Hosting” package currently gets pinned to the lower version, rather than getting lifted to the version depended upon by the Core package.
- User gets the downgrade error - This was originally a warning that this project type treats as an error.
- User should be able to go to package reference properties, see this warning is an error and be able to clear it to make the current error back to warning.
Scenario-2: 3. PackageTargetFallback warnings should be ignored for certain package dependencies...
- User creates a new NET Standard 2.0 project
- User add NuGet reference to
Microsoft.Composition
package – this gets added due to PackageTargetFallBack - User sees the following warning(NU1701) as part of each build:
Package 'Microsoft.Composition' was restored using 'net461' instead the project target framework 'netstandard2.0'. This may cause compatibility problems.
- User can suppress this warning(NU1701) totally for the project so that any warning w.r.t PackageTargetFallback is never shown for the project.
- User can suppress this warning(NU1701) for only
Microsoft.Composition
package so that the warning does not show forMicrosoft.Composition
package but it will show for newer such packages added due to PackageTargetFallback. - Suppression mechanisms (TBD)
Check out the proposals in the accepted
& proposed
folders on the repository, and active PRs for proposals being discussed today.