From 974e60ee2c103b2bc5f10cccb525f65df0e0ddd8 Mon Sep 17 00:00:00 2001 From: Mitchell Chambers Date: Fri, 9 Jun 2023 12:19:06 +1000 Subject: [PATCH 1/5] add support for patchlevel_minor check in module version --- lib/onceover/controlrepo.rb | 35 +++++++++++++++++++++++++---------- 1 file changed, 25 insertions(+), 10 deletions(-) diff --git a/lib/onceover/controlrepo.rb b/lib/onceover/controlrepo.rb index 6f2b782..9247cae 100644 --- a/lib/onceover/controlrepo.rb +++ b/lib/onceover/controlrepo.rb @@ -241,17 +241,32 @@ def print_puppetfile_table row << mod.expected_version row << mod.v3_module.current_release.version - current = Versionomy.parse(mod.expected_version) - latest = Versionomy.parse(mod.v3_module.current_release.version) + # Configure a custom version format to support modern Puppet Forge versions. + # (major.minor.tiny-patchlevel-patchlevel_minor) + # e.g. 8.5.0-0-2 + puppet_format = Versionomy.default_format.modified_copy do + field(:patchlevel_minor) do + recognize_number(:default_value_optional => true, + :delimiter_regexp => '-', + :default_delimiter => '-') + end + end + + current = puppetforge_format.parse(mod.expected_version) + latest = puppetforge_format.parse(mod.v3_module.current_release.version) row << if current.major < latest.major - "Major".red - elsif current.minor < latest.minor - "Minor".yellow - elsif current.tiny < latest.tiny - "Tiny".green - else - "No".green - end + "Major".red + elsif current.minor < latest.minor + "Minor".yellow + elsif current.tiny < latest.tiny + "Tiny".green + elsif current.patchlevel < latest.patchlevel + "PatchLevel".green + elsif current.patchlevel_minor < latest.patchlevel_minor + "PatchLevel_minor".green + else + "No".green + end row << mod.v3_module.endorsement superseded_by = mod.v3_module.superseded_by From 66a22c12f3315b7a5d97d59a21d9ff28d1219d60 Mon Sep 17 00:00:00 2001 From: Mitchell Chambers Date: Fri, 9 Jun 2023 12:19:24 +1000 Subject: [PATCH 2/5] fix minor typo in description --- lib/onceover/cli/show.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/onceover/cli/show.rb b/lib/onceover/cli/show.rb index 49436c9..2c1b1e3 100644 --- a/lib/onceover/cli/show.rb +++ b/lib/onceover/cli/show.rb @@ -56,7 +56,7 @@ def self.command summary 'Shows the current state of the puppetfile' description <<-DESCRIPTION Shows the state of the puppetfile including current versions and -laetst versions of each module. Great for checking for updates. +latest versions of each module. Great for checking for updates. To update all modules run `onceover update puppetfile`. (Hint: once you have done the update, run the tests to make sure nothing breaks.) DESCRIPTION From 641fcd0acac991add511fd778c6b3d9599764ace Mon Sep 17 00:00:00 2001 From: Mitchell Chambers Date: Fri, 9 Jun 2023 13:45:28 +1000 Subject: [PATCH 3/5] Add protective code for error parsing with versionomy issue #324 --- lib/onceover/controlrepo.rb | 99 +++++++++++++++++++++---------------- 1 file changed, 56 insertions(+), 43 deletions(-) diff --git a/lib/onceover/controlrepo.rb b/lib/onceover/controlrepo.rb index 9247cae..8462851 100644 --- a/lib/onceover/controlrepo.rb +++ b/lib/onceover/controlrepo.rb @@ -232,61 +232,74 @@ def print_puppetfile_table output_array = [] threads = [] + error_array = [] puppetfile.modules.each do |mod| threads << Thread.new do - row = [] - logger.debug "Loading data for #{mod.full_name}" - row << mod.full_name - if mod.is_a?(R10K::Module::Forge) - row << mod.expected_version - row << mod.v3_module.current_release.version - - # Configure a custom version format to support modern Puppet Forge versions. - # (major.minor.tiny-patchlevel-patchlevel_minor) - # e.g. 8.5.0-0-2 - puppet_format = Versionomy.default_format.modified_copy do - field(:patchlevel_minor) do - recognize_number(:default_value_optional => true, - :delimiter_regexp => '-', - :default_delimiter => '-') + begin + row = [] + logger.debug "Loading data for #{mod.full_name}" + row << mod.full_name + if mod.is_a?(R10K::Module::Forge) + row << mod.expected_version + row << mod.v3_module.current_release.version + + # Configure a custom version format to support modern Puppet Forge versions. + # (major.minor.tiny-patchlevel-patchlevel_minor) + # e.g. 8.5.0-0-2 + puppetforge_format = Versionomy.default_format.modified_copy do + field(:patchlevel_minor) do + recognize_number(:default_value_optional => true, + :delimiter_regexp => '-', + :default_delimiter => '-') + end end - end - current = puppetforge_format.parse(mod.expected_version) - latest = puppetforge_format.parse(mod.v3_module.current_release.version) - row << if current.major < latest.major - "Major".red - elsif current.minor < latest.minor - "Minor".yellow - elsif current.tiny < latest.tiny - "Tiny".green - elsif current.patchlevel < latest.patchlevel - "PatchLevel".green - elsif current.patchlevel_minor < latest.patchlevel_minor - "PatchLevel_minor".green - else - "No".green - end - - row << mod.v3_module.endorsement - superseded_by = mod.v3_module.superseded_by - row << (superseded_by.nil? ? '' : superseded_by[:slug]) - else - row << "N/A" - row << "N/A" - row << "N/A" - row << "N/A" - row << "N/A" + current = puppetforge_format.parse(mod.expected_version) + latest = puppetforge_format.parse(mod.v3_module.current_release.version) + row << if current.major < latest.major + "Major".red + elsif current.minor < latest.minor + "Minor".yellow + elsif current.tiny < latest.tiny + "Tiny".green + elsif current.patchlevel < latest.patchlevel + "PatchLevel".green + elsif current.patchlevel_minor < latest.patchlevel_minor + "PatchLevel_minor".green + else + "No".green + end + + row << mod.v3_module.endorsement + superseded_by = mod.v3_module.superseded_by + row << (superseded_by.nil? ? '' : superseded_by[:slug]) + else + row << "N/A" + row << "N/A" + row << "N/A" + row << "N/A" + row << "N/A" + end + output_array << row + rescue => e + error = [] + error << mod.full_name + error << mod.expected_version + error << mod.v3_module.current_release.version + error << e.message + error_array << error + logger.debug "Error loading module #{mod.full_name} - #{e.inspect}" + end end - output_array << row end - end threads.map(&:join) output_array.sort_by! { |line| line[0] } + error_array.sort_by! { |line| line[0] } unless error_array.empty? puts Terminal::Table.new(headings: ["Full Name", "Current Version", "Latest Version", "Out of Date?", "Endorsement", "Superseded by"], rows: output_array) + puts Terminal::Table.new(headings: ["Issue assessing module", "Current", "Latest", "Error"], rows: error_array) unless error_array.empty? end def update_puppetfile From 66a133872828c7a31f89d1f0bf8edf248588a589 Mon Sep 17 00:00:00 2001 From: Mitchell Chambers Date: Fri, 9 Jun 2023 13:53:34 +1000 Subject: [PATCH 4/5] style - correct alignment --- lib/onceover/controlrepo.rb | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/onceover/controlrepo.rb b/lib/onceover/controlrepo.rb index 8462851..297e4ff 100644 --- a/lib/onceover/controlrepo.rb +++ b/lib/onceover/controlrepo.rb @@ -249,8 +249,8 @@ def print_puppetfile_table puppetforge_format = Versionomy.default_format.modified_copy do field(:patchlevel_minor) do recognize_number(:default_value_optional => true, - :delimiter_regexp => '-', - :default_delimiter => '-') + :delimiter_regexp => '-', + :default_delimiter => '-') end end From b3ea0cc56ba59d4077d64f9ba86a0b3be1452f48 Mon Sep 17 00:00:00 2001 From: Dylan Ratcliffe Date: Sat, 17 Jun 2023 14:30:34 +0000 Subject: [PATCH 5/5] Handle only RuntimeError --- lib/onceover/controlrepo.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/onceover/controlrepo.rb b/lib/onceover/controlrepo.rb index 297e4ff..5df7198 100644 --- a/lib/onceover/controlrepo.rb +++ b/lib/onceover/controlrepo.rb @@ -281,7 +281,7 @@ def print_puppetfile_table row << "N/A" end output_array << row - rescue => e + rescue RuntimeError => e error = [] error << mod.full_name error << mod.expected_version