Expose parameter to customize [oslo_messaging_notifications] retry

The parameter has been managed by puppet-oslo, but its value could not
be set via this module.

Change-Id: I30b71bb4ecf654d54245bf9da7bcf0f19d110aca
This commit is contained in:
Takashi Kajinami 2024-09-30 12:15:13 +09:00
parent 96425f5fd5
commit 946b61df94
3 changed files with 20 additions and 6 deletions

View File

@ -150,7 +150,7 @@
# Defaults to $facts['os_service_default'] # Defaults to $facts['os_service_default']
# #
# [*notification_transport_url*] # [*notification_transport_url*]
# (optional) A URL representing the messaging driver to use for notifications # (Optional) A URL representing the messaging driver to use for notifications
# and its full configuration. Transport URLs take the form: # and its full configuration. Transport URLs take the form:
# transport://user:pass@host1:port[,hostN:portN]/virtual_host # transport://user:pass@host1:port[,hostN:portN]/virtual_host
# Defaults to $facts['os_service_default'] # Defaults to $facts['os_service_default']
@ -161,9 +161,14 @@
# Defaults to $facts['os_service_default'] # Defaults to $facts['os_service_default']
# #
# [*notification_topics*] # [*notification_topics*]
# (optional) AMQP topic used for OpenStack notifications # (Optional) AMQP topic used for OpenStack notifications
# Defaults to facts['os_service_default'] # Defaults to facts['os_service_default']
# #
# [*notification_retry*]
# (Optional) The maximum number of attempts to re-sent a notification
# message, which failed to be delivered due to a recoverable error.
# Defaults to $facts['os_service_default'].
#
# [*keystone_ec2_uri*] # [*keystone_ec2_uri*]
# (optional) Authentication Endpoint URI for ec2 service. # (optional) Authentication Endpoint URI for ec2 service.
# Defaults to facts['os_service_default'] # Defaults to facts['os_service_default']
@ -253,6 +258,7 @@ class heat(
$notification_transport_url = $facts['os_service_default'], $notification_transport_url = $facts['os_service_default'],
$notification_driver = $facts['os_service_default'], $notification_driver = $facts['os_service_default'],
$notification_topics = $facts['os_service_default'], $notification_topics = $facts['os_service_default'],
$notification_retry = $facts['os_service_default'],
$enable_proxy_headers_parsing = $facts['os_service_default'], $enable_proxy_headers_parsing = $facts['os_service_default'],
$max_request_body_size = $facts['os_service_default'], $max_request_body_size = $facts['os_service_default'],
Boolean $purge_config = false, Boolean $purge_config = false,
@ -320,6 +326,7 @@ class heat(
transport_url => $notification_transport_url, transport_url => $notification_transport_url,
driver => $notification_driver, driver => $notification_driver,
topics => $notification_topics, topics => $notification_topics,
retry => $notification_retry,
} }
oslo::messaging::default { 'heat_config': oslo::messaging::default { 'heat_config':

View File

@ -0,0 +1,4 @@
---
features:
- |
The new ``heat::notification_retry`` parameter has been added.

View File

@ -44,7 +44,7 @@ describe 'heat' do
it_configures 'without region_name set' it_configures 'without region_name set'
it_configures 'with enable_stack_adopt and enable_stack_abandon set' it_configures 'with enable_stack_adopt and enable_stack_abandon set'
it_configures 'with overridden messaging default parameters' it_configures 'with overridden messaging default parameters'
it_configures 'with notification_driver set to a string' it_configures 'with notification parameters'
end end
shared_examples_for 'a heat base installation' do shared_examples_for 'a heat base installation' do
@ -112,7 +112,8 @@ describe 'heat' do
is_expected.to contain_oslo__messaging__notifications('heat_config').with( is_expected.to contain_oslo__messaging__notifications('heat_config').with(
:driver => '<SERVICE DEFAULT>', :driver => '<SERVICE DEFAULT>',
:transport_url => '<SERVICE DEFAULT>', :transport_url => '<SERVICE DEFAULT>',
:topics => '<SERVICE DEFAULT>' :topics => '<SERVICE DEFAULT>',
:retry => '<SERVICE DEFAULT>',
) )
end end
@ -311,12 +312,13 @@ describe 'heat' do
end end
end end
shared_examples_for 'with notification_driver set to a string' do shared_examples_for 'with notification parameters' do
before do before do
params.merge!( params.merge!(
:notification_transport_url => 'rabbit://rabbit_user:password@localhost:5673', :notification_transport_url => 'rabbit://rabbit_user:password@localhost:5673',
:notification_driver => 'messagingv2', :notification_driver => 'messagingv2',
:notification_topics => 'notifications', :notification_topics => 'notifications',
:notification_retry => 10,
) )
end end
@ -324,7 +326,8 @@ describe 'heat' do
is_expected.to contain_oslo__messaging__notifications('heat_config').with( is_expected.to contain_oslo__messaging__notifications('heat_config').with(
:driver => 'messagingv2', :driver => 'messagingv2',
:transport_url => 'rabbit://rabbit_user:password@localhost:5673', :transport_url => 'rabbit://rabbit_user:password@localhost:5673',
:topics => 'notifications' :topics => 'notifications',
:retry => 10,
) )
end end
end end