(#12522) Adding purge option to apt class

Adds a purge option to the apt class to remove repositories
that are not managed by apt::source
This commit is contained in:
William Van Hevelingen 2012-02-08 11:40:09 -08:00
parent 52adc3555c
commit 8c279636f5
2 changed files with 52 additions and 17 deletions

View file

@ -15,14 +15,17 @@
# Sample Usage: # Sample Usage:
# class { 'apt': } # class { 'apt': }
class apt( class apt(
$disable_keys = false,
$always_apt_update = false, $always_apt_update = false,
$disable_keys = false,
$proxy_host = false, $proxy_host = false,
$proxy_port = '8080' $proxy_port = '8080',
$purge = false
) { ) {
include apt::params include apt::params
validate_bool($purge)
$refresh_only_apt_update = $always_apt_update? { $refresh_only_apt_update = $always_apt_update? {
true => false, true => false,
false => true false => true
@ -36,6 +39,10 @@ class apt(
owner => root, owner => root,
group => root, group => root,
mode => 644, mode => 644,
content => $purge ? {
false => undef,
true => "# Repos managed by puppet.\n",
},
} }
file { "sources.list.d": file { "sources.list.d":
@ -43,6 +50,8 @@ class apt(
ensure => directory, ensure => directory,
owner => root, owner => root,
group => root, group => root,
purge => $purge,
recurse => $purge,
} }
exec { "apt_update": exec { "apt_update":

View file

@ -3,7 +3,8 @@ describe 'apt', :type => :class do
let :default_params do let :default_params do
{ {
:disable_keys => false, :disable_keys => false,
:always_apt_update => false :always_apt_update => false,
:purge => false
} }
end end
@ -12,7 +13,8 @@ describe 'apt', :type => :class do
:disable_keys => true, :disable_keys => true,
:always_apt_update => true, :always_apt_update => true,
:proxy_host => true, :proxy_host => true,
:proxy_port => '3128' :proxy_port => '3128',
:purge => true
} }
].each do |param_set| ].each do |param_set|
describe "when #{param_set == {} ? "using default" : "specifying"} class parameters" do describe "when #{param_set == {} ? "using default" : "specifying"} class parameters" do
@ -37,22 +39,46 @@ describe 'apt', :type => :class do
it { should contain_package("python-software-properties") } it { should contain_package("python-software-properties") }
it { it {
if param_hash[:purge]
should contain_file("sources.list").with({ should contain_file("sources.list").with({
'path' => "/etc/apt/sources.list", 'path' => "/etc/apt/sources.list",
'ensure' => "present", 'ensure' => "present",
'owner' => "root", 'owner' => "root",
'group' => "root", 'group' => "root",
'mode' => 644 'mode' => 644,
"content" => "# Repos managed by puppet.\n"
}) })
else
should contain_file("sources.list").with({
'path' => "/etc/apt/sources.list",
'ensure' => "present",
'owner' => "root",
'group' => "root",
'mode' => 644,
'content' => nil
})
end
} }
it { it {
if param_hash[:purge]
should create_file("sources.list.d").with({ should create_file("sources.list.d").with({
"path" => "/etc/apt/sources.list.d", 'path' => "/etc/apt/sources.list.d",
"ensure" => "directory", 'ensure' => "directory",
"owner" => "root", 'owner' => "root",
"group" => "root" 'group' => "root",
'purge' => true,
'recurse' => true
}) })
else
should create_file("sources.list.d").with({
'path' => "/etc/apt/sources.list.d",
'ensure' => "directory",
'owner' => "root",
'group' => "root",
'purge' => false,
'recurse' => false
})
end
} }
it { it {