Class: Dependabot::NpmAndYarn::UpdateChecker::SubdependencyVersionResolver

Inherits:
Object
  • Object
show all
Defined in:
lib/dependabot/npm_and_yarn/update_checker/subdependency_version_resolver.rb

Instance Method Summary collapse

Constructor Details

#initialize(dependency:, credentials:, dependency_files:, ignored_versions:, latest_allowable_version:) ⇒ SubdependencyVersionResolver

Returns a new instance of SubdependencyVersionResolver.



19
20
21
22
23
24
25
26
# File 'lib/dependabot/npm_and_yarn/update_checker/subdependency_version_resolver.rb', line 19

def initialize(dependency:, credentials:, dependency_files:,
               ignored_versions:, latest_allowable_version:)
  @dependency = dependency
  @credentials = credentials
  @dependency_files = dependency_files
  @ignored_versions = ignored_versions
  @latest_allowable_version = latest_allowable_version
end

Instance Method Details

#latest_resolvable_versionObject



28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# File 'lib/dependabot/npm_and_yarn/update_checker/subdependency_version_resolver.rb', line 28

def latest_resolvable_version
  raise "Not a subdependency!" if dependency.requirements.any?
  return if bundled_dependency?

  SharedHelpers.in_a_temporary_directory do
    dependency_files_builder.write_temporary_dependency_files

    updated_lockfiles = filtered_lockfiles.map do |lockfile|
      updated_content = update_subdependency_in_lockfile(lockfile)
      updated_lockfile = lockfile.dup
      updated_lockfile.content = updated_content
      updated_lockfile
    end

    version_from_updated_lockfiles(updated_lockfiles)
  end
rescue SharedHelpers::HelperSubprocessFailed
  # TODO: Move error handling logic from the FileUpdater to this class

  # Return nil (no update possible) if an unknown error occurred
  nil
end