puppet-cinder/spec/classes/cinder_db_sync_spec.rb
ZhongShengping 0f2219c5ef Allow db sync timeouts to be configurable
As Openstack projects continue to have longer database migration
chains, the Puppet default timeout of 300 seconds for an execution
is becoming too short a duration on some hardware, leading to timeouts.
As projects continue to add more migration scripts without pruning
the base, timeouts will continue to become more frequent unless
this time can be expanded.

Change-Id: I02fcb369f9435c729081aa7b0d5682da83d8446d
Closes-Bug: #1904962
2020-11-23 09:27:52 +08:00

69 lines
2.0 KiB
Ruby

require 'spec_helper'
describe 'cinder::db::sync' do
shared_examples 'cinder-dbsync' do
it { is_expected.to contain_class('cinder::deps') }
it 'runs cinder-manage db_sync' do
is_expected.to contain_exec('cinder-manage db_sync').with(
:command => 'cinder-manage db sync',
:user => 'cinder',
:path => ['/bin', '/usr/bin'],
:refreshonly => 'true',
:try_sleep => 5,
:tries => 10,
:timeout => 300,
:logoutput => 'on_failure',
:subscribe => ['Anchor[cinder::install::end]',
'Anchor[cinder::config::end]',
'Anchor[cinder::dbsync::begin]'],
:notify => 'Anchor[cinder::dbsync::end]',
:tag => 'openstack-db',
)
end
context "overriding params" do
let :params do
{
:extra_params => '--config-file /etc/cinder/cinder.conf',
:db_sync_timeout => 750,
}
end
it {
is_expected.to contain_exec('cinder-manage db_sync').with(
:command => 'cinder-manage --config-file /etc/cinder/cinder.conf db sync',
:user => 'cinder',
:path => ['/bin', '/usr/bin'],
:refreshonly => 'true',
:try_sleep => 5,
:tries => 10,
:timeout => 750,
:logoutput => 'on_failure',
:subscribe => ['Anchor[cinder::install::end]',
'Anchor[cinder::config::end]',
'Anchor[cinder::dbsync::begin]'],
:notify => 'Anchor[cinder::dbsync::end]',
:tag => 'openstack-db',
)
}
end
end
on_supported_os({
:supported_os => OSDefaults.get_supported_os
}).each do |os,facts|
context "on #{os}" do
let (:facts) do
facts.merge(OSDefaults.get_facts({
:os_workers => 8,
:concat_basedir => '/var/lib/puppet/concat'
}))
end
it_behaves_like 'cinder-dbsync'
end
end
end