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

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

Constant Summary collapse

VERSION_REGEX =
/[0-9]+(?:\.[A-Za-z0-9\-_]+)*/.freeze
SEPARATOR =
/(?<=[a-zA-Z0-9*])[\s|]+(?![\s|-])/.freeze
ALLOWED_UPDATE_STRATEGIES =
%i(widen_ranges bump_versions bump_versions_if_necessary).freeze

Instance Method Summary collapse

Constructor Details

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

Returns a new instance of RequirementsUpdater.



21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/dependabot/npm_and_yarn/update_checker/requirements_updater.rb', line 21

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 =
    version_class.new(latest_resolvable_version)
end

Instance Method Details

#updated_requirementsObject



35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# File 'lib/dependabot/npm_and_yarn/update_checker/requirements_updater.rb', line 35

def updated_requirements
  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 :widen_ranges then widen_requirement(req)
    when :bump_versions then update_version_requirement(req)
    when :bump_versions_if_necessary
      update_version_requirement_if_needed(req)
    else raise "Unexpected update strategy: #{update_strategy}"
    end
  end
end