dependabot-nuget 0.274.0 → 0.276.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 8faf1e75a17d2bcd56f2396c6c0f9854b887e2bd1be7e89d3f869f5a2f923ce4
4
- data.tar.gz: ab89e33d64147019f89d0625c4325c2edcd6079ddadd3af418bd1c1e999b9976
3
+ metadata.gz: fbad6797ed312b229980246a81f96e7820b511542f77e10c9eae64a1d6410955
4
+ data.tar.gz: fd2d203b41a13ce9a5b5c9b9fe8054773bc1579efcb7a315a7721992d696bafb
5
5
  SHA512:
6
- metadata.gz: 70e59e0078a18db33554fae631c5b4a78593ce97457956ad4ccd827ff6e76be6ee2eb112ac7ad72b91d29d2300496cad82e24d3b27457ea9f2c26cb27d6c82b2
7
- data.tar.gz: 1768859035978b5f61b7d509a30de784273684e0949b6f7dccceda2d39321aa56796be6a4addce50d9aa011776ee02694691e60b9eedc409bd04adcede024e72
6
+ metadata.gz: 362f0baccef540bfbbd899bcf3ff2415fd8db0b73aa712ca96d1b2c6f6521a5f1a57cc64c37c423337f92bfcaba87c156f1a6c9d3a394a344c77e7394410b73b
7
+ data.tar.gz: 1f43136d55a7a4b2d5058ec80e71479e645de9ab4e9a37de4acab9808e2f5c09c577c18c39bb39cb6ba8ba9cf15b01df5e37ec1a30ccc50aba74227275138a7f
@@ -304,12 +304,12 @@ internal static class BindingRedirectManager
304
304
  {
305
305
  public bool Equals(AssemblyIdentity? x, AssemblyIdentity? y) =>
306
306
  string.Equals(x?.Name, y?.Name, StringComparison.OrdinalIgnoreCase) &&
307
- string.Equals(x?.PublicKeyToken, y?.PublicKeyToken, StringComparison.OrdinalIgnoreCase);
307
+ string.Equals(x?.PublicKeyToken ?? "null", y?.PublicKeyToken ?? "null", StringComparison.OrdinalIgnoreCase);
308
308
 
309
309
  public int GetHashCode(AssemblyIdentity obj) =>
310
310
  HashCode.Combine(
311
311
  obj.Name?.ToLowerInvariant(),
312
- obj.PublicKeyToken?.ToLowerInvariant()
312
+ obj.PublicKeyToken?.ToLowerInvariant() ?? "null"
313
313
  );
314
314
  }
315
315
  }
@@ -48,8 +48,8 @@ public static partial class BindingRedirectResolver
48
48
  return false;
49
49
  }
50
50
 
51
- dict.TryGetValue("PublicKeyToken", out var publicKeyToken);
52
- dict.TryGetValue("Culture", out var culture);
51
+ var publicKeyToken = dict.GetValueOrDefault("PublicKeyToken", "null");
52
+ var culture = dict.GetValueOrDefault("Culture", "neutral");
53
53
 
54
54
  assemblyInfo = new AssemblyWrapper(name, version, publicKeyToken, culture);
55
55
  return true;
@@ -63,7 +63,7 @@ public static partial class BindingRedirectResolver
63
63
  /// </summary>
64
64
  private class AssemblyWrapper : Runtime_IAssembly
65
65
  {
66
- public AssemblyWrapper(string name, Version version, string? publicKeyToken = null, string? culture = null)
66
+ public AssemblyWrapper(string name, Version version, string publicKeyToken, string culture)
67
67
  {
68
68
  Name = name;
69
69
  Version = version;
@@ -73,8 +73,8 @@ public static partial class BindingRedirectResolver
73
73
 
74
74
  public string Name { get; }
75
75
  public Version Version { get; }
76
- public string? PublicKeyToken { get; }
77
- public string? Culture { get; }
76
+ public string PublicKeyToken { get; }
77
+ public string Culture { get; }
78
78
  public IEnumerable<Runtime_IAssembly> ReferencedAssemblies { get; } = Enumerable.Empty<AssemblyWrapper>();
79
79
  }
80
80
 
@@ -1019,6 +1019,224 @@ public partial class UpdateWorkerTests
1019
1019
  );
