
Prior to this change, we were incorrectly using merge! on the @default_facts. This would eventually lead to weird testing issues if @default_facts was ever reused within a test run. merge!(...) will update the @default_facts variable and we want to use merge(...) so that we are not updating the @default_facts variable. Change-Id: I55b518ee4af1a76ff5fc0e071410ccee5e4dfb34
79 lines
2.5 KiB
Ruby
79 lines
2.5 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'cinder::db' do
|
|
|
|
shared_examples 'cinder::db' do
|
|
|
|
context 'with default parameters' do
|
|
|
|
it { is_expected.to contain_cinder_config('database/connection').with_value('sqlite:////var/lib/cinder/cinder.sqlite').with_secret(true) }
|
|
it { is_expected.to contain_cinder_config('database/idle_timeout').with_value('<SERVICE DEFAULT>') }
|
|
it { is_expected.to contain_cinder_config('database/min_pool_size').with_value('<SERVICE DEFAULT>') }
|
|
it { is_expected.to contain_cinder_config('database/max_retries').with_value('<SERVICE DEFAULT>') }
|
|
it { is_expected.to contain_cinder_config('database/retry_interval').with_value('<SERVICE DEFAULT>') }
|
|
|
|
end
|
|
|
|
context 'with specific parameters' do
|
|
let :params do
|
|
{ :database_connection => 'mysql://cinder:cinder@localhost/cinder',
|
|
:database_idle_timeout => '3601',
|
|
:database_min_pool_size => '2',
|
|
:database_max_retries => '11',
|
|
:database_retry_interval => '11', }
|
|
end
|
|
|
|
it { is_expected.to contain_cinder_config('database/connection').with_value('mysql://cinder:cinder@localhost/cinder').with_secret(true) }
|
|
it { is_expected.to contain_cinder_config('database/idle_timeout').with_value('3601') }
|
|
it { is_expected.to contain_cinder_config('database/min_pool_size').with_value('2') }
|
|
it { is_expected.to contain_cinder_config('database/max_retries').with_value('11') }
|
|
it { is_expected.to contain_cinder_config('database/retry_interval').with_value('11') }
|
|
|
|
end
|
|
|
|
context 'with postgresql backend' do
|
|
let :params do
|
|
{ :database_connection => 'postgresql://cinder:cinder@localhost/cinder', }
|
|
end
|
|
|
|
it 'install the proper backend package' do
|
|
is_expected.to contain_package('python-psycopg2').with(:ensure => 'present')
|
|
end
|
|
|
|
end
|
|
|
|
context 'with incorrect database_connection string' do
|
|
let :params do
|
|
{ :database_connection => 'redis://cinder:cinder@localhost/cinder', }
|
|
end
|
|
|
|
it_raises 'a Puppet::Error', /validate_re/
|
|
end
|
|
|
|
end
|
|
|
|
context 'on Debian platforms' do
|
|
let :facts do
|
|
@default_facts.merge({
|
|
:osfamily => 'Debian',
|
|
:operatingsystem => 'Debian',
|
|
:operatingsystemrelease => 'jessie',
|
|
})
|
|
end
|
|
|
|
it_configures 'cinder::db'
|
|
end
|
|
|
|
context 'on Redhat platforms' do
|
|
let :facts do
|
|
@default_facts.merge({
|
|
:osfamily => 'RedHat',
|
|
:operatingsystemrelease => '7.1',
|
|
})
|
|
end
|
|
|
|
it_configures 'cinder::db'
|
|
end
|
|
|
|
end
|