Class: Dependabot::NpmAndYarn::UpdateChecker::RequirementsUpdater

Inherits:
Object
  • Object
show all
Extended by:
T::Sig
Defined in:
lib/dependabot/npm_and_yarn/update_checker/requirements_updater.rb

Constant Summary collapse

VERSION_REGEX =
/[0-9]+(?:\.[A-Za-z0-9\-_]+)*/
SEPARATOR =
/(?<=[a-zA-Z0-9*])[\s|]+(?![\s|-])/
ALLOWED_UPDATE_STRATEGIES =
T.let(
  [
    RequirementsUpdateStrategy::LockfileOnly,
    RequirementsUpdateStrategy::WidenRanges,
    RequirementsUpdateStrategy::BumpVersions,
    RequirementsUpdateStrategy::BumpVersionsIfNecessary
  ].freeze,
  T::Array[Dependabot::RequirementsUpdateStrategy]
)

Instance Method Summary collapse

Constructor Details

#initialize(requirements:, updated_source:, update_strategy:, latest_resolvable_version:) ⇒ RequirementsUpdater



43
44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'lib/dependabot/npm_and_yarn/update_checker/requirements_updater.rb', line 43

def initialize(requirements:, updated_source:, update_strategy:, latest_resolvable_version:)
  @requirements = requirements
  @updated_source = updated_source
  @update_strategy = update_strategy

  check_update_strategy

  return unless latest_resolvable_version

  @latest_resolvable_version = T.let(
    version_class.new(latest_resolvable_version),
    NpmAndYarn::Version
  )
end

Instance Method Details

#updated_requirementsObject



59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# File 'lib/dependabot/npm_and_yarn/update_checker/requirements_updater.rb', line 59

def updated_requirements
  return requirements if update_strategy.lockfile_only?

  requirements.map do |req|
    req = req.merge(source: updated_source)
    next req unless latest_resolvable_version
    next initial_req_after_source_change(req) unless req[:requirement]
    next req if req[:requirement].match?(/^([A-Za-uw-z]|v[^\d])/)

    case update_strategy
    when RequirementsUpdateStrategy::WidenRanges then widen_requirement(req)
    when RequirementsUpdateStrategy::BumpVersions then update_version_requirement(req)
    when RequirementsUpdateStrategy::BumpVersionsIfNecessary
      update_version_requirement_if_needed(req)
    else raise "Unexpected update strategy: #{update_strategy}"
    end
  end
end