1020
1020
  }
1021
1021
 
1022
+ [Fact]
1023
+ public async Task UpdateBindingRedirect_UnrelatedAssemblyReferenceWithMissingPublicKeyTokenAttribute()
1024
+ {
1025
+ await TestUpdateForProject("Some.Package", "7.0.1", "13.0.1",
1026
+ packages:
1027
+ [
1028
+ MockNuGetPackage.CreatePackageWithAssembly("Some.Package", "7.0.1", "net45", "7.0.0.0"),
1029
+ MockNuGetPackage.CreatePackageWithAssembly("Some.Package", "13.0.1", "net45", "13.0.0.0"),
1030
+ ],
1031
+ projectContents: """
1032
+ <Project ToolsVersion="15.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
1033
+ <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
1034
+ <PropertyGroup>
1035
+ <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
1036
+ </PropertyGroup>
1037
+ <ItemGroup>
1038
+ <None Include="packages.config" />
1039
+ </ItemGroup>
1040
+ <ItemGroup>
1041
+ <None Include="app.config" />
1042
+ </ItemGroup>
1043
+ <ItemGroup>
1044
+ <Reference Include="Some.Package, Version=7.0.0.0, Culture=neutral, PublicKeyToken=null">
1045
+ <HintPath>packages\Some.Package.7.0.1\lib\net45\Some.Package.dll</HintPath>
1046
+ <Private>True</Private>
1047
+ </Reference>
1048
+ <Reference Include="Some.Unrelated.Package, Version=1.0.0.0, Culture=neutral">
1049
+ <HintPath>packages\Some.Unrelated.Package.1.0.0\lib\net45\Some.Unrelated.Package.dll</HintPath>
1050
+ </Reference>
1051
+ </ItemGroup>
1052
+ <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
1053
+ </Project>
1054
+ """,
1055
+ packagesConfigContents: """
1056
+ <packages>
1057
+ <package id="Some.Package" version="7.0.1" targetFramework="net45" />
1058
+ </packages>
1059
+ """,
1060
+ additionalFiles:
1061
+ [
1062
+ ("app.config", """
1063
+ <configuration>
1064
+ <runtime>
1065
+ <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
1066
+ <dependentAssembly>
1067
+ <assemblyIdentity name="Some.Package" publicKeyToken="null" culture="neutral" />
1068
+ <bindingRedirect oldVersion="0.0.0.0-7.0.0.0" newVersion="7.0.0.0" />
1069
+ </dependentAssembly>
1070
+ <dependentAssembly>
1071
+ <assemblyIdentity name="Some.Unrelated.Package" culture="neutral" />
1072
+ <bindingRedirect oldVersion="0.0.0.0-1.0.0.0" newVersion="1.0.0.0" />
1073
+ </dependentAssembly>
1074
+ </assemblyBinding>
1075
+ </runtime>
1076
+ </configuration>
1077
+ """)
1078
+ ],
1079
+ expectedProjectContents: """
1080
+ <Project ToolsVersion="15.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
1081
+ <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
1082
+ <PropertyGroup>
1083
+ <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
1084
+ </PropertyGroup>
1085
+ <ItemGroup>
1086
+ <None Include="packages.config" />
1087
+ </ItemGroup>
1088
+ <ItemGroup>
1089
+ <None Include="app.config" />
1090
+ </ItemGroup>
1091
+ <ItemGroup>
1092
+ <Reference Include="Some.Package, Version=13.0.0.0, Culture=neutral, PublicKeyToken=null">
1093
+ <HintPath>packages\Some.Package.13.0.1\lib\net45\Some.Package.dll</HintPath>
1094
+ <Private>True</Private>
1095
+ </Reference>
1096
+ <Reference Include="Some.Unrelated.Package, Version=1.0.0.0, Culture=neutral">
1097
+ <HintPath>packages\Some.Unrelated.Package.1.0.0\lib\net45\Some.Unrelated.Package.dll</HintPath>
1098
+ </Reference>
1099
+ </ItemGroup>
1100
+ <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
1101
+ </Project>
1102
+ """,
1103
+ expectedPackagesConfigContents: """
1104
+ <?xml version="1.0" encoding="utf-8"?>
1105
+ <packages>
1106
+ <package id="Some.Package" version="13.0.1" targetFramework="net45" />
1107
+ </packages>
1108
+ """,
1109
+ additionalFilesExpected:
1110
+ [
1111
+ ("app.config", """
1112
+ <configuration>
1113
+ <runtime>
1114
+ <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
1115
+ <dependentAssembly>
1116
+ <assemblyIdentity name="Some.Package" publicKeyToken="null" culture="neutral" />
1117
+ <bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
1118
+ </dependentAssembly>
1119
+ <dependentAssembly>
1120
+ <assemblyIdentity name="Some.Unrelated.Package" culture="neutral" />
1121
+ <bindingRedirect oldVersion="0.0.0.0-1.0.0.0" newVersion="1.0.0.0" />
1122
+ </dependentAssembly>
1123
+ </assemblyBinding>
1124
+ </runtime>
1125
+ </configuration>
1126
+ """)
1127
+ ]
1128
+ );
1129
+ }
1130
+
1131
+ [Fact]
1132
+ public async Task UpdateBindingRedirect_UnrelatedAssemblyReferenceWithMissingCultureAttribute()
1133
+ {
1134
+ await TestUpdateForProject("Some.Package", "7.0.1", "13.0.1",
1135
+ packages:
1136
+ [
1137
+ MockNuGetPackage.CreatePackageWithAssembly("Some.Package", "7.0.1", "net45", "7.0.0.0"),
1138
+ MockNuGetPackage.CreatePackageWithAssembly("Some.Package", "13.0.1", "net45", "13.0.0.0"),
1139
+ ],
1140
+ projectContents: """
1141
+ <Project ToolsVersion="15.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
1142
+ <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
1143
+ <PropertyGroup>
1144
+ <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
1145
+ </PropertyGroup>
1146
+ <ItemGroup>
1147
+ <None Include="packages.config" />
1148
+ </ItemGroup>
1149
+ <ItemGroup>
1150
+ <None Include="app.config" />
1151
+ </ItemGroup>
1152
+ <ItemGroup>
1153
+ <Reference Include="Some.Package, Version=7.0.0.0, Culture=neutral, PublicKeyToken=null">
1154
+ <HintPath>packages\Some.Package.7.0.1\lib\net45\Some.Package.dll</HintPath>
1155
+ <Private>True</Private>
1156
+ </Reference>
1157
+ <Reference Include="Some.Unrelated.Package, Version=1.0.0.0, PublicKeyToken=null">
1158
+ <HintPath>packages\Some.Unrelated.Package.1.0.0\lib\net45\Some.Unrelated.Package.dll</HintPath>
1159
+ </Reference>
1160
+ </ItemGroup>
1161
+ <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
1162
+ </Project>
1163
+ """,
1164
+ packagesConfigContents: """
1165
+ <packages>
1166
+ <package id="Some.Package" version="7.0.1" targetFramework="net45" />
1167
+ </packages>
1168
+ """,
1169
+ additionalFiles:
1170
+ [
1171
+ ("app.config", """
1172
+ <configuration>
1173
+ <runtime>
1174
+ <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
1175
+ <dependentAssembly>
1176
+ <assemblyIdentity name="Some.Package" publicKeyToken="null" culture="neutral" />
1177
+ <bindingRedirect oldVersion="0.0.0.0-7.0.0.0" newVersion="7.0.0.0" />
1178
+ </dependentAssembly>
1179
+ <dependentAssembly>
1180
+ <assemblyIdentity name="Some.Unrelated.Package" publicKeyToken="null" />
1181
+ <bindingRedirect oldVersion="0.0.0.0-1.0.0.0" newVersion="1.0.0.0" />
1182
+ </dependentAssembly>
1183
+ </assemblyBinding>
1184
+ </runtime>
1185
+ </configuration>
1186
+ """)
1187
+ ],
1188
+ expectedProjectContents: """
1189
+ <Project ToolsVersion="15.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
1190
+ <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
1191
+ <PropertyGroup>
1192
+ <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
1193
+ </PropertyGroup>
1194
+ <ItemGroup>
1195
+ <None Include="packages.config" />
1196
+ </ItemGroup>
1197
+ <ItemGroup>
1198
+ <None Include="app.config" />
1199
+ </ItemGroup>
1200
+ <ItemGroup>
1201
+ <Reference Include="Some.Package, Version=13.0.0.0, Culture=neutral, PublicKeyToken=null">
1202
+ <HintPath>packages\Some.Package.13.0.1\lib\net45\Some.Package.dll</HintPath>
1203
+ <Private>True</Private>
1204
+ </Reference>
1205
+ <Reference Include="Some.Unrelated.Package, Version=1.0.0.0, PublicKeyToken=null">
1206
+ <HintPath>packages\Some.Unrelated.Package.1.0.0\lib\net45\Some.Unrelated.Package.dll</HintPath>
1207
+ </Reference>
1208
+ </ItemGroup>
1209
+ <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
1210
+ </Project>
1211
+ """,
1212
+ expectedPackagesConfigContents: """
1213
+ <?xml version="1.0" encoding="utf-8"?>
1214
+ <packages>
1215
+ <package id="Some.Package" version="13.0.1" targetFramework="net45" />
1216
+ </packages>
1217
+ """,
1218
+ additionalFilesExpected:
1219
+ [
1220
+ ("app.config", """
1221
+ <configuration>
1222
+ <runtime>
1223
+ <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
1224
+ <dependentAssembly>
1225
+ <assemblyIdentity name="Some.Package" publicKeyToken="null" culture="neutral" />
1226
+ <bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
1227
+ </dependentAssembly>
1228
+ <dependentAssembly>
1229
+ <assemblyIdentity name="Some.Unrelated.Package" publicKeyToken="null" />
1230
+ <bindingRedirect oldVersion="0.0.0.0-1.0.0.0" newVersion="1.0.0.0" />
1231
+ </dependentAssembly>
1232
+ </assemblyBinding>
1233
+ </runtime>
1234
+ </configuration>
1235
+ """)
1236
+ ]
1237
+ );
1238
+ }
1239
+
1022
1240
  [Fact]
1023
1241
  public async Task UpdateBindingRedirect_DuplicateRedirectsForTheSameAssemblyAreRemoved()
1024
1242
  {
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: dependabot-nuget
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.274.0
4
+ version: 0.276.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Dependabot
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-09-05 00:00:00.000000000 Z
11
+ date: 2024-09-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: dependabot-common
@@ -16,14 +16,14 @@ dependencies:
16
16
  requirements:
17
17
  - - '='
18
18
  - !ruby/object:Gem::Version
19
- version: 0.274.0
19
+ version: 0.276.0
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - '='
25
25
  - !ruby/object:Gem::Version
26
- version: 0.274.0
26
+ version: 0.276.0
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: rubyzip
29
29
  requirement: !ruby/object:Gem::Requirement
@@ -463,7 +463,7 @@ licenses:
463
463
  - MIT
464
464
  metadata:
465
465
  bug_tracker_uri: https://github.com/dependabot/dependabot-core/issues
466
- changelog_uri: https://github.com/dependabot/dependabot-core/releases/tag/v0.274.0
466
+ changelog_uri: https://github.com/dependabot/dependabot-core/releases/tag/v0.276.0
467
467
  post_install_message:
468
468
  rdoc_options: []
469
469
  require_paths: