dependabot-nuget 0.242.1 → 0.244.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (60) hide show
  1. checksums.yaml +4 -4
  2. data/helpers/lib/NuGetUpdater/.editorconfig +37 -28
  3. data/helpers/lib/NuGetUpdater/.gitignore +1 -0
  4. data/helpers/lib/NuGetUpdater/NuGetProjects/NuGet.CommandLine/AssemblyMetadataExtractor.cs +2 -1
  5. data/helpers/lib/NuGetUpdater/NuGetUpdater.Cli/Program.cs +2 -2
  6. data/helpers/lib/NuGetUpdater/NuGetUpdater.Cli.Test/EntryPointTests.Update.cs +178 -176
  7. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Files/JsonBuildFile.cs +2 -1
  8. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Files/PackagesConfigBuildFile.cs +1 -0
  9. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Files/ProjectBuildFile.cs +5 -4
  10. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/FrameworkChecker/CompatabilityChecker.cs +1 -0
  11. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/FrameworkChecker/FrameworkCompatibilityService.cs +10 -5
  12. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/FrameworkChecker/SupportedFrameworks.cs +16 -12
  13. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/BindingRedirectManager.cs +18 -17
  14. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/BindingRedirectResolver.cs +7 -7
  15. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/DotNetToolsJsonUpdater.cs +13 -20
  16. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/GlobalJsonUpdater.cs +9 -3
  17. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/PackagesConfigUpdater.cs +32 -16
  18. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/SdkPackageUpdater.cs +44 -24
  19. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/UpdaterWorker.cs +32 -13
  20. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/WebApplicationTargetsConditionPatcher.cs +47 -0
  21. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/XmlFilePreAndPostProcessor.cs +55 -0
  22. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/JsonHelper.cs +12 -9
  23. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/MSBuildHelper.cs +78 -54
  24. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/PathHelper.cs +16 -3
  25. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/ProcessExtensions.cs +6 -6
  26. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/XmlExtensions.cs +11 -0
  27. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Files/ProjectBuildFileTests.cs +18 -9
  28. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/FrameworkChecker/CompatibilityCheckerFacts.cs +2 -2
  29. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/FrameworkChecker/FrameworkCompatibilityServiceFacts.cs +7 -7
  30. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/FrameworkChecker/SupportedFrameworkFacts.cs +1 -1
  31. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/PackagesConfigUpdaterTests.cs +9 -9
  32. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/UpdateWorker.DirsProj.cs +228 -75
  33. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/UpdateWorkerTestBase.cs +22 -9
  34. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/UpdateWorkerTests.DotNetTools.cs +140 -104
  35. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/UpdateWorkerTests.GlobalJson.cs +25 -25
  36. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/UpdateWorkerTests.Mixed.cs +8 -9
  37. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/UpdateWorkerTests.PackagesConfig.cs +198 -22
  38. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Update/UpdateWorkerTests.Sdk.cs +401 -399
  39. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Utilities/JsonHelperTests.cs +17 -15
  40. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Utilities/MSBuildHelperTests.cs +114 -45
  41. data/helpers/lib/NuGetUpdater/NuGetUpdater.Core.Test/Utilities/SdkPackageUpdaterTests.cs +103 -87
  42. data/lib/dependabot/nuget/file_parser/project_file_parser.rb +109 -39
  43. data/lib/dependabot/nuget/file_parser.rb +23 -4
  44. data/lib/dependabot/nuget/file_updater.rb +44 -7
  45. data/lib/dependabot/nuget/native_helpers.rb +27 -8
  46. data/lib/dependabot/nuget/nuget_client.rb +66 -23
  47. data/lib/dependabot/nuget/nuget_config_credential_helpers.rb +7 -3
  48. data/lib/dependabot/nuget/update_checker/compatibility_checker.rb +63 -59
  49. data/lib/dependabot/nuget/update_checker/dependency_finder.rb +7 -5
  50. data/lib/dependabot/nuget/update_checker/nupkg_fetcher.rb +1 -1
  51. data/lib/dependabot/nuget/update_checker/nuspec_fetcher.rb +22 -17
  52. data/lib/dependabot/nuget/update_checker/property_updater.rb +7 -4
  53. data/lib/dependabot/nuget/update_checker/repository_finder.rb +292 -270
  54. data/lib/dependabot/nuget/update_checker/tfm_comparer.rb +11 -13
  55. data/lib/dependabot/nuget/update_checker/tfm_finder.rb +82 -82
  56. data/lib/dependabot/nuget/update_checker/version_finder.rb +9 -5
  57. data/lib/dependabot/nuget/update_checker.rb +6 -3
  58. data/lib/dependabot/nuget/version.rb +18 -7
  59. data/lib/dependabot/nuget.rb +0 -2
  60. metadata +7 -5
