Deprecate oslo.messaging rpc_backend option parameter

Oslo.messaging uses the transport_url to represent the rpc and
notification messaging driver to use and its full configuration. The
rpc_backend configuration option is deprecated for removal and
should not gate oslo.messaging driver configuration options.

This patch:
* deprecate rpc_backend
* remove conditional check
* update spec tests
* add release note

Change-Id: I1537c9e0db956d4271c8334a0aa543cd20c57e67
This commit is contained in:
Andrew Smith 2017-07-26 20:52:06 -04:00
parent 380353399e
commit a28c18cc00
3 changed files with 56 additions and 56 deletions

View File

@ -29,10 +29,6 @@
# option. # option.
# Defaults to $::os_service_default # Defaults to $::os_service_default
# #
# [*rpc_backend*]
# (Optional) Use these options to configure the message system.
# Defaults to $::os_service_default.
#
# [*rpc_response_timeout*] # [*rpc_response_timeout*]
# (Optional) Configure the timeout (in seconds) for rpc responses # (Optional) Configure the timeout (in seconds) for rpc responses
# Defaults to $::os_service_default. # Defaults to $::os_service_default.
@ -317,13 +313,16 @@
# (Optional) Virtual_host to use. # (Optional) Virtual_host to use.
# Defaults to $::os_service_default. # Defaults to $::os_service_default.
# #
# [*rpc_backend*]
# (Optional) Use these options to configure the message system.
# Defaults to $::os_service_default.
#
class heat( class heat(
$package_ensure = 'present', $package_ensure = 'present',
$debug = undef, $debug = undef,
$log_dir = undef, $log_dir = undef,
$keystone_ec2_uri = 'http://127.0.0.1:5000/v2.0/ec2tokens', $keystone_ec2_uri = 'http://127.0.0.1:5000/v2.0/ec2tokens',
$default_transport_url = $::os_service_default, $default_transport_url = $::os_service_default,
$rpc_backend = $::os_service_default,
$rpc_response_timeout = $::os_service_default, $rpc_response_timeout = $::os_service_default,
$control_exchange = $::os_service_default, $control_exchange = $::os_service_default,
$rabbit_ha_queues = $::os_service_default, $rabbit_ha_queues = $::os_service_default,
@ -389,6 +388,7 @@ class heat(
$rabbit_userid = $::os_service_default, $rabbit_userid = $::os_service_default,
$rabbit_password = $::os_service_default, $rabbit_password = $::os_service_default,
$rabbit_virtual_host = $::os_service_default, $rabbit_virtual_host = $::os_service_default,
$rpc_backend = $::os_service_default,
) { ) {
include ::heat::logging include ::heat::logging
@ -405,10 +405,12 @@ class heat(
!is_service_default($rabbit_password) or !is_service_default($rabbit_password) or
!is_service_default($rabbit_port) or !is_service_default($rabbit_port) or
!is_service_default($rabbit_userid) or !is_service_default($rabbit_userid) or
!is_service_default($rabbit_virtual_host) { !is_service_default($rabbit_virtual_host) or
!is_service_default($rpc_backend) {
warning("heat::rabbit_host, heat::rabbit_hosts, heat::rabbit_password, \ warning("heat::rabbit_host, heat::rabbit_hosts, heat::rabbit_password, \
heat::rabbit_port, heat::rabbit_userid and heat::rabbit_virtual_host are \ heat::rabbit_port, heat::rabbit_userid, heat::rabbit_virtual_host and \
deprecated. Please use heat::default_transport_url instead.") heat::rpc_backend are deprecated. Please use heat::default_transport_url \
instead.")
} }
package { 'heat-common': package { 'heat-common':
@ -421,51 +423,48 @@ deprecated. Please use heat::default_transport_url instead.")
purge => $purge_config, purge => $purge_config,
} }
if $rpc_backend == 'rabbit' or is_service_default($rpc_backend) { if $rabbit_heartbeat_timeout_threshold == 0 {
if $rabbit_heartbeat_timeout_threshold == 0 { warning('Default value for rabbit_heartbeat_timeout_threshold parameter is different from OpenStack project defaults')
warning('Default value for rabbit_heartbeat_timeout_threshold parameter is different from OpenStack project defaults')
}
oslo::messaging::rabbit { 'heat_config':
kombu_ssl_version => $kombu_ssl_version,
kombu_ssl_keyfile => $kombu_ssl_keyfile,
kombu_ssl_certfile => $kombu_ssl_certfile,
kombu_ssl_ca_certs => $kombu_ssl_ca_certs,
kombu_reconnect_delay => $kombu_reconnect_delay,
kombu_failover_strategy => $kombu_failover_strategy,
kombu_compression => $kombu_compression,
rabbit_userid => $rabbit_userid,
rabbit_password => $rabbit_password,
rabbit_virtual_host => $rabbit_virtual_host,
heartbeat_timeout_threshold => $rabbit_heartbeat_timeout_threshold,
heartbeat_rate => $rabbit_heartbeat_rate,
rabbit_use_ssl => $rabbit_use_ssl,
amqp_durable_queues => $amqp_durable_queues,
rabbit_host => $rabbit_host,
rabbit_port => $rabbit_port,
rabbit_hosts => $rabbit_hosts,
rabbit_ha_queues => $rabbit_ha_queues,
}
} }
elsif $rpc_backend == 'amqp' {
oslo::messaging::amqp { 'heat_config': oslo::messaging::rabbit { 'heat_config':
server_request_prefix => $amqp_server_request_prefix, kombu_ssl_version => $kombu_ssl_version,
broadcast_prefix => $amqp_broadcast_prefix, kombu_ssl_keyfile => $kombu_ssl_keyfile,
group_request_prefix => $amqp_group_request_prefix, kombu_ssl_certfile => $kombu_ssl_certfile,
container_name => $amqp_container_name, kombu_ssl_ca_certs => $kombu_ssl_ca_certs,
idle_timeout => $amqp_idle_timeout, kombu_reconnect_delay => $kombu_reconnect_delay,
trace => $amqp_trace, kombu_failover_strategy => $kombu_failover_strategy,
ssl_ca_file => $amqp_ssl_ca_file, kombu_compression => $kombu_compression,
ssl_cert_file => $amqp_ssl_cert_file, rabbit_userid => $rabbit_userid,
ssl_key_file => $amqp_ssl_key_file, rabbit_password => $rabbit_password,
ssl_key_password => $amqp_ssl_key_password, rabbit_virtual_host => $rabbit_virtual_host,
allow_insecure_clients => $amqp_allow_insecure_clients, heartbeat_timeout_threshold => $rabbit_heartbeat_timeout_threshold,
sasl_mechanisms => $amqp_sasl_mechanisms, heartbeat_rate => $rabbit_heartbeat_rate,
sasl_config_dir => $amqp_sasl_config_dir, rabbit_use_ssl => $rabbit_use_ssl,
sasl_config_name => $amqp_sasl_config_name, amqp_durable_queues => $amqp_durable_queues,
username => $amqp_username, rabbit_host => $rabbit_host,
password => $amqp_password, rabbit_port => $rabbit_port,
} rabbit_hosts => $rabbit_hosts,
rabbit_ha_queues => $rabbit_ha_queues,
}
oslo::messaging::amqp { 'heat_config':
server_request_prefix => $amqp_server_request_prefix,
broadcast_prefix => $amqp_broadcast_prefix,
group_request_prefix => $amqp_group_request_prefix,
container_name => $amqp_container_name,
idle_timeout => $amqp_idle_timeout,
trace => $amqp_trace,
ssl_ca_file => $amqp_ssl_ca_file,
ssl_cert_file => $amqp_ssl_cert_file,
ssl_key_file => $amqp_ssl_key_file,
ssl_key_password => $amqp_ssl_key_password,
allow_insecure_clients => $amqp_allow_insecure_clients,
sasl_mechanisms => $amqp_sasl_mechanisms,
sasl_config_dir => $amqp_sasl_config_dir,
sasl_config_name => $amqp_sasl_config_name,
username => $amqp_username,
password => $amqp_password,
} }
$auth_url = $::heat::keystone::authtoken::auth_url $auth_url = $::heat::keystone::authtoken::auth_url

View File

@ -0,0 +1,4 @@
---
deprecations:
- heat::rpc_backend is deprecated and will be removed in a future
release. Please use heat::default_transport_url instead.

View File

@ -68,7 +68,7 @@ describe 'heat' do
it_configures 'with overriden transport_url parameter' it_configures 'with overriden transport_url parameter'
it_configures 'with notification_driver set to a string' it_configures 'with notification_driver set to a string'
context 'with amqp rpc_backend value' do context 'with amqp messaging' do
it_configures 'amqp support' it_configures 'amqp support'
end end
end end
@ -459,8 +459,6 @@ describe 'heat' do
shared_examples_for 'amqp support' do shared_examples_for 'amqp support' do
context 'with default parameters' do context 'with default parameters' do
before { params.merge!( :rpc_backend => 'amqp' ) }
it { is_expected.to contain_heat_config('oslo_messaging_amqp/server_request_prefix').with_value('<SERVICE DEFAULT>') } it { is_expected.to contain_heat_config('oslo_messaging_amqp/server_request_prefix').with_value('<SERVICE DEFAULT>') }
it { is_expected.to contain_heat_config('oslo_messaging_amqp/broadcast_prefix').with_value('<SERVICE DEFAULT>') } it { is_expected.to contain_heat_config('oslo_messaging_amqp/broadcast_prefix').with_value('<SERVICE DEFAULT>') }
it { is_expected.to contain_heat_config('oslo_messaging_amqp/group_request_prefix').with_value('<SERVICE DEFAULT>') } it { is_expected.to contain_heat_config('oslo_messaging_amqp/group_request_prefix').with_value('<SERVICE DEFAULT>') }
@ -481,7 +479,6 @@ describe 'heat' do
context 'with overriden amqp parameters' do context 'with overriden amqp parameters' do
before { params.merge!( before { params.merge!(
:rpc_backend => 'amqp',
:amqp_idle_timeout => '60', :amqp_idle_timeout => '60',
:amqp_trace => true, :amqp_trace => true,
:amqp_ssl_ca_file => '/path/to/ca.cert', :amqp_ssl_ca_file => '/path/to/ca.cert',