From a99131795b296edba18879ce4b31b030ab382801 Mon Sep 17 00:00:00 2001 From: Lars Haugan Date: Mon, 23 Dec 2024 14:56:21 +0100 Subject: [PATCH] Add fix for package running dnf5 on fedora Fedora 41 introduced dnf5 which has deprecated the use of the flags '-d' and '-e'. This change removes the options Signed-off-by: Lars Haugan --- lib/puppet/provider/package/dnfmodule.rb | 12 ++++++------ lib/puppet/provider/package/yum.rb | 7 ++----- spec/unit/provider/package/yum_spec.rb | 22 +++++++++++----------- 3 files changed, 19 insertions(+), 22 deletions(-) diff --git a/lib/puppet/provider/package/dnfmodule.rb b/lib/puppet/provider/package/dnfmodule.rb index 8d58d2fdd8f..de052ad744e 100644 --- a/lib/puppet/provider/package/dnfmodule.rb +++ b/lib/puppet/provider/package/dnfmodule.rb @@ -35,7 +35,7 @@ def self.prefetch(packages) def self.instances packages = [] - cmd = "#{command(:dnf)} module list -y -d 0 -e #{error_level}" + cmd = "#{command(:dnf)} module list -y" execute(cmd).each_line do |line| # select only lines with actual packages since DNF clutters the output next unless line =~ /\[[eix]\][, ]/ @@ -90,7 +90,7 @@ def install enable(args) else begin - execute([command(:dnf), 'module', 'install', '-d', '0', '-e', self.class.error_level, '-y', args]) + execute([command(:dnf), 'module', 'install', '-y', args]) rescue Puppet::ExecutionFailure => e # module has no default profile and no profile was requested, so just enable the stream # DNF versions prior to 4.2.8 do not need this workaround @@ -117,20 +117,20 @@ def insync?(is) end def enable(args = @resource[:name]) - execute([command(:dnf), 'module', 'enable', '-d', '0', '-e', self.class.error_level, '-y', args]) + execute([command(:dnf), 'module', 'enable', '-y', args]) end def uninstall - execute([command(:dnf), 'module', 'remove', '-d', '0', '-e', self.class.error_level, '-y', @resource[:name]]) + execute([command(:dnf), 'module', 'remove', '-y', @resource[:name]]) reset # reset module to the default stream end def disable(args = @resource[:name]) - execute([command(:dnf), 'module', 'disable', '-d', '0', '-e', self.class.error_level, '-y', args]) + execute([command(:dnf), 'module', 'disable', '-y', args]) end def reset - execute([command(:dnf), 'module', 'reset', '-d', '0', '-e', self.class.error_level, '-y', @resource[:name]]) + execute([command(:dnf), 'module', 'reset', '-y', @resource[:name]]) end def flavor diff --git a/lib/puppet/provider/package/yum.rb b/lib/puppet/provider/package/yum.rb index 15bc372c6b3..6c0f85e31b8 100644 --- a/lib/puppet/provider/package/yum.rb +++ b/lib/puppet/provider/package/yum.rb @@ -247,7 +247,7 @@ def install update_command = self.class.update_command # If not allowing virtual packages, do a query to ensure a real package exists unless @resource.allow_virtual? - execute([command(:cmd), '-d', '0', '-e', error_level, '-y', install_options, :list, wanted].compact) + execute([command(:cmd), '-y', install_options, :list, wanted].compact) end should = @resource.should(:ensure) @@ -307,10 +307,7 @@ def install end end - # Yum on el-4 and el-5 returns exit status 0 when trying to install a package it doesn't recognize; - # ensure we capture output to check for errors. - no_debug = Puppet.runtime[:facter].value('os.release.major').to_i > 5 ? ["-d", "0"] : [] - command = [command(:cmd)] + no_debug + ["-e", error_level, "-y", install_options, operation, wanted].compact + command = [command(:cmd)] + ["-y", install_options, operation, wanted].compact output = execute(command) if output.to_s =~ /^No package #{wanted} available\.$/ diff --git a/spec/unit/provider/package/yum_spec.rb b/spec/unit/provider/package/yum_spec.rb index c4a9d386a23..40325b4348d 100644 --- a/spec/unit/provider/package/yum_spec.rb +++ b/spec/unit/provider/package/yum_spec.rb @@ -363,7 +363,7 @@ it 'selects best_version' do expect(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, 'myresource-18.3.2'] + ['/usr/bin/yum', '-y', :install, 'myresource-18.3.2'] ) provider.install end @@ -374,7 +374,7 @@ it 'treats no epoch as zero' do expect(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, 'myresource-18.3.2'] + ['/usr/bin/yum', '-y', :install, 'myresource-18.3.2'] ) provider.install end @@ -387,7 +387,7 @@ it 'selects best_version and removes epoch' do expect(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, 'myresource-18.3.2'] + ['/usr/bin/yum', '-y', :install, 'myresource-18.3.2'] ) provider.install end @@ -399,14 +399,14 @@ it 'uses requested version' do expect(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, "myresource->18.1 <19"] + ['/usr/bin/yum', '-y', :install, "myresource->18.1 <19"] ) provider.install end it 'logs a debug message' do allow(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, "myresource->18.1 <19"] + ['/usr/bin/yum', '-y', :install, "myresource->18.1 <19"] ) expect(Puppet).to receive(:debug).with( @@ -422,7 +422,7 @@ it 'passes the version to yum command' do expect(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, "myresource-1:18.12"] + ['/usr/bin/yum', '-y', :install, "myresource-1:18.12"] ) provider.install end @@ -440,7 +440,7 @@ it 'adds update flag to install command' do expect(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', 'update', 'myresource-18.3.2'] + ['/usr/bin/yum', '-y', 'update', 'myresource-18.3.2'] ) provider.install end @@ -458,7 +458,7 @@ it 'adds downgrade flag to install command' do expect(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :downgrade, 'myresource-18.3.2'] + ['/usr/bin/yum', '-y', :downgrade, 'myresource-18.3.2'] ) provider.install end @@ -470,7 +470,7 @@ context 'when execute command fails' do before do allow(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, "myresource-20"] + ['/usr/bin/yum', '-y', :install, "myresource-20"] ).and_return('No package myresource-20 available.') end @@ -484,7 +484,7 @@ before do allow(provider).to receive(:query) allow(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, "myresource-20"] + ['/usr/bin/yum', '-y', :install, "myresource-20"] ) end @@ -497,7 +497,7 @@ context 'when package is not installed' do before do allow(provider).to receive(:execute).with( - ['/usr/bin/yum', '-d', '0', '-e', '0', '-y', :install, "myresource-20"] + ['/usr/bin/yum', '-y', :install, "myresource-20"] ) allow(provider).to receive(:insync?).and_return(false) end