@@ -9,22 +9,20 @@ require "dependabot/shared_helpers"
9
9
 
10
10
  module Dependabot
11
11
  module Nuget
12
- class UpdateChecker < Dependabot::UpdateCheckers::Base
13
- class TfmComparer
14
- def self.are_frameworks_compatible?(project_tfms, package_tfms)
15
- return false if package_tfms.empty?
16
- return false if project_tfms.empty?
12
+ class TfmComparer
13
+ def self.are_frameworks_compatible?(project_tfms, package_tfms)
14
+ return false if package_tfms.empty?
15
+ return false if project_tfms.empty?
17
16
 
18
- key = "project_ftms:#{project_tfms.sort.join(',')}:package_tfms:#{package_tfms.sort.join(',')}".downcase
17
+ key = "project_ftms:#{project_tfms.sort.join(',')}:package_tfms:#{package_tfms.sort.join(',')}".downcase
19
18
 
20
- @cached_framework_check ||= {}
21
- unless @cached_framework_check.key?(key)
22
- @cached_framework_check[key] =
23
- NativeHelpers.run_nuget_framework_check(project_tfms,
24
- package_tfms)
25
- end
26
- @cached_framework_check[key]
19
+ @cached_framework_check ||= {}
20
+ unless @cached_framework_check.key?(key)
21
+ @cached_framework_check[key] =
22
+ NativeHelpers.run_nuget_framework_check(project_tfms,
23
+ package_tfms)
27
24
  end
25
+ @cached_framework_check[key]
28
26
  end
29
27
  end
30
28
  end
@@ -12,115 +12,115 @@ require "dependabot/shared_helpers"
12
12
 
13
13
  module Dependabot
14
14
  module Nuget
15
- class UpdateChecker < Dependabot::UpdateCheckers::Base
16
- class TfmFinder
17
- require "dependabot/nuget/file_parser/packages_config_parser"
18
- require "dependabot/nuget/file_parser/project_file_parser"
19
-
20
- def initialize(dependency_files:, credentials:)
21
- @dependency_files = dependency_files
22
- @credentials = credentials
23
- end
15
+ class TfmFinder
16
+ require "dependabot/nuget/file_parser/packages_config_parser"
17
+ require "dependabot/nuget/file_parser/project_file_parser"
18
+
19
+ def initialize(dependency_files:, credentials:, repo_contents_path:)
20
+ @dependency_files = dependency_files
21
+ @credentials = credentials
22
+ @repo_contents_path = repo_contents_path
23
+ end
24
24
 
25
- def frameworks(dependency)
26
- tfms = Set.new
27
- tfms += project_file_tfms(dependency)
28
- tfms += project_import_file_tfms
29
- tfms.to_a
30
- end
25
+ def frameworks(dependency)
26
+ tfms = Set.new
27
+ tfms += project_file_tfms(dependency)
28
+ tfms += project_import_file_tfms
29
+ tfms.to_a
30
+ end
31
31
 
32
- private
32
+ private
33
33
 
