-
Notifications
You must be signed in to change notification settings - Fork 293
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
Incorrect binding redirects generated for SqlClient's runtime dependencies #2541
Comments
I'm guessing #2414 would probably fix the issue once and for all if/when it gets merged. |
Is this a dupe of #1900 ? If so I think that issue probably shouldn't have been closed. |
We will investigate this issue and we'll get back to you when we have an update. |
@benjamin-hodgson Hotfix 5.2.1 is out now, would you mind testing with this version and letting us know if this is still an issue please? |
Looks like this'll work for now, at least for our purposes, but it's liable to become broken again as new versions of the upstream libraries come out. The root cause is the missing references in the ref assemblies. (I don't think this issue should be closed.) Thanks for turning this hotfix around so quickly! |
With the release of Azure.Identity 1.12 (and Azure.Core 1.40) this is broken again. My full framework projects (net462 and net48) fail to automatically generate the binding redirects, it needs to be done manually. Referencing the following project combination:
Results in the following error:
Adding the following bindings manually to a app/web.config resolves the problem. But this should be done automatically when automatic binding redirects are enabled.
|
@zoeperryman Do you suggest that this should be handled on the driver side or as a general workaround? I believe it would be overstepping for the driver to make decisions regarding user-defined redirects or bindings. |
I'm suggesting that the binding redirects should automatically be generated when referencing later versions of Azure (and other) libraries then what Microsoft.Data.SqlClient is compiled against. This works for all the other nuget packages out there (well most I guess), what is different or broken about this one? @benjamin-hodgson's original post seemed to suggest this was a problem with the reference assemblies for Microsoft.Data.SqlClient in the nuget file. The fact that these bindings don't get added automatically means the bindings need to be manually added and maintained which is a pain and hugely error prone when you have dozens of solutions that require it. |
@JRahnama This is a real bug in the way the SqlClient package is distributed - please see my original detailed bug report. It was worked-around in v5.2.1 by rebuilding SqlClient against the latest version of Azure.Identity/Azure.Core but as predicted it became broken again when new versions of those upstream packages were released. To fix the bug you could either update your dependencies once again (ie, continue working around it) or get #2414 merged |
@benjamin-hodgson I think this should be fixed (in the absence of auto-generated reference assemblies) by #2878. I've synced the references between the runtime assembly and the reference assembly, and pushed it through CI. Could you test with the package from this CI build please? The direct download URL of the ZIP file containing the .nupkg is here To test, I added a reference to the version of the package (6.0.0-pull.126701, which has a transitive reference to Azure.Identity 1.11.4), then to Azure.Identity 1.12.0. I can see that VS' automatic binding redirects have added a few new entries to app.config. The relevant excerpt: <dependentAssembly>
<assemblyIdentity name="Azure.Core" publicKeyToken="92742159e12e44c8" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-1.40.0.0" newVersion="1.40.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="Azure.Identity" publicKeyToken="92742159e12e44c8" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-1.12.0.0" newVersion="1.12.0.0" />
</dependentAssembly> |
Here is the package from that build. Simply change the extension to .nupkg. Please note, this is an unsigned test package and is not intended for production use. |
Thanks @JRahnama - and yes, it's definitely not intended for production use. This package isn't designed to be anything more than a sanity check to make sure that the downstream projects referencing SqlClient build and that VS generates the correct binding redirects in the output app.config. |
I think this issue just bit me. I had
I was able to eliminate the vulnerable dependencies and get a working Related StackOverflow question: https://stackoverflow.com/questions/79356952/assembly-loading-failures-in-microsoft-data-sqlclients-dependencies/79357028#79357028 |
I should also note that if |
Describe the bug
SqlClient
was compiled withAzure.Core
version 1.35.0.0. When building a project using version 1.38.0.0 (or indeed any other version), the appropriate binding redirect is not generated. This results inFileLoadException
s in the AD authentication codepath - example:(My minimal repro, below, trips on
Azure.Core
but I've also seen errors mentioningValueTuple
andSystem.Threading.Tasks.Extensions
in other contexts. I believe they're all due to the same issue.)The problem here is that the
ResolveAssemblyReferences
target (which is responsible for determining which libraries need binding redirects) consumes reference assemblies from Nuget (when they exist), andSqlClient
's reference assemblies do not declare the library's runtime dependency onAzure.Core
.The reference assembly in ILSpy (
ref\net462\Microsoft.Data.SqlClient.dll
):The code assembly (
lib\net462\Microsoft.Data.SqlClient.dll
):This means
ResolveAssemblyReferences
doesn't realise there's a conflict (it thinksSqlClient
doesn't requireAzure.Core
at all) so fails to generate the correct binding redirects. WhenSqlClient
's code assembly is deployed into the bin folder and run, it requires version 1.35, and, absent the required binding redirect, it dies because it can only find 1.38.To reproduce
The issue manifests when the other assemblies in your compilation all reference v1.38 of the
Azure.Core
assembly. This combination of versions reproduces the issue (though there are other scenarios that produce the same issue with various other assemblies):Build this project and observe the lack of binding redirect for
Azure.Core
(and others, egTasks.Extensions
) inbin\Debug\net472\test.exe.config
:Running the project using
dotnet run
causes the exception above.Expected behavior
The reference assemblies for
SqlClient
should correctly declare all of the library's (immediate) runtime dependencies. This will allowResolveAssemblyReference
to solve the versions correctly and generate the required binding redirects.Further technical details
Microsoft.Data.SqlClient version: 5.2.0 or 3.1.5 (but probably others too)
.NET target: net472
SQL Server version: Any
Operating system: Windows 11
Additional context
Probably not relevant, but: I found this issue in a large repo with thousands of projects. The repo is in the process of being migrated off of CoreXT and onto CentralPackageVersions.
The text was updated successfully, but these errors were encountered: