a02654e36c
In Ubuntu 15.10 the path of the apt sources file, which is generated by apt-add-repository, changed to include the distid. This breaks apt::ppa idempotency, since it does not recognize the repository is already added. Reported on puppet-users as well: https://groups.google.com/forum/#!topic/puppet-users/YzeMyZYUo98
378 lines
12 KiB
Ruby
378 lines
12 KiB
Ruby
require 'spec_helper'
|
|
describe 'apt::ppa' do
|
|
let :pre_condition do
|
|
'class { "apt": }'
|
|
end
|
|
|
|
describe 'defaults' do
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '11.04',
|
|
:lsbdistcodename => 'natty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:lsbdistid => 'Ubuntu',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
|
|
let(:title) { 'ppa:needs/such.substitution/wow+type' }
|
|
it { is_expected.to_not contain_package('python-software-properties') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:needs/such.substitution/wow+type').that_notifies('Class[Apt::Update]').with({
|
|
:environment => [],
|
|
:command => '/usr/bin/add-apt-repository -y ppa:needs/such.substitution/wow+type',
|
|
:unless => '/usr/bin/test -s /etc/apt/sources.list.d/needs-such_substitution-wow_type-natty.list',
|
|
:user => 'root',
|
|
:logoutput => 'on_failure',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'Ubuntu 15.10 sources.list filename' do
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '15.10',
|
|
:lsbdistcodename => 'wily',
|
|
:operatingsystem => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:lsbdistid => 'Ubuntu',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
|
|
let(:title) { 'ppa:user/foo' }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:user/foo').that_notifies('Class[Apt::Update]').with({
|
|
:environment => [],
|
|
:command => '/usr/bin/add-apt-repository -y ppa:user/foo',
|
|
:unless => '/usr/bin/test -s /etc/apt/sources.list.d/user-ubuntu-foo-wily.list',
|
|
:user => 'root',
|
|
:logoutput => 'on_failure',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'ppa depending on ppa, MODULES-1156' do
|
|
let :pre_condition do
|
|
'class { "apt": }'
|
|
end
|
|
end
|
|
|
|
describe 'package_name => software-properties-common' do
|
|
let :pre_condition do
|
|
'class { "apt": }'
|
|
end
|
|
let :params do
|
|
{
|
|
:package_name => 'software-properties-common',
|
|
:package_manage => true,
|
|
}
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '11.04',
|
|
:lsbdistcodename => 'natty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:lsbdistid => 'Ubuntu',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
|
|
let(:title) { 'ppa:needs/such.substitution/wow' }
|
|
it { is_expected.to contain_package('software-properties-common') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:needs/such.substitution/wow').that_notifies('Class[Apt::Update]').with({
|
|
'environment' => [],
|
|
'command' => '/usr/bin/add-apt-repository -y ppa:needs/such.substitution/wow',
|
|
'unless' => '/usr/bin/test -s /etc/apt/sources.list.d/needs-such_substitution-wow-natty.list',
|
|
'user' => 'root',
|
|
'logoutput' => 'on_failure',
|
|
})
|
|
}
|
|
|
|
it { is_expected.to contain_file('/etc/apt/sources.list.d/needs-such_substitution-wow-natty.list').that_requires('Exec[add-apt-repository-ppa:needs/such.substitution/wow]').with({
|
|
'ensure' => 'file',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'package_manage => true, multiple ppas, MODULES-2873' do
|
|
let :pre_condition do
|
|
'class { "apt": }
|
|
apt::ppa {"ppa:user/foo":
|
|
package_manage => true
|
|
}'
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '11.04',
|
|
:lsbdistcodename => 'natty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:lsbdistid => 'Ubuntu',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let :params do
|
|
{
|
|
:package_manage => true,
|
|
}
|
|
end
|
|
|
|
let(:title) { 'ppa:user/bar' }
|
|
it { is_expected.to contain_package('python-software-properties') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:user/bar').that_notifies('Class[Apt::Update]').with({
|
|
'environment' => [],
|
|
'command' => '/usr/bin/add-apt-repository -y ppa:user/bar',
|
|
'unless' => '/usr/bin/test -s /etc/apt/sources.list.d/user-bar-natty.list',
|
|
'user' => 'root',
|
|
'logoutput' => 'on_failure',
|
|
})
|
|
}
|
|
|
|
it { is_expected.to contain_file('/etc/apt/sources.list.d/user-bar-natty.list').that_requires('Exec[add-apt-repository-ppa:user/bar]').with({
|
|
'ensure' => 'file',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'package_manage => false' do
|
|
let :pre_condition do
|
|
'class { "apt": }'
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '11.04',
|
|
:lsbdistcodename => 'natty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:lsbdistid => 'Ubuntu',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let :params do
|
|
{
|
|
:package_manage => false,
|
|
}
|
|
end
|
|
|
|
let(:title) { 'ppa:needs/such.substitution/wow' }
|
|
it { is_expected.to_not contain_package('python-software-properties') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:needs/such.substitution/wow').that_notifies('Class[Apt::Update]').with({
|
|
'environment' => [],
|
|
'command' => '/usr/bin/add-apt-repository -y ppa:needs/such.substitution/wow',
|
|
'unless' => '/usr/bin/test -s /etc/apt/sources.list.d/needs-such_substitution-wow-natty.list',
|
|
'user' => 'root',
|
|
'logoutput' => 'on_failure',
|
|
})
|
|
}
|
|
|
|
it { is_expected.to contain_file('/etc/apt/sources.list.d/needs-such_substitution-wow-natty.list').that_requires('Exec[add-apt-repository-ppa:needs/such.substitution/wow]').with({
|
|
'ensure' => 'file',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'apt included, no proxy' do
|
|
let :pre_condition do
|
|
'class { "apt": }
|
|
apt::ppa { "ppa:user/foo2": }
|
|
'
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '14.04',
|
|
:lsbdistcodename => 'trusty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:lsbdistid => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let :params do
|
|
{
|
|
:options => '',
|
|
:package_manage => true,
|
|
:require => 'Apt::Ppa[ppa:user/foo2]',
|
|
}
|
|
end
|
|
let(:title) { 'ppa:user/foo' }
|
|
it { is_expected.to compile.with_all_deps }
|
|
it { is_expected.to contain_package('software-properties-common') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:user/foo').that_notifies('Class[Apt::Update]').with({
|
|
:environment => [],
|
|
:command => '/usr/bin/add-apt-repository ppa:user/foo',
|
|
:unless => '/usr/bin/test -s /etc/apt/sources.list.d/user-foo-trusty.list',
|
|
:user => 'root',
|
|
:logoutput => 'on_failure',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'apt included, proxy host' do
|
|
let :pre_condition do
|
|
'class { "apt":
|
|
proxy => { "host" => "localhost" },
|
|
}'
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '14.04',
|
|
:lsbdistcodename => 'trusty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:lsbdistid => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let :params do
|
|
{
|
|
'options' => '',
|
|
'package_manage' => true,
|
|
}
|
|
end
|
|
let(:title) { 'ppa:user/foo' }
|
|
it { is_expected.to contain_package('software-properties-common') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:user/foo').that_notifies('Class[Apt::Update]').with({
|
|
:environment => ['http_proxy=http://localhost:8080'],
|
|
:command => '/usr/bin/add-apt-repository ppa:user/foo',
|
|
:unless => '/usr/bin/test -s /etc/apt/sources.list.d/user-foo-trusty.list',
|
|
:user => 'root',
|
|
:logoutput => 'on_failure',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'apt included, proxy host and port' do
|
|
let :pre_condition do
|
|
'class { "apt":
|
|
proxy => { "host" => "localhost", "port" => 8180 },
|
|
}'
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '14.04',
|
|
:lsbdistcodename => 'trusty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:lsbdistid => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let :params do
|
|
{
|
|
:options => '',
|
|
:package_manage => true,
|
|
}
|
|
end
|
|
let(:title) { 'ppa:user/foo' }
|
|
it { is_expected.to contain_package('software-properties-common') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:user/foo').that_notifies('Class[Apt::Update]').with({
|
|
:environment => ['http_proxy=http://localhost:8180'],
|
|
:command => '/usr/bin/add-apt-repository ppa:user/foo',
|
|
:unless => '/usr/bin/test -s /etc/apt/sources.list.d/user-foo-trusty.list',
|
|
:user => 'root',
|
|
:logoutput => 'on_failure',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'apt included, proxy host and port and https' do
|
|
let :pre_condition do
|
|
'class { "apt":
|
|
proxy => { "host" => "localhost", "port" => 8180, "https" => true },
|
|
}'
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '14.04',
|
|
:lsbdistcodename => 'trusty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:lsbdistid => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let :params do
|
|
{
|
|
:options => '',
|
|
:package_manage => true,
|
|
}
|
|
end
|
|
let(:title) { 'ppa:user/foo' }
|
|
it { is_expected.to contain_package('software-properties-common') }
|
|
it { is_expected.to contain_exec('add-apt-repository-ppa:user/foo').that_notifies('Class[Apt::Update]').with({
|
|
:environment => ['http_proxy=http://localhost:8180', 'https_proxy=https://localhost:8180'],
|
|
:command => '/usr/bin/add-apt-repository ppa:user/foo',
|
|
:unless => '/usr/bin/test -s /etc/apt/sources.list.d/user-foo-trusty.list',
|
|
:user => 'root',
|
|
:logoutput => 'on_failure',
|
|
})
|
|
}
|
|
end
|
|
|
|
describe 'ensure absent' do
|
|
let :pre_condition do
|
|
'class { "apt": }'
|
|
end
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '14.04',
|
|
:lsbdistcodename => 'trusty',
|
|
:operatingsystem => 'Ubuntu',
|
|
:lsbdistid => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let(:title) { 'ppa:user/foo' }
|
|
let :params do
|
|
{
|
|
:ensure => 'absent'
|
|
}
|
|
end
|
|
it { is_expected.to contain_file('/etc/apt/sources.list.d/user-foo-trusty.list').that_notifies('Class[Apt::Update]').with({
|
|
:ensure => 'absent',
|
|
})
|
|
}
|
|
end
|
|
|
|
context 'validation' do
|
|
describe 'no release' do
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '14.04',
|
|
:operatingsystem => 'Ubuntu',
|
|
:lsbdistid => 'Ubuntu',
|
|
:osfamily => 'Debian',
|
|
:lsbdistcodeanme => nil,
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let(:title) { 'ppa:user/foo' }
|
|
it do
|
|
expect {
|
|
subject.call
|
|
}.to raise_error(Puppet::Error, /lsbdistcodename fact not available: release parameter required/)
|
|
end
|
|
end
|
|
|
|
describe 'not ubuntu' do
|
|
let :facts do
|
|
{
|
|
:lsbdistrelease => '6.0.7',
|
|
:lsbdistcodename => 'wheezy',
|
|
:operatingsystem => 'Debian',
|
|
:lsbdistid => 'debian',
|
|
:osfamily => 'Debian',
|
|
:puppetversion => Puppet.version,
|
|
}
|
|
end
|
|
let(:title) { 'ppa:user/foo' }
|
|
it do
|
|
expect {
|
|
subject.call
|
|
}.to raise_error(Puppet::Error, /not currently supported on Debian/)
|
|
end
|
|
end
|
|
end
|
|
end
|