34
- attr_reader :dependency_files, :credentials
34
+ attr_reader :dependency_files, :credentials, :repo_contents_path
35
35
 
36
- def project_file_tfms(dependency)
37
- project_files_with_dependency(dependency).flat_map do |file|
38
- project_file_parser.target_frameworks(project_file: file)
39
- end
36
+ def project_file_tfms(dependency)
37
+ project_files_with_dependency(dependency).flat_map do |file|
38
+ project_file_parser.target_frameworks(project_file: file)
40
39
  end
40
+ end
41
41
 
42
- def project_files_with_dependency(dependency)
43
- project_files.select do |file|
44
- packages_config_contains_dependency?(file, dependency) ||
45
- project_file_contains_dependency?(file, dependency)
46
- end
42
+ def project_files_with_dependency(dependency)
43
+ project_files.select do |file|
44
+ packages_config_contains_dependency?(file, dependency) ||
45
+ project_file_contains_dependency?(file, dependency)
47
46
  end
47
+ end
48
48
 
49
- def packages_config_contains_dependency?(file, dependency)
50
- config_file = find_packages_config_file(file)
51
- return false unless config_file
49
+ def packages_config_contains_dependency?(file, dependency)
50
+ config_file = find_packages_config_file(file)
51
+ return false unless config_file
52
52
 
53
- config_parser = FileParser::PackagesConfigParser.new(packages_config: config_file)
54
- config_parser.dependency_set.dependencies.any? do |d|
55
- d.name.casecmp(dependency.name).zero?
56
- end
53
+ config_parser = FileParser::PackagesConfigParser.new(packages_config: config_file)
54
+ config_parser.dependency_set.dependencies.any? do |d|
55
+ d.name.casecmp(dependency.name).zero?
57
56
  end
57
+ end
58
58
 
59
- def project_file_contains_dependency?(file, dependency)
60
- project_file_parser.dependency_set(project_file: file).dependencies.any? do |d|
61
- d.name.casecmp(dependency.name).zero?
62
- end
59
+ def project_file_contains_dependency?(file, dependency)
60
+ project_file_parser.dependency_set(project_file: file).dependencies.any? do |d|
61
+ d.name.casecmp(dependency.name).zero?
63
62
  end
63
+ end
64
64
 
65
- def find_packages_config_file(file)
66
- return file if file.name.end_with?("packages.config")
65
+ def find_packages_config_file(file)
66
+ return file if file.name.end_with?("packages.config")
67
67
 
68
- filename = File.basename(file.name)
69
- search_path = file.name.sub(filename, "packages.config")
68
+ filename = File.basename(file.name)
69
+ search_path = file.name.sub(filename, "packages.config")
70
70
 
71
- dependency_files.find { |f| f.name.casecmp(search_path).zero? }
72
- end
71
+ dependency_files.find { |f| f.name.casecmp(search_path).zero? }
72
+ end
73
73
 
74
- def project_import_file_tfms
75
- @project_import_file_tfms ||= project_import_files.flat_map do |file|
76
- project_file_parser.target_frameworks(project_file: file)
77
- end
74
+ def project_import_file_tfms
75
+ @project_import_file_tfms ||= project_import_files.flat_map do |file|
76
+ project_file_parser.target_frameworks(project_file: file)
78
77
  end
78
+ end
79
79
 
80
- def project_file_parser
81
- @project_file_parser ||=
82
- FileParser::ProjectFileParser.new(
83
- dependency_files: dependency_files,
84
- credentials: credentials
85
- )
86
- end
80
+ def project_file_parser
81
+ @project_file_parser ||=
82
+ FileParser::ProjectFileParser.new(
83
+ dependency_files: dependency_files,
84
+ credentials: credentials,
85
+ repo_contents_path: repo_contents_path
86
+ )
87
+ end
87
88
 
