6156cb49f2
Switch to $::os_service_default all params in logging and db. Changes: logging.pp, db.pp and tests. Related-bug: #1515273 Change-Id: I412104bf46c4b40fdbd366e3a8a9dc9de5abb5fd
132 lines
3.8 KiB
Ruby
132 lines
3.8 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'ceilometer::agent::compute' do
|
|
|
|
let :pre_condition do
|
|
"include nova\n" +
|
|
"include nova::compute\n" +
|
|
"class { 'ceilometer': metering_secret => 's3cr3t' }"
|
|
end
|
|
|
|
let :params do
|
|
{ :enabled => true,
|
|
:manage_service => true,
|
|
:package_ensure => 'installed' }
|
|
end
|
|
|
|
shared_examples_for 'ceilometer-agent-compute' do
|
|
|
|
it { is_expected.to contain_class('ceilometer::params') }
|
|
|
|
it 'installs ceilometer-agent-compute package' do
|
|
is_expected.to contain_package('ceilometer-agent-compute').with(
|
|
:ensure => 'installed',
|
|
:name => platform_params[:agent_package_name],
|
|
:before => ['Service[ceilometer-agent-compute]'],
|
|
:tag => ['openstack', 'ceilometer-package'],
|
|
)
|
|
end
|
|
|
|
it 'adds ceilometer user to nova group and, if required, to libvirt group' do
|
|
if platform_params[:libvirt_group]
|
|
is_expected.to contain_user('ceilometer').with_groups(['nova', "#{platform_params[:libvirt_group]}"])
|
|
else
|
|
is_expected.to contain_user('ceilometer').with_groups(['nova'])
|
|
end
|
|
end
|
|
|
|
it 'ensures ceilometer-common is installed before the service' do
|
|
is_expected.to contain_package('ceilometer-common').with(
|
|
:before => /Service\[ceilometer-agent-compute\]/
|
|
)
|
|
end
|
|
|
|
it 'ensures nova-common is installed before the package ceilometer-common' do
|
|
is_expected.to contain_package('nova-common').with(
|
|
:before => /Package\[ceilometer-common\]/
|
|
)
|
|
end
|
|
|
|
[{:enabled => true}, {:enabled => false}].each do |param_hash|
|
|
context "when service should be #{param_hash[:enabled] ? 'enabled' : 'disabled'}" do
|
|
before do
|
|
params.merge!(param_hash)
|
|
end
|
|
|
|
it 'configures ceilometer-agent-compute service' do
|
|
|
|
is_expected.to contain_service('ceilometer-agent-compute').with(
|
|
:ensure => (params[:manage_service] && params[:enabled]) ? 'running' : 'stopped',
|
|
:name => platform_params[:agent_service_name],
|
|
:enable => params[:enabled],
|
|
:hasstatus => true,
|
|
:hasrestart => true,
|
|
:tag => 'ceilometer-service',
|
|
)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with disabled service managing' do
|
|
before do
|
|
params.merge!({
|
|
:manage_service => false,
|
|
:enabled => false })
|
|
end
|
|
|
|
it 'configures ceilometer-agent-compute service' do
|
|
is_expected.to contain_service('ceilometer-agent-compute').with(
|
|
:ensure => nil,
|
|
:name => platform_params[:agent_service_name],
|
|
:enable => false,
|
|
:hasstatus => true,
|
|
:hasrestart => true,
|
|
:tag => 'ceilometer-service',
|
|
)
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
context 'on Debian platforms' do
|
|
let :facts do
|
|
@default_facts.merge({ :osfamily => 'Debian' })
|
|
end
|
|
|
|
let :platform_params do
|
|
{ :agent_package_name => 'ceilometer-agent-compute',
|
|
:agent_service_name => 'ceilometer-agent-compute' }
|
|
end
|
|
|
|
context 'on Ubuntu operating systems' do
|
|
before do
|
|
facts.merge!( :operatingsystem => 'Ubuntu' )
|
|
platform_params.merge!( :libvirt_group => 'libvirtd' )
|
|
end
|
|
|
|
it_configures 'ceilometer-agent-compute'
|
|
end
|
|
|
|
context 'on other operating systems' do
|
|
before do
|
|
platform_params.merge!( :libvirt_group => 'libvirt' )
|
|
end
|
|
|
|
it_configures 'ceilometer-agent-compute'
|
|
end
|
|
end
|
|
|
|
context 'on RedHat platforms' do
|
|
let :facts do
|
|
@default_facts.merge({ :osfamily => 'RedHat' })
|
|
end
|
|
|
|
let :platform_params do
|
|
{ :agent_package_name => 'openstack-ceilometer-compute',
|
|
:agent_service_name => 'openstack-ceilometer-compute' }
|
|
end
|
|
|
|
it_configures 'ceilometer-agent-compute'
|
|
end
|
|
end
|