8c279636f5
Adds a purge option to the apt class to remove repositories that are not managed by apt::source
119 lines
3.4 KiB
Ruby
119 lines
3.4 KiB
Ruby
require 'spec_helper'
|
|
describe 'apt', :type => :class do
|
|
let :default_params do
|
|
{
|
|
:disable_keys => false,
|
|
:always_apt_update => false,
|
|
:purge => false
|
|
}
|
|
end
|
|
|
|
[{},
|
|
{
|
|
:disable_keys => true,
|
|
:always_apt_update => true,
|
|
:proxy_host => true,
|
|
:proxy_port => '3128',
|
|
:purge => true
|
|
}
|
|
].each do |param_set|
|
|
describe "when #{param_set == {} ? "using default" : "specifying"} class parameters" do
|
|
let :param_hash do
|
|
default_params.merge(param_set)
|
|
end
|
|
|
|
let :params do
|
|
param_set
|
|
end
|
|
|
|
let :refresh_only_apt_update do
|
|
if param_hash[:always_apt_update]
|
|
false
|
|
else
|
|
true
|
|
end
|
|
end
|
|
|
|
it { should include_class("apt::params") }
|
|
|
|
it { should contain_package("python-software-properties") }
|
|
|
|
it {
|
|
if param_hash[:purge]
|
|
should contain_file("sources.list").with({
|
|
'path' => "/etc/apt/sources.list",
|
|
'ensure' => "present",
|
|
'owner' => "root",
|
|
'group' => "root",
|
|
'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 {
|
|
if param_hash[:purge]
|
|
should create_file("sources.list.d").with({
|
|
'path' => "/etc/apt/sources.list.d",
|
|
'ensure' => "directory",
|
|
'owner' => "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 {
|
|
should contain_exec("apt_update").with({
|
|
'command' => "/usr/bin/apt-get update",
|
|
'subscribe' => ["File[sources.list]", "File[sources.list.d]"],
|
|
'refreshonly' => refresh_only_apt_update
|
|
})
|
|
}
|
|
|
|
it {
|
|
if param_hash[:disable_keys]
|
|
should contain_exec("make-apt-insecure").with({
|
|
'command' => '/bin/echo "APT::Get::AllowUnauthenticated 1;" >> /etc/apt/apt.conf.d/99unauth',
|
|
'creates' => '/etc/apt/apt.conf.d/99unauth'
|
|
})
|
|
else
|
|
should_not contain_exec("make-apt-insecure").with({
|
|
'command' => '/bin/echo "APT::Get::AllowUnauthenticated 1;" >> /etc/apt/apt.conf.d/99unauth',
|
|
'creates' => '/etc/apt/apt.conf.d/99unauth'
|
|
})
|
|
end
|
|
}
|
|
describe 'when setting a proxy' do
|
|
it {
|
|
if param_hash[:proxy_host]
|
|
should contain_file('configure-apt-proxy').with(
|
|
'path' => '/etc/apt/apt.conf.d/proxy',
|
|
'content' => "Acquire::http::Proxy \"http://#{param_hash[:proxy_host]}:#{param_hash[:proxy_port]}\";"
|
|
)
|
|
else
|
|
should_not contain_file('configure_apt_proxy')
|
|
end
|
|
}
|
|
end
|
|
end
|
|
end
|
|
end
|