88
- def project_files
89
- projfile = /\.[a-z]{2}proj$/
90
- packageprops = /[Dd]irectory.[Pp]ackages.props/
89
+ def project_files
90
+ projfile = /\.[a-z]{2}proj$/
91
+ packageprops = /[Dd]irectory.[Pp]ackages.props/
91
92
 
92
- dependency_files.select do |df|
93
- df.name.match?(projfile) ||
94
- df.name.match?(packageprops)
95
- end
93
+ dependency_files.select do |df|
94
+ df.name.match?(projfile) ||
95
+ df.name.match?(packageprops)
96
96
  end
97
+ end
97
98
 
98
- def packages_config_files
99
- dependency_files.select do |f|
100
- f.name.split("/").last.casecmp("packages.config").zero?
101
- end
99
+ def packages_config_files
100
+ dependency_files.select do |f|
101
+ f.name.split("/").last.casecmp("packages.config").zero?
102
102
  end
103
+ end
103
104
 
104
- def project_import_files
105
- dependency_files -
106
- project_files -
107
- packages_config_files -
108
- nuget_configs -
109
- [global_json] -
110
- [dotnet_tools_json]
111
- end
105
+ def project_import_files
106
+ dependency_files -
107
+ project_files -
108
+ packages_config_files -
109
+ nuget_configs -
110
+ [global_json] -
111
+ [dotnet_tools_json]
112
+ end
112
113
 
113
- def nuget_configs
114
- dependency_files.select { |f| f.name.match?(/nuget\.config$/i) }
115
- end
114
+ def nuget_configs
115
+ dependency_files.select { |f| f.name.match?(/nuget\.config$/i) }
116
+ end
116
117
 
117
- def global_json
118
- dependency_files.find { |f| f.name.casecmp("global.json").zero? }
119
- end
118
+ def global_json
119
+ dependency_files.find { |f| f.name.casecmp("global.json").zero? }
120
+ end
120
121
 
121
- def dotnet_tools_json
122
- dependency_files.find { |f| f.name.casecmp(".config/dotnet-tools.json").zero? }
123
- end
122
+ def dotnet_tools_json
123
+ dependency_files.find { |f| f.name.casecmp(".config/dotnet-tools.json").zero? }
124
124
  end
125
125
  end
126
126
  end
@@ -18,13 +18,15 @@ module Dependabot
18
18
 
19
19
  def initialize(dependency:, dependency_files:, credentials:,
20
20
  ignored_versions:, raise_on_ignored: false,
21
- security_advisories:)
21
+ security_advisories:,
22
+ repo_contents_path:)
22
23
  @dependency = dependency
23
24
  @dependency_files = dependency_files
24
25
  @credentials = credentials
25
26
  @ignored_versions = ignored_versions
26
27
  @raise_on_ignored = raise_on_ignored
27
28
  @security_advisories = security_advisories
29
+ @repo_contents_path = repo_contents_path
28
30
  end
29
31
 
30
32
  def latest_version_details
@@ -58,7 +60,7 @@ module Dependabot
58
60
  end
59
61
 
60
62
  attr_reader :dependency, :dependency_files, :credentials,
61
- :ignored_versions, :security_advisories
63
+ :ignored_versions, :security_advisories, :repo_contents_path
62
64
 
63
65
  private
64
66
 
@@ -81,9 +83,10 @@ module Dependabot
81
83
  # If the current package version is incompatible, then we don't enforce compatibility.
82
84
  # It could appear incompatible because they are ignoring NU1701 or the package is poorly authored.
83
85
  return first_version unless version_compatible?(dependency.version)
84
- return first_version if version_compatible?(first_version.fetch(:version))
85
86
 
86
- sorted_versions.bsearch { |v| version_compatible?(v.fetch(:version)) }
87
+ # once sorted by version, the best we can do is search every package, because it's entirely possible for there
88
+ # to be incompatible packages both with a higher and lower version number, so no smart searching can be done.
89
+ sorted_versions.find { |v| version_compatible?(v.fetch(:version)) }
87
90
  end
