diff --git a/NuGet.config b/NuGet.config
index 83bb3a983858..1d1ed063d794 100644
--- a/NuGet.config
+++ b/NuGet.config
@@ -4,10 +4,10 @@
-
+
-
+
@@ -30,10 +30,10 @@
-
+
-
+
diff --git a/eng/Baseline.Designer.props b/eng/Baseline.Designer.props
index 28c064e01b73..3fd723523160 100644
--- a/eng/Baseline.Designer.props
+++ b/eng/Baseline.Designer.props
@@ -2,117 +2,117 @@
$(MSBuildAllProjects);$(MSBuildThisFileFullPath)
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
@@ -120,279 +120,279 @@
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
-
-
-
+
+
+
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
-
-
-
-
-
+
+
+
+
+
- 9.0.4
+ 9.0.6
-
-
-
-
-
+
+
+
+
+
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
-
-
-
-
+
+
+
+
+
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
-
+
-
-
-
+
+
+
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
-
+
-
+
- 9.0.4
+ 9.0.6
-
-
-
-
-
-
+
+
+
+
+
+
-
+
-
-
-
-
-
-
-
+
+
+
+
+
+
+
-
-
-
-
-
-
+
+
+
+
+
+
-
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
-
-
+
+
-
-
+
+
-
-
+
+
- 9.0.4
+ 9.0.6
-
+
-
+
-
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
@@ -401,83 +401,83 @@
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
-
+
-
-
-
-
+
+
+
+
-
-
-
-
+
+
+
+
-
-
-
-
+
+
+
+
- 9.0.4
+ 9.0.6
-
-
+
+
-
+
-
-
+
+
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
@@ -493,510 +493,510 @@
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
+
+
-
-
+
+
-
-
+
+
- 9.0.4
+ 9.0.6
-
-
-
-
-
-
+
+
+
+
+
+
-
-
-
-
-
+
+
+
+
+
-
-
-
-
-
-
+
+
+
+
+
+
-
-
-
-
-
-
+
+
+
+
+
+
- 9.0.4
+ 9.0.6
-
-
+
+
-
+
-
-
+
+
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
-
+
-
+
-
+
- 9.0.4
+ 9.0.6
-
+
-
+
-
+
- 9.0.4
+ 9.0.6
-
+
-
+
-
+
- 9.0.4
+ 9.0.6
-
-
-
-
+
+
+
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
+
+
-
-
+
+
-
-
+
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
-
-
-
+
+
+
-
-
-
+
+
+
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
-
-
+
+
-
-
+
+
-
-
+
+
- 9.0.4
+ 9.0.6
-
-
-
-
-
+
+
+
+
+
-
-
-
-
+
+
+
+
-
-
-
-
-
+
+
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
-
+
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
-
-
-
+
+
+
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
-
-
-
+
+
+
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
-
-
-
-
+
+
+
+
-
-
-
-
+
+
+
+
-
-
-
-
+
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
-
-
-
+
+
+
+
+
-
-
-
-
-
+
+
+
+
+
-
-
-
-
-
+
+
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
-
-
+
+
+
-
-
+
+
-
-
-
+
+
+
- 9.0.4
+ 9.0.6
- 9.0.4
+ 9.0.6
-
+
- 9.0.4
+ 9.0.6
-
+
\ No newline at end of file
diff --git a/eng/Baseline.xml b/eng/Baseline.xml
index 71537197d7a9..4c39c3649c99 100644
--- a/eng/Baseline.xml
+++ b/eng/Baseline.xml
@@ -4,110 +4,110 @@ This file contains a list of all the packages and their versions which were rele
Update this list when preparing for a new patch.
-->
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/eng/Version.Details.xml b/eng/Version.Details.xml
index 17a58cbdce67..45cd5c7c30f3 100644
--- a/eng/Version.Details.xml
+++ b/eng/Version.Details.xml
@@ -9,325 +9,325 @@
-->
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-efcore
- 6765359588e8b38bab2a7974db9398432703828f
+ 67d253c17619e6ba325e5390905ea2a13cc7f532
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
https://github.com/dotnet/xdt
@@ -367,9 +367,9 @@
bc1c3011064a493b0ca527df6fb7215e2e5cfa96
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
@@ -380,47 +380,47 @@
-
+
https://dev.azure.com/dnceng/internal/_git/dotnet-runtime
- e36e4d1a8f8dfb08d7e3a6041459c9791d732c01
+ 3c298d9f00936d651cc47d221762474e25277672
https://github.com/dotnet/winforms
9b822fd70005bf5632d12fe76811b97b3dd044e4
-
+
https://github.com/dotnet/arcade
- aa61e8c20a869bcc994f8b29eb07d927d2bec6f4
+ 0d52a8b262d35fa2fde84e398cb2e791b8454bd2
-
+
https://github.com/dotnet/arcade
- aa61e8c20a869bcc994f8b29eb07d927d2bec6f4
+ 0d52a8b262d35fa2fde84e398cb2e791b8454bd2
-
+
https://github.com/dotnet/arcade
- aa61e8c20a869bcc994f8b29eb07d927d2bec6f4
+ 0d52a8b262d35fa2fde84e398cb2e791b8454bd2
-
+
https://github.com/dotnet/arcade
- aa61e8c20a869bcc994f8b29eb07d927d2bec6f4
+ 0d52a8b262d35fa2fde84e398cb2e791b8454bd2
-
+
https://github.com/dotnet/arcade
- aa61e8c20a869bcc994f8b29eb07d927d2bec6f4
+ 0d52a8b262d35fa2fde84e398cb2e791b8454bd2
-
+
https://github.com/dotnet/arcade
- aa61e8c20a869bcc994f8b29eb07d927d2bec6f4
+ 0d52a8b262d35fa2fde84e398cb2e791b8454bd2
-
+
https://github.com/dotnet/extensions
- f0a1a79c0b0dfb724edfcbcef82cb22d44e13e13
+ 04bd58871e6dd4dfd2fbcf5f0365c89d2466fffe
-
+
https://github.com/dotnet/extensions
- f0a1a79c0b0dfb724edfcbcef82cb22d44e13e13
+ 04bd58871e6dd4dfd2fbcf5f0365c89d2466fffe
https://github.com/nuget/nuget.client
diff --git a/eng/Versions.props b/eng/Versions.props
index 30f307266c9c..9b36b8ee3df4 100644
--- a/eng/Versions.props
+++ b/eng/Versions.props
@@ -8,7 +8,7 @@
9
0
- 5
+ 7
true
@@ -68,92 +68,92 @@
-->
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5-servicing.25215.9
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5-servicing.25215.9
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5-servicing.25215.9
- 9.0.5-servicing.25215.9
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7-servicing.25316.16
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7-servicing.25316.16
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7-servicing.25316.16
+ 9.0.7-servicing.25316.16
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
- 9.0.5-servicing.25215.9
- 9.0.5
+ 9.0.7-servicing.25316.16
+ 9.0.7
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
- 9.5.0-preview.1.25211.2
- 9.5.0-preview.1.25211.2
+ 9.7.0-preview.1.25306.2
+ 9.7.0-preview.1.25306.2
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
- 9.0.5
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
+ 9.0.7
4.11.0-3.24554.2
4.11.0-3.24554.2
@@ -166,10 +166,10 @@
6.2.4
6.2.4
- 9.0.0-beta.25208.6
- 9.0.0-beta.25208.6
- 9.0.0-beta.25208.6
- 9.0.0-beta.25208.6
+ 9.0.0-beta.25302.2
+ 9.0.0-beta.25302.2
+ 9.0.0-beta.25302.2
+ 9.0.0-beta.25302.2
9.0.0-alpha.1.24575.1
diff --git a/eng/common/core-templates/job/source-build.yml b/eng/common/core-templates/job/source-build.yml
index c4713c8b6ede..d47f09d58fd9 100644
--- a/eng/common/core-templates/job/source-build.yml
+++ b/eng/common/core-templates/job/source-build.yml
@@ -26,6 +26,8 @@ parameters:
# Specifies the build script to invoke to perform the build in the repo. The default
# './build.sh' should work for typical Arcade repositories, but this is customizable for
# difficult situations.
+ # buildArguments: ''
+ # Specifies additional build arguments to pass to the build script.
# jobProperties: {}
# A list of job properties to inject at the top level, for potential extensibility beyond
# container and pool.
diff --git a/eng/common/core-templates/job/source-index-stage1.yml b/eng/common/core-templates/job/source-index-stage1.yml
index 205fb5b3a395..8b833332b3ee 100644
--- a/eng/common/core-templates/job/source-index-stage1.yml
+++ b/eng/common/core-templates/job/source-index-stage1.yml
@@ -1,7 +1,7 @@
parameters:
runAsPublic: false
- sourceIndexUploadPackageVersion: 2.0.0-20240522.1
- sourceIndexProcessBinlogPackageVersion: 1.0.1-20240522.1
+ sourceIndexUploadPackageVersion: 2.0.0-20250425.2
+ sourceIndexProcessBinlogPackageVersion: 1.0.1-20250425.2
sourceIndexPackageSource: https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet-tools/nuget/v3/index.json
sourceIndexBuildCommand: powershell -NoLogo -NoProfile -ExecutionPolicy Bypass -Command "eng/common/build.ps1 -restore -build -binarylog -ci"
preSteps: []
diff --git a/eng/common/core-templates/post-build/post-build.yml b/eng/common/core-templates/post-build/post-build.yml
index 454fd75c7aff..a8c0bd3b9214 100644
--- a/eng/common/core-templates/post-build/post-build.yml
+++ b/eng/common/core-templates/post-build/post-build.yml
@@ -44,6 +44,11 @@ parameters:
displayName: Publish installers and checksums
type: boolean
default: true
+
+ - name: requireDefaultChannels
+ displayName: Fail the build if there are no default channel(s) registrations for the current build
+ type: boolean
+ default: false
- name: SDLValidationParameters
type: object
@@ -312,5 +317,6 @@ stages:
-PublishingInfraVersion ${{ parameters.publishingInfraVersion }}
-AzdoToken '$(System.AccessToken)'
-WaitPublishingFinish true
+ -RequireDefaultChannels ${{ parameters.requireDefaultChannels }}
-ArtifactsPublishingAdditionalParameters '${{ parameters.artifactsPublishingAdditionalParameters }}'
-SymbolPublishingAdditionalParameters '${{ parameters.symbolPublishingAdditionalParameters }}'
diff --git a/eng/common/core-templates/steps/source-build.yml b/eng/common/core-templates/steps/source-build.yml
index 2915d29bb7f6..37133b55b754 100644
--- a/eng/common/core-templates/steps/source-build.yml
+++ b/eng/common/core-templates/steps/source-build.yml
@@ -79,6 +79,7 @@ steps:
${{ coalesce(parameters.platform.buildScript, './build.sh') }} --ci \
--configuration $buildConfig \
--restore --build --pack $publishArgs -bl \
+ ${{ parameters.platform.buildArguments }} \
$officialBuildArgs \
$internalRuntimeDownloadArgs \
$internalRestoreArgs \
diff --git a/eng/common/post-build/publish-using-darc.ps1 b/eng/common/post-build/publish-using-darc.ps1
index 90b58e32a87b..a261517ef906 100644
--- a/eng/common/post-build/publish-using-darc.ps1
+++ b/eng/common/post-build/publish-using-darc.ps1
@@ -5,7 +5,8 @@ param(
[Parameter(Mandatory=$false)][string] $MaestroApiEndPoint = 'https://maestro.dot.net',
[Parameter(Mandatory=$true)][string] $WaitPublishingFinish,
[Parameter(Mandatory=$false)][string] $ArtifactsPublishingAdditionalParameters,
- [Parameter(Mandatory=$false)][string] $SymbolPublishingAdditionalParameters
+ [Parameter(Mandatory=$false)][string] $SymbolPublishingAdditionalParameters,
+ [Parameter(Mandatory=$false)][string] $RequireDefaultChannels
)
try {
@@ -33,6 +34,10 @@ try {
if ("false" -eq $WaitPublishingFinish) {
$optionalParams.Add("--no-wait") | Out-Null
}
+
+ if ("true" -eq $RequireDefaultChannels) {
+ $optionalParams.Add("--default-channels-required") | Out-Null
+ }
& $darc add-build-to-channel `
--id $buildId `
diff --git a/eng/targets/Helix.Common.props b/eng/targets/Helix.Common.props
index 8a0fdf3481d3..1ba8ba99dbe3 100644
--- a/eng/targets/Helix.Common.props
+++ b/eng/targets/Helix.Common.props
@@ -2,7 +2,7 @@
(AlmaLinux.8.Amd64.Open)Ubuntu.2204.Amd64.Open@mcr.microsoft.com/dotnet-buildtools/prereqs:almalinux-8-helix-amd64
- (Alpine.318.Amd64.Open)Ubuntu.2204.Amd64.Open@mcr.microsoft.com/dotnet-buildtools/prereqs:alpine-3.18-helix-amd64
+ (Alpine.321.Amd64.Open)azurelinux.3.Amd64.Open@mcr.microsoft.com/dotnet-buildtools/prereqs:alpine-3.21-helix-amd64
(Debian.12.Amd64.Open)Ubuntu.2204.Amd64.Open@mcr.microsoft.com/dotnet-buildtools/prereqs:debian-12-helix-amd64
(Fedora.41.Amd64.Open)Ubuntu.2204.Amd64.Open@mcr.microsoft.com/dotnet-buildtools/prereqs:fedora-41-helix
(Mariner)Ubuntu.2204.Amd64.Open@mcr.microsoft.com/dotnet-buildtools/prereqs:cbl-mariner-2.0-helix-amd64
@@ -42,7 +42,7 @@
-
+
diff --git a/eng/targets/Helix.targets b/eng/targets/Helix.targets
index 70e01877befa..0aab28ef20cc 100644
--- a/eng/targets/Helix.targets
+++ b/eng/targets/Helix.targets
@@ -17,7 +17,7 @@
$(HelixQueueAlmaLinux8);
- $(HelixQueueAlpine318);
+ $(HelixQueueAlpine);
$(HelixQueueDebian12);
$(HelixQueueFedora40);
$(HelixQueueMariner);
diff --git a/global.json b/global.json
index 00bc10af2c7f..df8d08a6315e 100644
--- a/global.json
+++ b/global.json
@@ -1,9 +1,9 @@
{
"sdk": {
- "version": "9.0.105"
+ "version": "9.0.107"
},
"tools": {
- "dotnet": "9.0.105",
+ "dotnet": "9.0.107",
"runtimes": {
"dotnet/x86": [
"$(MicrosoftNETCoreBrowserDebugHostTransportVersion)"
@@ -27,7 +27,7 @@
"jdk": "latest"
},
"msbuild-sdks": {
- "Microsoft.DotNet.Arcade.Sdk": "9.0.0-beta.25208.6",
- "Microsoft.DotNet.Helix.Sdk": "9.0.0-beta.25208.6"
+ "Microsoft.DotNet.Arcade.Sdk": "9.0.0-beta.25302.2",
+ "Microsoft.DotNet.Helix.Sdk": "9.0.0-beta.25302.2"
}
}
diff --git a/src/Components/test/E2ETest/ServerRenderingTests/FormHandlingTests/FormWithParentBindingContextTest.cs b/src/Components/test/E2ETest/ServerRenderingTests/FormHandlingTests/FormWithParentBindingContextTest.cs
index 792e222f4183..53fd2addd404 100644
--- a/src/Components/test/E2ETest/ServerRenderingTests/FormHandlingTests/FormWithParentBindingContextTest.cs
+++ b/src/Components/test/E2ETest/ServerRenderingTests/FormHandlingTests/FormWithParentBindingContextTest.cs
@@ -1287,7 +1287,7 @@ public void CanBindToFormWithFiles()
}
[Theory]
- [InlineData(true)]
+ // [InlineData(true)] QuarantinedTest: https://github.com/dotnet/aspnetcore/issues/61882
[InlineData(false)]
public void CanUseFormWithMethodGet(bool suppressEnhancedNavigation)
{
diff --git a/src/Http/Headers/test/CookieHeaderValueTest.cs b/src/Http/Headers/test/CookieHeaderValueTest.cs
index 6623a8ed13dd..6ad2e962d005 100644
--- a/src/Http/Headers/test/CookieHeaderValueTest.cs
+++ b/src/Http/Headers/test/CookieHeaderValueTest.cs
@@ -75,7 +75,7 @@ public static TheoryData InvalidCookieValues
}
}
- public static TheoryData, string?[]> ListOfCookieHeaderDataSet
+ public static TheoryData, string?[]> ListOfStrictCookieHeaderDataSet
{
get
{
@@ -94,19 +94,30 @@ public static TheoryData InvalidCookieValues
dataset.Add(new[] { header1 }.ToList(), new[] { string1 });
dataset.Add(new[] { header1, header1 }.ToList(), new[] { string1, string1 });
- dataset.Add(new[] { header1, header1 }.ToList(), new[] { string1, null, "", " ", ";", " , ", string1 });
dataset.Add(new[] { header2 }.ToList(), new[] { string2 });
dataset.Add(new[] { header1, header2 }.ToList(), new[] { string1, string2 });
- dataset.Add(new[] { header1, header2 }.ToList(), new[] { string1 + ", " + string2 });
dataset.Add(new[] { header2, header1 }.ToList(), new[] { string2 + "; " + string1 });
dataset.Add(new[] { header1, header2, header3, header4 }.ToList(), new[] { string1, string2, string3, string4 });
- dataset.Add(new[] { header1, header2, header3, header4 }.ToList(), new[] { string.Join(",", string1, string2, string3, string4) });
dataset.Add(new[] { header1, header2, header3, header4 }.ToList(), new[] { string.Join(";", string1, string2, string3, string4) });
return dataset;
}
}
+ public static TheoryData, string?[]> ListOfCookieHeaderDataSet
+ {
+ get
+ {
+ var header1 = new CookieHeaderValue("name1", "n1=v1&n2=v2&n3=v3");
+ var string1 = "name1=n1=v1&n2=v2&n3=v3";
+
+ var dataset = new TheoryData, string?[]>();
+ dataset.Concat(ListOfStrictCookieHeaderDataSet);
+ dataset.Add(new[] { header1, header1 }.ToList(), new[] { string1, null, "", " ", ";", " , ", string1 });
+ return dataset;
+ }
+ }
+
public static TheoryData?, string?[]> ListWithInvalidCookieHeaderDataSet
{
get
@@ -127,18 +138,19 @@ public static TheoryData InvalidCookieValues
dataset.Add(new[] { header1 }.ToList(), new[] { validString1, invalidString1 });
dataset.Add(new[] { header1 }.ToList(), new[] { validString1, null, "", " ", ";", " , ", invalidString1 });
dataset.Add(new[] { header1 }.ToList(), new[] { invalidString1, null, "", " ", ";", " , ", validString1 });
- dataset.Add(new[] { header1 }.ToList(), new[] { validString1 + ", " + invalidString1 });
- dataset.Add(new[] { header2 }.ToList(), new[] { invalidString1 + ", " + validString2 });
+ dataset.Add(null, new[] { validString1 + ", " });
+ dataset.Add(null, new[] { invalidString1 + ", " + validString2 });
dataset.Add(new[] { header1 }.ToList(), new[] { invalidString1 + "; " + validString1 });
dataset.Add(new[] { header2 }.ToList(), new[] { validString2 + "; " + invalidString1 });
dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { invalidString1, validString1, validString2, validString3 });
dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { validString1, invalidString1, validString2, validString3 });
dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { validString1, validString2, invalidString1, validString3 });
dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { validString1, validString2, validString3, invalidString1 });
- dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { string.Join(",", invalidString1, validString1, validString2, validString3) });
- dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { string.Join(",", validString1, invalidString1, validString2, validString3) });
- dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { string.Join(",", validString1, validString2, invalidString1, validString3) });
- dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { string.Join(",", validString1, validString2, validString3, invalidString1) });
+ dataset.Add(null, new[] { string.Join(",", invalidString1, validString1, validString2, validString3) });
+ dataset.Add(null, new[] { string.Join(",", validString1, invalidString1, validString2, validString3) });
+ dataset.Add(null, new[] { string.Join(",", validString1, validString2, invalidString1, validString3) });
+ dataset.Add(null, new[] { string.Join(",", validString1, validString2, validString3, invalidString1) });
+ dataset.Add(null, new[] { string.Join(",", validString1, validString2, validString3) });
dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { string.Join(";", invalidString1, validString1, validString2, validString3) });
dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { string.Join(";", validString1, invalidString1, validString2, validString3) });
dataset.Add(new[] { header1, header2, header3 }.ToList(), new[] { string.Join(";", validString1, validString2, invalidString1, validString3) });
@@ -248,7 +260,7 @@ public void CookieHeaderValue_ParseList_AcceptsValidValues(IList cookies, string[] input)
{
var results = CookieHeaderValue.ParseStrictList(input);
@@ -267,7 +279,7 @@ public void CookieHeaderValue_TryParseList_AcceptsValidValues(IList cookies, string[] input)
{
var result = CookieHeaderValue.TryParseStrictList(input, out var results);
diff --git a/src/Http/Http.Extensions/test/HeaderDictionaryTypeExtensionsTest.cs b/src/Http/Http.Extensions/test/HeaderDictionaryTypeExtensionsTest.cs
index 33ecc3ff1ea8..b4071866534b 100644
--- a/src/Http/Http.Extensions/test/HeaderDictionaryTypeExtensionsTest.cs
+++ b/src/Http/Http.Extensions/test/HeaderDictionaryTypeExtensionsTest.cs
@@ -214,7 +214,7 @@ public void GetListT_StringWithQualityHeaderValidValue_Success()
public void GetListT_CookieHeaderValue_Success()
{
var context = new DefaultHttpContext();
- context.Request.Headers.Cookie = "cookie1=a,cookie2=b";
+ context.Request.Headers.Cookie = "cookie1=a;cookie2=b";
var result = context.Request.GetTypedHeaders().GetList(HeaderNames.Cookie);
diff --git a/src/Http/Http/test/RequestCookiesCollectionTests.cs b/src/Http/Http/test/RequestCookiesCollectionTests.cs
index e08a53f29711..d584f2db0599 100644
--- a/src/Http/Http/test/RequestCookiesCollectionTests.cs
+++ b/src/Http/Http/test/RequestCookiesCollectionTests.cs
@@ -33,11 +33,18 @@ public void ParseManyCookies()
[Theory]
[InlineData(",", null)]
[InlineData(";", null)]
- [InlineData("er=dd,cc,bb", new[] { "dd" })]
- [InlineData("er=dd,err=cc,errr=bb", new[] { "dd", "cc", "bb" })]
- [InlineData("errorcookie=dd,:(\"sa;", new[] { "dd" })]
+ [InlineData("er=dd,cc,bb", null)]
+ [InlineData("er=dd,err=cc,errr=bb", null)]
+ [InlineData("errorcookie=dd,:(\"sa;", null)]
[InlineData("s;", null)]
[InlineData("er=;,err=,errr=\\,errrr=\"", null)]
+ [InlineData("a@a=a;", null)]
+ [InlineData("a@ a=a;", null)]
+ [InlineData("a a=a;", null)]
+ [InlineData(",a=a;", null)]
+ [InlineData(",a=a", null)]
+ [InlineData("a=a;,b=b", new []{ "a" })] // valid cookie followed by invalid cookie
+ [InlineData(",a=a;b=b", new[] { "b" })] // invalid cookie followed by valid cookie
public void ParseInvalidCookies(string cookieToParse, string[] expectedCookieValues)
{
var cookies = RequestCookieCollection.Parse(new StringValues(new[] { cookieToParse }));
diff --git a/src/Http/Shared/CookieHeaderParserShared.cs b/src/Http/Shared/CookieHeaderParserShared.cs
index e4b1d83e519a..0eb1c64d533a 100644
--- a/src/Http/Shared/CookieHeaderParserShared.cs
+++ b/src/Http/Shared/CookieHeaderParserShared.cs
@@ -89,6 +89,17 @@ public static bool TryParseValue(StringSegment value, ref int index, bool suppor
if (!TryGetCookieLength(value, ref current, out parsedName, out parsedValue))
{
+ var separatorIndex = value.IndexOf(';', current);
+ if (separatorIndex > 0)
+ {
+ // Skip the invalid values and keep trying.
+ index = separatorIndex;
+ }
+ else
+ {
+ // No more separators, so we're done.
+ index = value.Length;
+ }
return false;
}
@@ -97,6 +108,17 @@ public static bool TryParseValue(StringSegment value, ref int index, bool suppor
// If we support multiple values and we've not reached the end of the string, then we must have a separator.
if ((separatorFound && !supportsMultipleValues) || (!separatorFound && (current < value.Length)))
{
+ var separatorIndex = value.IndexOf(';', current);
+ if (separatorIndex > 0)
+ {
+ // Skip the invalid values and keep trying.
+ index = separatorIndex;
+ }
+ else
+ {
+ // No more separators, so we're done.
+ index = value.Length;
+ }
return false;
}
@@ -112,7 +134,7 @@ private static int GetNextNonEmptyOrWhitespaceIndex(StringSegment input, int sta
separatorFound = false;
var current = startIndex + HttpRuleParser.GetWhitespaceLength(input, startIndex);
- if ((current == input.Length) || (input[current] != ',' && input[current] != ';'))
+ if (current == input.Length || input[current] != ';')
{
return current;
}
@@ -125,8 +147,8 @@ private static int GetNextNonEmptyOrWhitespaceIndex(StringSegment input, int sta
if (skipEmptyValues)
{
- // Most headers only split on ',', but cookies primarily split on ';'
- while ((current < input.Length) && ((input[current] == ',') || (input[current] == ';')))
+ // Cookies are split on ';'
+ while (current < input.Length && input[current] == ';')
{
current++; // skip delimiter.
current = current + HttpRuleParser.GetWhitespaceLength(input, current);
@@ -136,6 +158,18 @@ private static int GetNextNonEmptyOrWhitespaceIndex(StringSegment input, int sta
return current;
}
+ /*
+ * https://www.rfc-editor.org/rfc/rfc6265#section-4.1.1
+ * cookie-pair = cookie-name "=" cookie-value
+ * cookie-name = token
+ * token = 1*
+ separators = "(" | ")" | "<" | ">" | "@"
+ | "," | ";" | ":" | "\" | <">
+ | "/" | "[" | "]" | "?" | "="
+ | "{" | "}" | SP | HT
+ CTL =
+ */
// name=value; name="value"
internal static bool TryGetCookieLength(StringSegment input, ref int offset, [NotNullWhen(true)] out StringSegment? parsedName, [NotNullWhen(true)] out StringSegment? parsedValue)
{
diff --git a/src/Middleware/HttpOverrides/src/ForwardedHeadersMiddleware.cs b/src/Middleware/HttpOverrides/src/ForwardedHeadersMiddleware.cs
index 6b2a118cb132..d00ccfa0a13d 100644
--- a/src/Middleware/HttpOverrides/src/ForwardedHeadersMiddleware.cs
+++ b/src/Middleware/HttpOverrides/src/ForwardedHeadersMiddleware.cs
@@ -220,19 +220,19 @@ public void ApplyForwarders(HttpContext context)
for (; entriesConsumed < sets.Length; entriesConsumed++)
{
var set = sets[entriesConsumed];
- if (checkFor)
+ // For the first instance, allow remoteIp to be null for servers that don't support it natively.
+ if (currentValues.RemoteIpAndPort != null && checkKnownIps && !CheckKnownAddress(currentValues.RemoteIpAndPort.Address))
{
- // For the first instance, allow remoteIp to be null for servers that don't support it natively.
- if (currentValues.RemoteIpAndPort != null && checkKnownIps && !CheckKnownAddress(currentValues.RemoteIpAndPort.Address))
+ // Stop at the first unknown remote IP, but still apply changes processed so far.
+ if (_logger.IsEnabled(LogLevel.Debug))
{
- // Stop at the first unknown remote IP, but still apply changes processed so far.
- if (_logger.IsEnabled(LogLevel.Debug))
- {
- _logger.LogDebug(1, "Unknown proxy: {RemoteIpAndPort}", currentValues.RemoteIpAndPort);
- }
- break;
+ _logger.LogDebug(1, "Unknown proxy: {RemoteIpAndPort}", currentValues.RemoteIpAndPort);
}
+ break;
+ }
+ if (checkFor)
+ {
if (IPEndPoint.TryParse(set.IpAndPortText, out var parsedEndPoint))
{
applyChanges = true;
diff --git a/src/Middleware/HttpOverrides/test/ForwardedHeadersMiddlewareTest.cs b/src/Middleware/HttpOverrides/test/ForwardedHeadersMiddlewareTest.cs
index aa33a191e7b7..4fd1341acc45 100644
--- a/src/Middleware/HttpOverrides/test/ForwardedHeadersMiddlewareTest.cs
+++ b/src/Middleware/HttpOverrides/test/ForwardedHeadersMiddlewareTest.cs
@@ -962,6 +962,79 @@ public async Task AllOptionsDisabledRequestDoesntChange()
Assert.Equal(PathString.Empty, context.Request.PathBase);
}
+ [Theory]
+ [InlineData(ForwardedHeaders.XForwardedFor, false)]
+ [InlineData(ForwardedHeaders.XForwardedFor, true)]
+ [InlineData(ForwardedHeaders.XForwardedHost, false)]
+ [InlineData(ForwardedHeaders.XForwardedHost, true)]
+ [InlineData(ForwardedHeaders.XForwardedProto, false)]
+ [InlineData(ForwardedHeaders.XForwardedProto, true)]
+ [InlineData(ForwardedHeaders.XForwardedPrefix, false)]
+ [InlineData(ForwardedHeaders.XForwardedPrefix, true)]
+ public async Task IgnoreXForwardedHeadersFromUnknownProxy(ForwardedHeaders forwardedHeaders, bool unknownProxy)
+ {
+ using var host = new HostBuilder()
+ .ConfigureWebHost(webHostBuilder =>
+ {
+ webHostBuilder
+ .UseTestServer()
+ .Configure(app =>
+ {
+ var options = new ForwardedHeadersOptions
+ {
+ ForwardedHeaders = forwardedHeaders
+ };
+ if (!unknownProxy)
+ {
+ var proxy = IPAddress.Parse("10.0.0.1");
+ options.KnownProxies.Add(proxy);
+ }
+ app.UseForwardedHeaders(options);
+ });
+ }).Build();
+
+ await host.StartAsync();
+
+ var server = host.GetTestServer();
+
+ var context = await server.SendAsync(c =>
+ {
+ c.Request.Headers["X-Forwarded-For"] = "11.111.111.11";
+ c.Request.Headers["X-Forwarded-Host"] = "testhost";
+ c.Request.Headers["X-Forwarded-Proto"] = "Protocol";
+ c.Request.Headers["X-Forwarded-Prefix"] = "/pathbase";
+ c.Connection.RemoteIpAddress = IPAddress.Parse("10.0.0.1");
+ c.Connection.RemotePort = 99;
+ });
+
+ if (unknownProxy)
+ {
+ Assert.Equal("10.0.0.1", context.Connection.RemoteIpAddress.ToString());
+ Assert.Equal("localhost", context.Request.Host.ToString());
+ Assert.Equal("http", context.Request.Scheme);
+ Assert.Equal(PathString.Empty, context.Request.PathBase);
+ }
+ else
+ {
+ if (forwardedHeaders.HasFlag(ForwardedHeaders.XForwardedFor))
+ {
+ Assert.Equal("11.111.111.11", context.Connection.RemoteIpAddress.ToString());
+ }
+ if (forwardedHeaders.HasFlag(ForwardedHeaders.XForwardedHost))
+ {
+ Assert.Equal("testhost", context.Request.Host.ToString());
+ }
+ if (forwardedHeaders.HasFlag(ForwardedHeaders.XForwardedProto))
+ {
+ Assert.Equal("Protocol", context.Request.Scheme);
+ }
+ if (forwardedHeaders.HasFlag(ForwardedHeaders.XForwardedPrefix))
+ {
+ Assert.Equal("/pathbase", context.Request.PathBase);
+ }
+ }
+ }
+
[Fact]
public async Task PartiallyEnabledForwardsPartiallyChangesRequest()
{
diff --git a/src/Middleware/OutputCaching/src/Memory/MemoryOutputCacheStore.cs b/src/Middleware/OutputCaching/src/Memory/MemoryOutputCacheStore.cs
index a75546b6793f..38a38069b32c 100644
--- a/src/Middleware/OutputCaching/src/Memory/MemoryOutputCacheStore.cs
+++ b/src/Middleware/OutputCaching/src/Memory/MemoryOutputCacheStore.cs
@@ -2,6 +2,7 @@
// The .NET Foundation licenses this file to you under the MIT license.
using System.Diagnostics;
+using System.Linq;
using Microsoft.Extensions.Caching.Memory;
namespace Microsoft.AspNetCore.OutputCaching.Memory;
@@ -9,7 +10,7 @@ namespace Microsoft.AspNetCore.OutputCaching.Memory;
internal sealed class MemoryOutputCacheStore : IOutputCacheStore
{
private readonly MemoryCache _cache;
- private readonly Dictionary> _taggedEntries = new();
+ private readonly Dictionary> _taggedEntries = [];
private readonly object _tagsLock = new();
internal MemoryOutputCacheStore(MemoryCache cache)
@@ -20,7 +21,7 @@ internal MemoryOutputCacheStore(MemoryCache cache)
}
// For testing
- internal Dictionary> TaggedEntries => _taggedEntries;
+ internal Dictionary> TaggedEntries => _taggedEntries.ToDictionary(kvp => kvp.Key, kvp => kvp.Value.Select(t => t.Key).ToHashSet());
public ValueTask EvictByTagAsync(string tag, CancellationToken cancellationToken)
{
@@ -30,7 +31,7 @@ public ValueTask EvictByTagAsync(string tag, CancellationToken cancellationToken
{
if (_taggedEntries.TryGetValue(tag, out var keys))
{
- if (keys != null && keys.Count > 0)
+ if (keys is { Count: > 0 })
{
// If MemoryCache changed to run eviction callbacks inline in Remove, iterating over keys could throw
// To prevent allocating a copy of the keys we check if the eviction callback ran,
@@ -40,7 +41,7 @@ public ValueTask EvictByTagAsync(string tag, CancellationToken cancellationToken
while (i > 0)
{
var oldCount = keys.Count;
- foreach (var key in keys)
+ foreach (var (key, _) in keys)
{
_cache.Remove(key);
i--;
@@ -74,6 +75,8 @@ public ValueTask SetAsync(string key, byte[] value, string[]? tags, TimeSpan val
ArgumentNullException.ThrowIfNull(key);
ArgumentNullException.ThrowIfNull(value);
+ var entryId = Guid.NewGuid();
+
if (tags != null)
{
// Lock with SetEntry() to prevent EvictByTagAsync() from trying to remove a tag whose entry hasn't been added yet.
@@ -90,27 +93,27 @@ public ValueTask SetAsync(string key, byte[] value, string[]? tags, TimeSpan val
if (!_taggedEntries.TryGetValue(tag, out var keys))
{
- keys = new HashSet();
+ keys = new HashSet();
_taggedEntries[tag] = keys;
}
Debug.Assert(keys != null);
- keys.Add(key);
+ keys.Add(new TaggedEntry(key, entryId));
}
- SetEntry(key, value, tags, validFor);
+ SetEntry(key, value, tags, validFor, entryId);
}
}
else
{
- SetEntry(key, value, tags, validFor);
+ SetEntry(key, value, tags, validFor, entryId);
}
return ValueTask.CompletedTask;
}
- void SetEntry(string key, byte[] value, string[]? tags, TimeSpan validFor)
+ private void SetEntry(string key, byte[] value, string[]? tags, TimeSpan validFor, Guid entryId)
{
Debug.Assert(key != null);
@@ -120,22 +123,25 @@ void SetEntry(string key, byte[] value, string[]? tags, TimeSpan validFor)
Size = value.Length
};
- if (tags != null && tags.Length > 0)
+ if (tags is { Length: > 0 })
{
// Remove cache keys from tag lists when the entry is evicted
- options.RegisterPostEvictionCallback(RemoveFromTags, tags);
+ options.RegisterPostEvictionCallback(RemoveFromTags, (tags, entryId));
}
_cache.Set(key, value, options);
}
- void RemoveFromTags(object key, object? value, EvictionReason reason, object? state)
+ private void RemoveFromTags(object key, object? value, EvictionReason reason, object? state)
{
- var tags = state as string[];
+ Debug.Assert(state != null);
+
+ var (tags, entryId) = ((string[] Tags, Guid EntryId))state;
Debug.Assert(tags != null);
Debug.Assert(tags.Length > 0);
Debug.Assert(key is string);
+ Debug.Assert(entryId != Guid.Empty);
lock (_tagsLock)
{
@@ -143,7 +149,7 @@ void RemoveFromTags(object key, object? value, EvictionReason reason, object? st
{
if (_taggedEntries.TryGetValue(tag, out var tagged))
{
- tagged.Remove((string)key);
+ tagged.Remove(new TaggedEntry((string)key, entryId));
// Remove the collection if there is no more keys in it
if (tagged.Count == 0)
@@ -154,4 +160,6 @@ void RemoveFromTags(object key, object? value, EvictionReason reason, object? st
}
}
}
+
+ private record TaggedEntry(string Key, Guid EntryId);
}
diff --git a/src/Middleware/OutputCaching/test/MemoryOutputCacheStoreTests.cs b/src/Middleware/OutputCaching/test/MemoryOutputCacheStoreTests.cs
index e8c809911add..c1ad1d708f4b 100644
--- a/src/Middleware/OutputCaching/test/MemoryOutputCacheStoreTests.cs
+++ b/src/Middleware/OutputCaching/test/MemoryOutputCacheStoreTests.cs
@@ -197,6 +197,43 @@ public async Task ExpiredEntries_AreRemovedFromTags()
Assert.Single(tag2s);
}
+ [Fact]
+ public async Task ReplacedEntries_AreNotRemovedFromTags()
+ {
+ var testClock = new TestMemoryOptionsClock { UtcNow = DateTimeOffset.UtcNow };
+ var cache = new MemoryCache(new MemoryCacheOptions { SizeLimit = 1000, Clock = testClock, ExpirationScanFrequency = TimeSpan.FromMilliseconds(1) });
+ var store = new MemoryOutputCacheStore(cache);
+ var value = "abc"u8.ToArray();
+
+ await store.SetAsync("a", value, new[] { "tag1", "tag2" }, TimeSpan.FromMilliseconds(5), default);
+ await store.SetAsync("a", value, new[] { "tag1" }, TimeSpan.FromMilliseconds(20), default);
+
+ testClock.Advance(TimeSpan.FromMilliseconds(10));
+
+ // Trigger background expiration by accessing the cache.
+ _ = cache.Get("a");
+
+ var resulta = await store.GetAsync("a", default);
+
+ Assert.NotNull(resulta);
+
+ HashSet tag1s, tag2s;
+
+ // Wait for the tag2 HashSet to be removed by the background expiration thread.
+
+ using var cts = new CancellationTokenSource(TimeSpan.FromSeconds(30));
+
+ while (store.TaggedEntries.TryGetValue("tag2", out tag2s) && !cts.IsCancellationRequested)
+ {
+ await Task.Yield();
+ }
+
+ store.TaggedEntries.TryGetValue("tag1", out tag1s);
+
+ Assert.Null(tag2s);
+ Assert.Single(tag1s);
+ }
+
[Theory]
[InlineData(null)]
public async Task Store_Throws_OnInvalidTag(string tag)
diff --git a/src/OpenApi/src/Schemas/OpenApiJsonSchema.Helpers.cs b/src/OpenApi/src/Schemas/OpenApiJsonSchema.Helpers.cs
index 830b0375d396..f05c595b5c2b 100644
--- a/src/OpenApi/src/Schemas/OpenApiJsonSchema.Helpers.cs
+++ b/src/OpenApi/src/Schemas/OpenApiJsonSchema.Helpers.cs
@@ -136,6 +136,8 @@ internal sealed partial class OpenApiJsonSchema
{
type = "array";
var array = new OpenApiArray();
+ // Read to process JsonTokenType.StartArray before advancing
+ reader.Read();
while (reader.TokenType != JsonTokenType.EndArray)
{
array.Add(ReadOpenApiAny(ref reader));
diff --git a/src/OpenApi/test/Microsoft.AspNetCore.OpenApi.Tests/Services/OpenApiSchemaService/OpenApiSchemaService.ParameterSchemas.cs b/src/OpenApi/test/Microsoft.AspNetCore.OpenApi.Tests/Services/OpenApiSchemaService/OpenApiSchemaService.ParameterSchemas.cs
index 1c7cb1ba5746..6f87374b1c92 100644
--- a/src/OpenApi/test/Microsoft.AspNetCore.OpenApi.Tests/Services/OpenApiSchemaService/OpenApiSchemaService.ParameterSchemas.cs
+++ b/src/OpenApi/test/Microsoft.AspNetCore.OpenApi.Tests/Services/OpenApiSchemaService/OpenApiSchemaService.ParameterSchemas.cs
@@ -722,4 +722,93 @@ public static bool TryParse(string value, out Student result)
return true;
}
}
+
+ // Regression test for https://github.com/dotnet/aspnetcore/issues/62023
+ // Testing that the array parsing in our OpenApiJsonSchema works
+ [Fact]
+ public async Task CustomConverterThatOutputsArrayWithDefaultValue()
+ {
+ // Arrange
+ var serviceCollection = new ServiceCollection();
+ serviceCollection.ConfigureHttpJsonOptions(options =>
+ {
+ options.SerializerOptions.Converters.Add(new EnumArrayTypeConverter());
+ });
+ var builder = CreateBuilder(serviceCollection);
+
+ // Act
+ builder.MapPost("/api", (EnumArrayType e = EnumArrayType.None) => { });
+
+ // Assert
+ await VerifyOpenApiDocument(builder, document =>
+ {
+ var operation = document.Paths["/api"].Operations[OperationType.Post];
+ var param = Assert.Single(operation.Parameters);
+ Assert.NotNull(param.Schema);
+ Assert.IsType(param.Schema.Default);
+ // Type is null, it's up to the user to configure this via a custom schema
+ // transformer for types with a converter.
+ Assert.Null(param.Schema.Type);
+ });
+ }
+
+ [Fact]
+ public async Task CustomConverterThatOutputsObjectWithDefaultValue()
+ {
+ // Arrange
+ var serviceCollection = new ServiceCollection();
+ serviceCollection.ConfigureHttpJsonOptions(options =>
+ {
+ options.SerializerOptions.Converters.Add(new EnumObjectTypeConverter());
+ });
+ var builder = CreateBuilder(serviceCollection);
+
+ // Act
+ builder.MapPost("/api", (EnumArrayType e = EnumArrayType.None) => { });
+
+ // Assert
+ await VerifyOpenApiDocument(builder, document =>
+ {
+ var operation = document.Paths["/api"].Operations[OperationType.Post];
+ var param = Assert.Single(operation.Parameters);
+ Assert.NotNull(param.Schema);
+ Assert.IsType(param.Schema.Default);
+ // Type is null, it's up to the user to configure this via a custom schema
+ // transformer for types with a converter.
+ Assert.Null(param.Schema.Type);
+ });
+ }
+
+ public enum EnumArrayType
+ {
+ None = 1
+ }
+
+ public class EnumArrayTypeConverter : JsonConverter
+ {
+ public override EnumArrayType Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
+ {
+ return new EnumArrayType();
+ }
+
+ public override void Write(Utf8JsonWriter writer, EnumArrayType value, JsonSerializerOptions options)
+ {
+ writer.WriteStartArray();
+ writer.WriteEndArray();
+ }
+ }
+
+ public class EnumObjectTypeConverter : JsonConverter
+ {
+ public override EnumArrayType Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
+ {
+ return new EnumArrayType();
+ }
+
+ public override void Write(Utf8JsonWriter writer, EnumArrayType value, JsonSerializerOptions options)
+ {
+ writer.WriteStartObject();
+ writer.WriteEndObject();
+ }
+ }
}
diff --git a/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.cpp b/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.cpp
index 9b12cd0132b4..8fb960261590 100644
--- a/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.cpp
+++ b/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.cpp
@@ -197,7 +197,7 @@ HostFxrResolver::TryGetHostFxrPath(
size_t size = MAX_PATH * 2;
hostfxrPath.resize(size);
- get_hostfxr_parameters params;
+ get_hostfxr_parameters params{};
params.size = sizeof(get_hostfxr_parameters);
params.assembly_path = applicationPath.c_str();
params.dotnet_root = dotnetRoot.c_str();
@@ -393,7 +393,7 @@ HostFxrResolver::GetAbsolutePathToDotnetFromHostfxr(const fs::path& hostfxrPath)
// Tries to call where.exe to find the location of dotnet.exe.
// Will check that the bitness of dotnet matches the current
// worker process bitness.
-// Returns true if a valid dotnet was found, else false.R
+// Returns true if a valid dotnet was found, else false.
//
std::optional
HostFxrResolver::InvokeWhereToFindDotnet()
@@ -415,8 +415,7 @@ HostFxrResolver::InvokeWhereToFindDotnet()
DWORD dwExitCode;
STRU struDotnetSubstring;
STRU struDotnetLocationsString;
- DWORD dwNumBytesRead;
- DWORD dwBinaryType;
+ DWORD dwNumBytesRead = 0;
INT index = 0;
INT prevIndex = 0;
std::optional result;
@@ -521,14 +520,7 @@ HostFxrResolver::InvokeWhereToFindDotnet()
LOG_INFOF(L"Processing entry '%ls'", struDotnetSubstring.QueryStr());
- if (LOG_LAST_ERROR_IF(!GetBinaryTypeW(struDotnetSubstring.QueryStr(), &dwBinaryType)))
- {
- continue;
- }
-
- LOG_INFOF(L"Binary type %d", dwBinaryType);
-
- if (fIsCurrentProcess64Bit == (dwBinaryType == SCS_64BIT_BINARY))
+ if (fIsCurrentProcess64Bit == IsX64(struDotnetSubstring.QueryStr()))
{
// The bitness of dotnet matched with the current worker process bitness.
return std::make_optional(struDotnetSubstring.QueryStr());
@@ -539,6 +531,62 @@ HostFxrResolver::InvokeWhereToFindDotnet()
return result;
}
+BOOL HostFxrResolver::IsX64(const WCHAR* dotnetPath)
+{
+ // Errors while reading from the file shouldn't throw unless
+ // file.exception(bits) is set
+ std::ifstream file(dotnetPath, std::ios::binary);
+ if (!file.is_open())
+ {
+ LOG_TRACEF(L"Failed to open file %ls", dotnetPath);
+ return false;
+ }
+
+ // Read the DOS header
+ IMAGE_DOS_HEADER dosHeader{};
+ file.read(reinterpret_cast(&dosHeader), sizeof(dosHeader));
+ if (dosHeader.e_magic != IMAGE_DOS_SIGNATURE) // 'MZ'
+ {
+ LOG_TRACEF(L"%ls is not a valid executable file (missing MZ header).", dotnetPath);
+ return false;
+ }
+
+ // Seek to the PE header
+ file.seekg(dosHeader.e_lfanew, std::ios::beg);
+
+ // Read the PE header
+ DWORD peSignature{};
+ file.read(reinterpret_cast(&peSignature), sizeof(peSignature));
+ if (peSignature != IMAGE_NT_SIGNATURE) // 'PE\0\0'
+ {
+ LOG_TRACEF(L"%ls is not a valid PE file (missing PE header).", dotnetPath);
+ return false;
+ }
+
+ // Read the file header
+ IMAGE_FILE_HEADER fileHeader{};
+ file.read(reinterpret_cast(&fileHeader), sizeof(fileHeader));
+
+ // Read the optional header magic field
+ WORD magic{};
+ file.read(reinterpret_cast(&magic), sizeof(magic));
+
+ // Determine the architecture based on the magic value
+ if (magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC)
+ {
+ LOG_INFOF(L"%ls is 32-bit", dotnetPath);
+ return false;
+ }
+ else if (magic == IMAGE_NT_OPTIONAL_HDR64_MAGIC)
+ {
+ LOG_INFOF(L"%ls is 64-bit", dotnetPath);
+ return true;
+ }
+
+ LOG_INFOF(L"%ls is unknown architecture %i", dotnetPath, fileHeader.Machine);
+ return false;
+}
+
std::optional
HostFxrResolver::GetAbsolutePathToDotnetFromProgramFiles()
{
diff --git a/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.h b/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.h
index 519f6df52c97..08ec650aec54 100644
--- a/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.h
+++ b/src/Servers/IIS/AspNetCoreModuleV2/CommonLib/HostFxrResolver.h
@@ -74,6 +74,8 @@ class HostFxrResolver
const std::filesystem::path & requestedPath
);
+ static BOOL IsX64(const WCHAR* dotnetPath);
+
struct LocalFreeDeleter
{
void operator ()(_In_ LPWSTR* ptr) const
diff --git a/src/Servers/IIS/build/Build.Lib.Settings b/src/Servers/IIS/build/Build.Lib.Settings
index 0dcba8c2011a..9327eb363771 100644
--- a/src/Servers/IIS/build/Build.Lib.Settings
+++ b/src/Servers/IIS/build/Build.Lib.Settings
@@ -9,7 +9,7 @@
- false
+ true
_LIB;%(PreprocessorDefinitions)
true
diff --git a/src/submodules/googletest b/src/submodules/googletest
index 52204f78f94d..e9092b12dc3c 160000
--- a/src/submodules/googletest
+++ b/src/submodules/googletest
@@ -1 +1 @@
-Subproject commit 52204f78f94d7512df1f0f3bea1d47437a2c3a58
+Subproject commit e9092b12dc3cf617d47578f13a1f64285cfa5b2f