Expose nova config option [workaround]/never_download_image_if_on_rbd

This exposes the nova workaround to disable downloading images from glance to
rbd (vs a cheap COW clone) when nova-compute and glance are not backed by the
same ceph cluster.

Related nova change: I069b6b1d28eaf1eee5c7fb8d0fdef9c0c229a1bf

Change-Id: I8329810d6c047c0d94e7b123e7cdc1263a7856cd
This commit is contained in:
Oliver Walsh 2020-10-21 16:33:29 +01:00
parent e2ebd2407d
commit 9f26045197
3 changed files with 19 additions and 3 deletions

View File

@ -328,6 +328,7 @@ class nova::compute (
include nova::deps include nova::deps
include nova::params include nova::params
include nova::workarounds
$cpu_shared_set_real = pick(join(any2array($cpu_shared_set), ','), $::os_service_default) $cpu_shared_set_real = pick(join(any2array($cpu_shared_set), ','), $::os_service_default)
$cpu_dedicated_set_real = pick(join(any2array($cpu_dedicated_set), ','), $::os_service_default) $cpu_dedicated_set_real = pick(join(any2array($cpu_dedicated_set), ','), $::os_service_default)

View File

@ -4,6 +4,11 @@
# #
# === Parameters: # === Parameters:
# #
# [*never_download_image_if_on_rbd*]
# (optional) refuse to boot an instance if it would require downloading from
# glance and uploading to ceph instead of a COW clone
# Defaults to $::os_service_default
#
# DEPRECATED # DEPRECATED
# #
# [*enable_numa_live_migration*] # [*enable_numa_live_migration*]
@ -11,6 +16,7 @@
# Defaults to undef # Defaults to undef
# #
class nova::workarounds ( class nova::workarounds (
$never_download_image_if_on_rbd = $::os_service_default,
# DEPRECATED PARAMETER # DEPRECATED PARAMETER
$enable_numa_live_migration = undef, $enable_numa_live_migration = undef,
) { ) {
@ -22,4 +28,8 @@ class nova::workarounds (
} }
} }
nova_config {
'workarounds/never_download_image_if_on_rbd': value => $never_download_image_if_on_rbd;
}
} }

View File

@ -9,15 +9,20 @@ describe 'nova::workarounds' do
shared_examples 'nova::workarounds' do shared_examples 'nova::workarounds' do
context 'with default parameters' do context 'with default parameters' do
it { is_expected.not_to contain_resources('nova_config') } it { is_expected.not_to contain_nova_config('workarounds/enable_numa_live_migration') }
it { is_expected.to contain_nova_config('workarounds/never_download_image_if_on_rbd').with_value('<SERVICE DEFAULT>') }
end end
context 'with overridden parameters' do context 'with overridden parameters' do
let :params do let :params do
{ :enable_numa_live_migration => true,} {
:enable_numa_live_migration => true,
:never_download_image_if_on_rbd => true
}
end end
it { is_expected.to contain_nova_config('workarounds/enable_numa_live_migration').with_value('true') } it { is_expected.to contain_nova_config('workarounds/enable_numa_live_migration').with_value('true') }
it { is_expected.to contain_nova_config('workarounds/never_download_image_if_on_rbd').with_value('true') }
end end
end end