88
91
 
89
92
  def version_compatible?(version)
@@ -100,7 +103,8 @@ module Dependabot
100
103
  dependency: dependency,
101
104
  tfm_finder: TfmFinder.new(
102
105
  dependency_files: dependency_files,
103
- credentials: credentials
106
+ credentials: credentials,
107
+ repo_contents_path: repo_contents_path
104
108
  )
105
109
  )
106
110
  end
@@ -107,7 +107,8 @@ module Dependabot
107
107
  updated_dependencies += DependencyFinder.new(
108
108
  dependency: updated_dependency,
109
109
  dependency_files: dependency_files,
110
- credentials: credentials
110
+ credentials: credentials,
111
+ repo_contents_path: @repo_contents_path
111
112
  ).updated_peer_dependencies
112
113
  updated_dependencies
113
114
  end
@@ -135,7 +136,8 @@ module Dependabot
135
136
  credentials: credentials,
136
137
  ignored_versions: ignored_versions,
137
138
  raise_on_ignored: @raise_on_ignored,
138
- security_advisories: security_advisories
139
+ security_advisories: security_advisories,
140
+ repo_contents_path: @repo_contents_path
139
141
  )
140
142
  end
141
143
 
@@ -147,7 +149,8 @@ module Dependabot
147
149
  target_version_details: latest_version_details,
148
150
  credentials: credentials,
149
151
  ignored_versions: ignored_versions,
150
- raise_on_ignored: @raise_on_ignored
152
+ raise_on_ignored: @raise_on_ignored,
153
+ repo_contents_path: @repo_contents_path
151
154
  )
152
155
  end
153
156
 
@@ -1,8 +1,9 @@
1
- # typed: true
1
+ # typed: strong
2
2
  # frozen_string_literal: true
3
3
 
4
4
  require "dependabot/version"
5
5
  require "dependabot/utils"
6
+ require "sorbet-runtime"
6
7
 
7
8
  # Dotnet pre-release versions use 1.0.1-rc1 syntax, which Gem::Version
8
9
  # converts into 1.0.1.pre.rc1. We override the `to_s` method to stop that
@@ -11,30 +12,37 @@ require "dependabot/utils"
11
12
  module Dependabot
12
13
  module Nuget
13
14
  class Version < Dependabot::Version
