apt::force: Added 2 parameters for automatic configuration file handling; fixes #modules-1306
when updating or installing newer packages with apt::force and you have changed previous configuration files aptitude or apt-get will prompt what to do. You can suppress that by pre-define the action with cfg_files parameter (new, old or unchanged and its backward compatible if not defined). With a second optional parameter cfg_missing you can force your provider to install missing configuration files as well. Signed-off-by: Martin Seener <martin@seener.de> apt::force: Changed selectors used in force.pp to case statements; refs #module-1306 Signed-off-by: Martin Seener <martin@seener.de> apt::force: rspec: fixed the failing tests and added validate_re for cfg_files and validate_bool for cfg_missing. Also removed default values for both case statements and only allow pre-defined values or true/false. Furthermore enhanced the README refs #module-1306 Was able to fix the failing rspec tests for the patch. Thanks to Morgan Haskel. Signed-off-by: Martin Seener <martin@seener.de> Despite the puppetlabs-stdlib documentation says validation_re supports 3 arguments the tests failed telling that only 2 are supported. Fixed this by removing the 3 optional argument; refs #modules-1306 Signed-off-by: Martin Seener <martin.seener@barzahlen.de> apt::force: updated readme refs #module-1306 Signed-off-by: Martin Seener <martin@seener.de>
This commit is contained in:
parent
932c3a7e6b
commit
93567aef4a
3 changed files with 84 additions and 13 deletions
14
README.md
14
README.md
|
@ -71,13 +71,21 @@ Installs the build depends of a specified package.
|
||||||
### apt::force
|
### apt::force
|
||||||
|
|
||||||
Forces a package to be installed from a specific release. This class is particularly useful when using repositories, like Debian, that are unstable in Ubuntu.
|
Forces a package to be installed from a specific release. This class is particularly useful when using repositories, like Debian, that are unstable in Ubuntu.
|
||||||
|
The cfg_files parameter controls wether newer or older configuration files should be used or only unchanged configuration files should be updated. Cfg_missing forces the provider to install all missing configuration files. Both are optional.
|
||||||
|
|
||||||
apt::force { 'glusterfs-server':
|
apt::force { 'glusterfs-server':
|
||||||
release => 'unstable',
|
release => 'unstable',
|
||||||
version => '3.0.3',
|
version => '3.0.3',
|
||||||
require => Apt::Source['debian_unstable'],
|
cfg_files => 'unchanged',
|
||||||
|
cfg_missing => true,
|
||||||
|
require => Apt::Source['debian_unstable'],
|
||||||
}
|
}
|
||||||
|
|
||||||
|
You can additionally set the following attributes:
|
||||||
|
|
||||||
|
* `cfg_files`: "new", "old", "unchanged" or "none" (default). "new" will overwrite all existing configuration files with newer ones, "old" will force usage of all old files and "unchanged" only updates unchanged config files whereas setting "none" will don't do anything but providing backward-compatability with existing puppet manifests.
|
||||||
|
* `cfg_missing`: "true" or "false". Setting cfg_missing to false will provide backward compatability whereas setting true will add an aptitude/apt-get parameter which checks and installs missing configuration files for the selected package.
|
||||||
|
|
||||||
### apt_key
|
### apt_key
|
||||||
|
|
||||||
A native Puppet type and provider for managing GPG keys for APT is provided by this module.
|
A native Puppet type and provider for managing GPG keys for APT is provided by this module.
|
||||||
|
|
|
@ -2,11 +2,16 @@
|
||||||
# force a package from a specific release
|
# force a package from a specific release
|
||||||
|
|
||||||
define apt::force(
|
define apt::force(
|
||||||
$release = false,
|
$release = false,
|
||||||
$version = false,
|
$version = false,
|
||||||
$timeout = 300
|
$timeout = 300,
|
||||||
|
$cfg_files = 'none',
|
||||||
|
$cfg_missing = false,
|
||||||
) {
|
) {
|
||||||
|
|
||||||
|
validate_re($cfg_files, ['^new', '^old', '^unchanged', '^none'])
|
||||||
|
validate_bool($cfg_missing)
|
||||||
|
|
||||||
$provider = $apt::params::provider
|
$provider = $apt::params::provider
|
||||||
|
|
||||||
$version_string = $version ? {
|
$version_string = $version ? {
|
||||||
|
@ -19,6 +24,18 @@ define apt::force(
|
||||||
default => "-t ${release}",
|
default => "-t ${release}",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case $cfg_files {
|
||||||
|
'new': { $config_files = '-o Dpkg::Options::="--force-confnew"' }
|
||||||
|
'old': { $config_files = '-o Dpkg::Options::="--force-confold"' }
|
||||||
|
'unchanged': { $config_files = '-o Dpkg::Options::="--force-confdef"' }
|
||||||
|
'none': { $config_files = '' }
|
||||||
|
}
|
||||||
|
|
||||||
|
case $cfg_missing {
|
||||||
|
true: { $config_missing = '-o Dpkg::Options::="--force-confmiss"' }
|
||||||
|
false: { $config_missing = '' }
|
||||||
|
}
|
||||||
|
|
||||||
if $version == false {
|
if $version == false {
|
||||||
if $release == false {
|
if $release == false {
|
||||||
$install_check = "/usr/bin/dpkg -s ${name} | grep -q 'Status: install'"
|
$install_check = "/usr/bin/dpkg -s ${name} | grep -q 'Status: install'"
|
||||||
|
@ -34,7 +51,7 @@ define apt::force(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
exec { "${provider} -y ${release_string} install ${name}${version_string}":
|
exec { "${provider} -y ${config_files} ${config_missing} ${release_string} install ${name}${version_string}":
|
||||||
unless => $install_check,
|
unless => $install_check,
|
||||||
logoutput => 'on_failure',
|
logoutput => 'on_failure',
|
||||||
timeout => $timeout,
|
timeout => $timeout,
|
||||||
|
|
|
@ -11,13 +11,15 @@ describe 'apt::force', :type => :define do
|
||||||
|
|
||||||
let :default_params do
|
let :default_params do
|
||||||
{
|
{
|
||||||
:release => false,
|
:release => false,
|
||||||
:version => false
|
:version => false,
|
||||||
|
:cfg_files => 'none',
|
||||||
|
:cfg_missing => false,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "when using default parameters" do
|
describe "when using default parameters" do
|
||||||
it { should contain_exec("/usr/bin/apt-get -y install #{title}").with(
|
it { should contain_exec("/usr/bin/apt-get -y install #{title}").with(
|
||||||
:unless => "/usr/bin/dpkg -s #{title} | grep -q 'Status: install'",
|
:unless => "/usr/bin/dpkg -s #{title} | grep -q 'Status: install'",
|
||||||
:logoutput => 'on_failure',
|
:logoutput => 'on_failure',
|
||||||
:timeout => '300'
|
:timeout => '300'
|
||||||
|
@ -28,7 +30,7 @@ describe 'apt::force', :type => :define do
|
||||||
let :params do
|
let :params do
|
||||||
default_params.merge(:release => 'testing')
|
default_params.merge(:release => 'testing')
|
||||||
end
|
end
|
||||||
it { should contain_exec("/usr/bin/apt-get -y -t #{params[:release]} install #{title}").with(
|
it { should contain_exec("/usr/bin/apt-get -y -t #{params[:release]} install #{title}").with(
|
||||||
:unless => "/usr/bin/test \$(/usr/bin/apt-cache policy -t #{params[:release]} #{title} | /bin/grep -E 'Installed|Candidate' | /usr/bin/uniq -s 14 | /usr/bin/wc -l) -eq 1"
|
:unless => "/usr/bin/test \$(/usr/bin/apt-cache policy -t #{params[:release]} #{title} | /bin/grep -E 'Installed|Candidate' | /usr/bin/uniq -s 14 | /usr/bin/wc -l) -eq 1"
|
||||||
) }
|
) }
|
||||||
end
|
end
|
||||||
|
@ -37,11 +39,41 @@ describe 'apt::force', :type => :define do
|
||||||
let :params do
|
let :params do
|
||||||
default_params.merge(:version => '1')
|
default_params.merge(:version => '1')
|
||||||
end
|
end
|
||||||
it { should contain_exec("/usr/bin/apt-get -y install #{title}=#{params[:version]}").with(
|
it { should contain_exec("/usr/bin/apt-get -y install #{title}=#{params[:version]}").with(
|
||||||
:unless => "/usr/bin/dpkg -s #{title} | grep -q 'Version: #{params[:version]}'"
|
:unless => "/usr/bin/dpkg -s #{title} | grep -q 'Version: #{params[:version]}'"
|
||||||
) }
|
) }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "when specifying cfg_files parameter" do
|
||||||
|
let :params do
|
||||||
|
default_params.merge(:cfg_files => 'unchanged')
|
||||||
|
end
|
||||||
|
it { should contain_exec('/usr/bin/apt-get -y -o Dpkg::Options::="--force-confdef" install my_package').with(
|
||||||
|
:unless => "/usr/bin/dpkg -s #{title} | grep -q 'Status: install'"
|
||||||
|
) }
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "when specifying cfg_missing parameter" do
|
||||||
|
let :params do
|
||||||
|
default_params.merge(:cfg_missing => true)
|
||||||
|
end
|
||||||
|
it { should contain_exec('/usr/bin/apt-get -y -o Dpkg::Options::="--force-confmiss" install my_package').with(
|
||||||
|
:unless => "/usr/bin/dpkg -s #{title} | grep -q 'Status: install'"
|
||||||
|
) }
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "when specifying cfg_files and cfg_missing parameter" do
|
||||||
|
let :params do
|
||||||
|
default_params.merge(
|
||||||
|
:cfg_files => 'unchanged',
|
||||||
|
:cfg_missing => true
|
||||||
|
)
|
||||||
|
end
|
||||||
|
it { should contain_exec('/usr/bin/apt-get -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confmiss" install my_package').with(
|
||||||
|
:unless => "/usr/bin/dpkg -s #{title} | grep -q 'Status: install'"
|
||||||
|
) }
|
||||||
|
end
|
||||||
|
|
||||||
describe "when specifying release and version parameters" do
|
describe "when specifying release and version parameters" do
|
||||||
let :params do
|
let :params do
|
||||||
default_params.merge(
|
default_params.merge(
|
||||||
|
@ -49,8 +81,22 @@ describe 'apt::force', :type => :define do
|
||||||
:version => '1'
|
:version => '1'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
it { should contain_exec("/usr/bin/apt-get -y -t #{params[:release]} install #{title}=1").with(
|
it { should contain_exec("/usr/bin/apt-get -y -t #{params[:release]} install #{title}=1").with(
|
||||||
:unless => "/usr/bin/apt-cache policy -t #{params[:release]} #{title} | /bin/grep -q 'Installed: #{params[:version]}'"
|
:unless => "/usr/bin/apt-cache policy -t #{params[:release]} #{title} | /bin/grep -q 'Installed: #{params[:version]}'"
|
||||||
) }
|
) }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "when specifying release, version, cfg_files and cfg_missing parameters" do
|
||||||
|
let :params do
|
||||||
|
default_params.merge(
|
||||||
|
:release => 'testing',
|
||||||
|
:version => '1',
|
||||||
|
:cfg_files => 'unchanged',
|
||||||
|
:cfg_missing => true
|
||||||
|
)
|
||||||
|
end
|
||||||
|
it { should contain_exec('/usr/bin/apt-get -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confmiss" -t testing install my_package=1').with(
|
||||||
|
:unless => "/usr/bin/apt-cache policy -t #{params[:release]} #{title} | /bin/grep -q 'Installed: #{params[:version]}'"
|
||||||
|
) }
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue