e837bed3ff
The parameter name used to enforce package state is inconsistent across manifests and modules. I settle on package_ensure since it's already widely used. Change-Id: I9868f954a032a0014b9304526daf5476b0922c5d Closes-Bug: #1668732
57 lines
1.6 KiB
Ruby
57 lines
1.6 KiB
Ruby
shared_examples_for "a Puppet::Error" do |description|
|
|
it "with message matching #{description.inspect}" do
|
|
expect { is_expected.to have_class_count(1) }.to raise_error(Puppet::Error, description)
|
|
end
|
|
end
|
|
|
|
shared_examples 'generic designate service' do |service|
|
|
|
|
context 'with default parameters' do
|
|
it 'installs package and service' do
|
|
is_expected.to contain_package(service[:name]).with({
|
|
:name => service[:package_name],
|
|
:ensure => 'present',
|
|
:notify => "Service[#{service[:name]}]"
|
|
})
|
|
is_expected.to contain_service(service[:name]).with({
|
|
:name => service[:service_name],
|
|
:ensure => 'stopped',
|
|
:hasstatus => true,
|
|
:enable => false
|
|
})
|
|
end
|
|
end
|
|
|
|
context 'with overridden parameters' do
|
|
let :params do
|
|
{ :enabled => true,
|
|
:package_ensure => '2014.2-1' }
|
|
end
|
|
|
|
it 'installs package and service' do
|
|
is_expected.to contain_package(service[:name]).with({
|
|
:name => service[:package_name],
|
|
:ensure => '2014.2-1',
|
|
:notify => "Service[#{service[:name]}]"
|
|
})
|
|
is_expected.to contain_service(service[:name]).with({
|
|
:name => service[:service_name],
|
|
:ensure => 'running',
|
|
:hasstatus => true,
|
|
:enable => true
|
|
})
|
|
end
|
|
end
|
|
|
|
context 'while not managing service state' do
|
|
let :params do
|
|
{ :enabled => false,
|
|
:manage_service => false }
|
|
end
|
|
|
|
it 'does not control service state' do
|
|
is_expected.to contain_service(service[:name]).without_ensure
|
|
end
|
|
end
|
|
end
|