14
- VERSION_PATTERN = Gem::Version::VERSION_PATTERN + '(\+[0-9a-zA-Z\-.]+)?'
15
+ extend T::Sig
16
+
17
+ VERSION_PATTERN = T.let(Gem::Version::VERSION_PATTERN + '(\+[0-9a-zA-Z\-.]+)?', String)
15
18
  ANCHORED_VERSION_PATTERN = /\A\s*(#{VERSION_PATTERN})?\s*\z/
16
19
 
20
+ sig { override.params(version: T.nilable(T.any(String, Integer, Float, Gem::Version))).returns(T::Boolean) }
17
21
  def self.correct?(version)
18
22
  return false if version.nil?
19
23
 
20
24
  version.to_s.match?(ANCHORED_VERSION_PATTERN)
21
25
  end
22
26
 
27
+ sig { override.params(version: T.nilable(T.any(String, Integer, Float, Gem::Version))).void }
23
28
  def initialize(version)
24
29
  version = version.to_s.split("+").first || ""
25
- @version_string = version
30
+ @version_string = T.let(version, String)
26
31
 
27
32
  super
28
33
  end
29
34
 
35
+ sig { returns(String) }
30
36
  def to_s
31
37
  @version_string
32
38
  end
33
39
 
40
+ sig { returns(String) }
34
41
  def inspect # :nodoc:
35
42
  "#<#{self.class} #{@version_string}>"
36
43
  end
37
44
 
45
+ sig { params(other: Object).returns(Integer) }
38
46
  def <=>(other)
39
47
  version_comparison = compare_release(other)
40
48
  return version_comparison unless version_comparison.zero?
@@ -42,14 +50,16 @@ module Dependabot
42
50
  compare_prerelease_part(other)
43
51
  end
44
52
 
53
+ sig { params(other: Object).returns(Integer) }
45
54
  def compare_release(other)
46
55
  release_str = @version_string.split("-").first || ""
47
56
  other_release_str = other.to_s.split("-").first || ""
48
57
 
49
- Gem::Version.new(release_str) <=> Gem::Version.new(other_release_str)
58
+ T.must(Gem::Version.new(release_str) <=> Gem::Version.new(other_release_str))
50
59
  end
51
60
 
52
61
  # rubocop:disable Metrics/PerceivedComplexity
62
+ sig { params(other: Object).returns(Integer) }
53
63
  def compare_prerelease_part(other)
54
64
  release_str = @version_string.split("-").first || ""
55
65
  prerelease_string = @version_string
@@ -67,8 +77,8 @@ module Dependabot
67
77
  return 1 if !prerelease_string && other_prerelease_string
68
78
  return 0 if !prerelease_string && !other_prerelease_string
69
79
 
70
- split_prerelease_string = prerelease_string.split(".")
71
- other_split_prerelease_string = other_prerelease_string.split(".")
80
+ split_prerelease_string = T.must(prerelease_string).split(".")
81
+ other_split_prerelease_string = T.must(other_prerelease_string).split(".")
72
82
 
73
83
  length = [split_prerelease_string.length, other_split_prerelease_string.length].max - 1
74
84
  (0..length).to_a.each do |index|
@@ -82,13 +92,14 @@ module Dependabot
82
92
  end
83
93
  # rubocop:enable Metrics/PerceivedComplexity
84
94
 
95
+ sig { params(lhs: T.nilable(String), rhs: T.nilable(String)).returns(Integer) }
85
96
  def compare_dot_separated_part(lhs, rhs)
86
97
  return -1 if lhs.nil?
87
98
  return 1 if rhs.nil?
88
99
 
89
100
  return lhs.to_i <=> rhs.to_i if lhs.match?(/^\d+$/) && rhs.match?(/^\d+$/)
90
101
 
91
- lhs.upcase <=> rhs.upcase
102
+ T.must(lhs.upcase <=> rhs.upcase)
92
103
  end
93
104
  end
94
105
  end
@@ -24,5 +24,3 @@ Dependabot::Dependency.register_production_check(
24
24
  groups.include?("dependencies")
25
25
  end
26
26
  )
27
-
28
- Dependabot::Utils.register_always_clone("nuget")
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.242.1
4
+ version: 0.244.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-01-23 00:00:00.000000000 Z
11
+ date: 2024-02-15 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.242.1
19
+ version: 0.244.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.242.1
26
+ version: 0.244.0
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: rubyzip
29
29
  requirement: !ruby/object:Gem::Requirement
@@ -325,6 +325,8 @@ files:
325
325
  - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/SdkPackageUpdater.cs
326
326
  - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/UpdateResult.cs
327
327
  - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/UpdaterWorker.cs
328
+ - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/WebApplicationTargetsConditionPatcher.cs
329
+ - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Updater/XmlFilePreAndPostProcessor.cs
328
330
  - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/JsonHelper.cs
329
331
  - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/Logger.cs
330
332
  - helpers/lib/NuGetUpdater/NuGetUpdater.Core/Utilities/MSBuildHelper.cs
@@ -369,7 +371,7 @@ licenses:
369
371
  - Nonstandard
370
372
  metadata:
371
373
  bug_tracker_uri: https://github.com/dependabot/dependabot-core/issues
372
- changelog_uri: https://github.com/dependabot/dependabot-core/releases/tag/v0.242.1
374
+ changelog_uri: https://github.com/dependabot/dependabot-core/releases/tag/v0.244.0
373
375
  post_install_message:
374
376
  rdoc_options: []
375
377
  require_paths: