Class: Dependabot::Python::FileUpdater::PyprojectPreparer
- Inherits:
-
Object
- Object
- Dependabot::Python::FileUpdater::PyprojectPreparer
- Defined in:
- lib/dependabot/python/file_updater/pyproject_preparer.rb
Instance Method Summary collapse
-
#freeze_top_level_dependencies_except(dependencies) ⇒ Object
rubocop:disable Metrics/PerceivedComplexity rubocop:disable Metrics/AbcSize.
-
#initialize(pyproject_content:, lockfile: nil) ⇒ PyprojectPreparer
constructor
A new instance of PyprojectPreparer.
- #replace_sources(credentials) ⇒ Object
- #sanitize ⇒ Object
Constructor Details
#initialize(pyproject_content:, lockfile: nil) ⇒ PyprojectPreparer
Returns a new instance of PyprojectPreparer.
16 17 18 19 |
# File 'lib/dependabot/python/file_updater/pyproject_preparer.rb', line 16 def initialize(pyproject_content:, lockfile: nil) @pyproject_content = pyproject_content @lockfile = lockfile end |
Instance Method Details
#freeze_top_level_dependencies_except(dependencies) ⇒ Object
rubocop:disable Metrics/PerceivedComplexity rubocop:disable Metrics/AbcSize
50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 |
# File 'lib/dependabot/python/file_updater/pyproject_preparer.rb', line 50 def freeze_top_level_dependencies_except(dependencies) return pyproject_content unless lockfile pyproject_object = TomlRB.parse(pyproject_content) poetry_object = pyproject_object["tool"]["poetry"] excluded_names = dependencies.map(&:name) + ["python"] Dependabot::Python::FileParser::PoetryFilesParser::POETRY_DEPENDENCY_TYPES.each do |key| next unless poetry_object[key] poetry_object.fetch(key).each do |dep_name, _| next if excluded_names.include?(normalise(dep_name)) locked_details = locked_details(dep_name) next unless (locked_version = locked_details&.fetch("version")) next if %w(directory file url).include?(locked_details&.dig("source", "type")) if locked_details&.dig("source", "type") == "git" poetry_object[key][dep_name] = { "git" => locked_details&.dig("source", "url"), "rev" => locked_details&.dig("source", "reference") } elsif poetry_object[key][dep_name].is_a?(Hash) poetry_object[key][dep_name]["version"] = locked_version else poetry_object[key][dep_name] = locked_version end end end TomlRB.dump(pyproject_object) end |
#replace_sources(credentials) ⇒ Object
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/dependabot/python/file_updater/pyproject_preparer.rb', line 21 def replace_sources(credentials) pyproject_object = TomlRB.parse(pyproject_content) poetry_object = pyproject_object.fetch("tool").fetch("poetry") sources_hash = pyproject_sources.map { |source| [source["url"], source] }.to_h config_variable_sources(credentials).each do |source| if sources_hash.key?(source["original_url"]) sources_hash[source["original_url"]]["url"] = source["url"] else source.delete("original_url") sources_hash[source["url"]] = source end end poetry_object["source"] = sources_hash.values unless sources_hash.empty? TomlRB.dump(pyproject_object) end |
#sanitize ⇒ Object
41 42 43 44 45 46 |
# File 'lib/dependabot/python/file_updater/pyproject_preparer.rb', line 41 def sanitize # {{ name }} syntax not allowed pyproject_content. gsub(/\{\{.*?\}\}/, "something"). gsub('#{', "{") end |