From 3570c762fdd05ae86e3d80de539c1b3c0b41ce27 Mon Sep 17 00:00:00 2001 From: Greg Langlois Date: Thu, 17 Aug 2023 15:34:58 -0500 Subject: [PATCH] Drop stderr from mkconfig output when updating grub (#84) * Drop stderr from mkconfig output * Fix references to mkconfig_path class method --- lib/puppet/provider/grub_config/grub2.rb | 7 ++++++- lib/puppet/provider/grub_menuentry/grub2.rb | 7 ++++++- lib/puppet/provider/grub_user/grub2.rb | 6 +++++- lib/puppet/provider/kernel_parameter/grub2.rb | 7 ++++++- 4 files changed, 23 insertions(+), 4 deletions(-) diff --git a/lib/puppet/provider/grub_config/grub2.rb b/lib/puppet/provider/grub_config/grub2.rb index 429a618..6ae30c8 100644 --- a/lib/puppet/provider/grub_config/grub2.rb +++ b/lib/puppet/provider/grub_config/grub2.rb @@ -20,7 +20,12 @@ def self.mkconfig_path end confine feature: :augeas - commands mkconfig: mkconfig_path + + confine exists: mkconfig_path, for_binary: true + + def mkconfig + execute(self.class.mkconfig_path, { failonfail: true, combine: false }) + end defaultfor osfamily: :RedHat diff --git a/lib/puppet/provider/grub_menuentry/grub2.rb b/lib/puppet/provider/grub_menuentry/grub2.rb index 0b2080f..a9797a6 100644 --- a/lib/puppet/provider/grub_menuentry/grub2.rb +++ b/lib/puppet/provider/grub_menuentry/grub2.rb @@ -250,7 +250,12 @@ def self.prefetch(resources) #### End Class Methods - commands mkconfig: mkconfig_path + confine exists: mkconfig_path, for_binary: true + + def mkconfig + execute(self.class.mkconfig_path, { failonfail: true, combine: false }) + end + commands grubby: 'grubby' commands grub_set_default: 'grub2-set-default' diff --git a/lib/puppet/provider/grub_user/grub2.rb b/lib/puppet/provider/grub_user/grub2.rb index 817b2ad..01ea87f 100644 --- a/lib/puppet/provider/grub_user/grub2.rb +++ b/lib/puppet/provider/grub_user/grub2.rb @@ -14,7 +14,11 @@ def self.mkconfig_path which('grub2-mkconfig') or which('grub-mkconfig') or '/usr/sbin/grub-mkconfig' end - commands mkconfig: mkconfig_path + confine exists: mkconfig_path, for_binary: true + + def mkconfig + execute(self.class.mkconfig_path, { failonfail: true, combine: false }) + end confine exists: '/etc/grub.d' diff --git a/lib/puppet/provider/kernel_parameter/grub2.rb b/lib/puppet/provider/kernel_parameter/grub2.rb index 94636d6..b7d9c25 100644 --- a/lib/puppet/provider/kernel_parameter/grub2.rb +++ b/lib/puppet/provider/kernel_parameter/grub2.rb @@ -28,7 +28,12 @@ def self.mkconfig_path confine feature: :augeas defaultfor augeasprovider_grub_version: 2 - commands mkconfig: mkconfig_path + + confine exists: mkconfig_path, for_binary: true + + def mkconfig + execute(self.class.mkconfig_path, { failonfail: true, combine: false }) + end # when both grub* providers match, prefer GRUB 2 def self.specificity