Ensure [DEFAULT] scheduler_driver is cleared by default
... otherwise the old setting can be left in manila.conf. This also refactors unit tests for the manila::share class. Change-Id: I30fa9fdc73164f898bf46d2983c807ec2bcd5451
This commit is contained in:
parent
be8585045a
commit
525aae76e8
@ -5,7 +5,7 @@
|
|||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
# [*scheduler_driver*]
|
# [*scheduler_driver*]
|
||||||
# (Optional) Description
|
# (Optional) Default scheduler driver to use
|
||||||
# Defaults to false.
|
# Defaults to false.
|
||||||
#
|
#
|
||||||
# [*package_ensure*]
|
# [*package_ensure*]
|
||||||
@ -34,6 +34,10 @@ class manila::scheduler (
|
|||||||
manila_config {
|
manila_config {
|
||||||
'DEFAULT/scheduler_driver': value => $scheduler_driver;
|
'DEFAULT/scheduler_driver': value => $scheduler_driver;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
manila_config {
|
||||||
|
'DEFAULT/scheduler_driver': value => $::os_service_default;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::manila::params::scheduler_package {
|
if $::manila::params::scheduler_package {
|
||||||
|
@ -2,20 +2,16 @@ require 'spec_helper'
|
|||||||
|
|
||||||
describe 'manila::scheduler' do
|
describe 'manila::scheduler' do
|
||||||
|
|
||||||
shared_examples_for 'manila::scheduler on Debian' do
|
shared_examples_for 'manila::scheduler' do
|
||||||
|
|
||||||
context 'with default parameters' do
|
context 'with default parameters' do
|
||||||
|
|
||||||
it { is_expected.to contain_class('manila::params') }
|
it { is_expected.to contain_class('manila::params') }
|
||||||
|
|
||||||
it { is_expected.to contain_package('manila-scheduler').with(
|
it { is_expected.to contain_manila_config('DEFAULT/scheduler_driver').with_value('<SERVICE DEFAULT>') }
|
||||||
:name => 'manila-scheduler',
|
|
||||||
:ensure => 'present',
|
|
||||||
:tag => ['openstack', 'manila-package'],
|
|
||||||
) }
|
|
||||||
|
|
||||||
it { is_expected.to contain_service('manila-scheduler').with(
|
it { is_expected.to contain_service('manila-scheduler').with(
|
||||||
:name => 'manila-scheduler',
|
:name => platform_params[:scheduler_service],
|
||||||
:enable => true,
|
:enable => true,
|
||||||
:ensure => 'running',
|
:ensure => 'running',
|
||||||
:hasstatus => true,
|
:hasstatus => true,
|
||||||
@ -26,18 +22,18 @@ describe 'manila::scheduler' do
|
|||||||
context 'with parameters' do
|
context 'with parameters' do
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{ :scheduler_driver => 'manila.scheduler.filter_scheduler.FilterScheduler',
|
{
|
||||||
:package_ensure => 'present'
|
:scheduler_driver => 'manila.scheduler.filter_scheduler.FilterScheduler',
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it { is_expected.to contain_manila_config('DEFAULT/scheduler_driver').with_value('manila.scheduler.filter_scheduler.FilterScheduler') }
|
it { is_expected.to contain_manila_config('DEFAULT/scheduler_driver').with_value('manila.scheduler.filter_scheduler.FilterScheduler') }
|
||||||
it { is_expected.to contain_package('manila-scheduler').with_ensure('present') }
|
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'with manage_service false' do
|
context 'with manage_service false' do
|
||||||
let :params do
|
let :params do
|
||||||
{ 'manage_service' => false
|
{
|
||||||
|
:manage_service => false
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
it 'should not configure the service' do
|
it 'should not configure the service' do
|
||||||
@ -46,28 +42,33 @@ describe 'manila::scheduler' do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'manila::scheduler on Debian' do
|
||||||
shared_examples_for 'manila::scheduler on RedHat' do
|
|
||||||
|
|
||||||
context 'with default parameters' do
|
context 'with default parameters' do
|
||||||
|
it { is_expected.to contain_package('manila-scheduler').with(
|
||||||
it { is_expected.to contain_class('manila::params') }
|
:name => 'manila-scheduler',
|
||||||
|
:ensure => 'present',
|
||||||
it { is_expected.to contain_service('manila-scheduler').with(
|
:tag => ['openstack', 'manila-package'],
|
||||||
:name => 'openstack-manila-scheduler',
|
|
||||||
:enable => true,
|
|
||||||
:ensure => 'running',
|
|
||||||
:tag => 'manila-service',
|
|
||||||
) }
|
) }
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'with parameters' do
|
context 'with parameters' do
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{ :scheduler_driver => 'manila.scheduler.filter_scheduler.FilterScheduler' }
|
{
|
||||||
|
:package_ensure => 'installed'
|
||||||
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it { is_expected.to contain_manila_config('DEFAULT/scheduler_driver').with_value('manila.scheduler.filter_scheduler.FilterScheduler') }
|
it { is_expected.to contain_package('manila-scheduler').with(
|
||||||
|
:name => 'manila-scheduler',
|
||||||
|
:ensure => 'installed',
|
||||||
|
:tag => ['openstack', 'manila-package'],
|
||||||
|
) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'manila::scheduler on RedHat' do
|
||||||
|
context 'with default parameters' do
|
||||||
|
it { is_expected.to_not contain_package('manila-scheduler') }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -76,8 +77,19 @@ describe 'manila::scheduler' do
|
|||||||
}).each do |os,facts|
|
}).each do |os,facts|
|
||||||
context "on #{os}" do
|
context "on #{os}" do
|
||||||
let (:facts) do
|
let (:facts) do
|
||||||
facts.merge!(OSDefaults.get_facts({ :fqdn => 'some.host.tld'}))
|
facts.merge!(OSDefaults.get_facts())
|
||||||
end
|
end
|
||||||
|
|
||||||
|
let :platform_params do
|
||||||
|
case facts[:osfamily]
|
||||||
|
when 'Debian'
|
||||||
|
{ :scheduler_service => 'manila-scheduler' }
|
||||||
|
when 'RedHat'
|
||||||
|
{ :scheduler_service => 'openstack-manila-scheduler' }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
it_behaves_like 'manila::scheduler'
|
||||||
it_behaves_like "manila::scheduler on #{facts[:osfamily]}"
|
it_behaves_like "manila::scheduler on #{facts[:osfamily]}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user