Enable DVR + HA support
Juno brings two new big features: - distributed routers - router high availability This patchs aims to allow the users to configure DVR and/or HA routers. Signed-off-by: Emilien Macchi <emilien.macchi@enovance.com> Change-Id: Iaab5ab7e63f2627381ca1d5bb1cfd836433d734e
This commit is contained in:
parent
dcd122e477
commit
c4aafdd3b3
@ -76,6 +76,29 @@
|
|||||||
# (optional) namespaces can be deleted cleanly on the host running the L3 agent
|
# (optional) namespaces can be deleted cleanly on the host running the L3 agent
|
||||||
# Defaults to False
|
# Defaults to False
|
||||||
#
|
#
|
||||||
|
# [*ha_enabled*]
|
||||||
|
# (optional) Enabled or not HA for L3 agent.
|
||||||
|
# Defaults to false
|
||||||
|
#
|
||||||
|
# [*ha_vrrp_auth_type*]
|
||||||
|
# (optional) VRRP authentication type. Can be AH or PASS.
|
||||||
|
# Defaults to "PASS"
|
||||||
|
#
|
||||||
|
# [*ha_vrrp_auth_password*]
|
||||||
|
# (optional) VRRP authentication password. Required if ha_enabled = true.
|
||||||
|
# Defaults to undef
|
||||||
|
#
|
||||||
|
# [*ha_vrrp_advert_int*]
|
||||||
|
# (optional) The advertisement interval in seconds.
|
||||||
|
# Defaults to '2'
|
||||||
|
#
|
||||||
|
# [*agent_mode*]
|
||||||
|
# (optional) The working mode for the agent.
|
||||||
|
# 'legacy': default behavior (without DVR)
|
||||||
|
# 'dvr': enable DVR for an L3 agent running on compute node (DVR in production)
|
||||||
|
# 'dvr_snat': enable DVR with centralized SNAT support (DVR for single-host, for testing only)
|
||||||
|
# Defaults to 'legacy'
|
||||||
|
#
|
||||||
class neutron::agents::l3 (
|
class neutron::agents::l3 (
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
@ -93,7 +116,12 @@ class neutron::agents::l3 (
|
|||||||
$periodic_fuzzy_delay = '5',
|
$periodic_fuzzy_delay = '5',
|
||||||
$enable_metadata_proxy = true,
|
$enable_metadata_proxy = true,
|
||||||
$network_device_mtu = undef,
|
$network_device_mtu = undef,
|
||||||
$router_delete_namespaces = false
|
$router_delete_namespaces = false,
|
||||||
|
$ha_enabled = false,
|
||||||
|
$ha_vrrp_auth_type = 'PASS',
|
||||||
|
$ha_vrrp_auth_password = undef,
|
||||||
|
$ha_vrrp_advert_int = '3',
|
||||||
|
$agent_mode = 'legacy',
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include neutron::params
|
include neutron::params
|
||||||
@ -101,6 +129,14 @@ class neutron::agents::l3 (
|
|||||||
Neutron_config<||> ~> Service['neutron-l3']
|
Neutron_config<||> ~> Service['neutron-l3']
|
||||||
Neutron_l3_agent_config<||> ~> Service['neutron-l3']
|
Neutron_l3_agent_config<||> ~> Service['neutron-l3']
|
||||||
|
|
||||||
|
if $ha_enabled {
|
||||||
|
neutron_l3_agent_config {
|
||||||
|
'DEFAULT/ha_vrrp_auth_type': value => $ha_vrrp_auth_type;
|
||||||
|
'DEFAULT/ha_vrrp_auth_password': value => $ha_vrrp_auth_password;
|
||||||
|
'DEFAULT/ha_vrrp_advert_int': value => $ha_vrrp_advert_int;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
neutron_l3_agent_config {
|
neutron_l3_agent_config {
|
||||||
'DEFAULT/debug': value => $debug;
|
'DEFAULT/debug': value => $debug;
|
||||||
'DEFAULT/external_network_bridge': value => $external_network_bridge;
|
'DEFAULT/external_network_bridge': value => $external_network_bridge;
|
||||||
@ -115,6 +151,7 @@ class neutron::agents::l3 (
|
|||||||
'DEFAULT/periodic_fuzzy_delay': value => $periodic_fuzzy_delay;
|
'DEFAULT/periodic_fuzzy_delay': value => $periodic_fuzzy_delay;
|
||||||
'DEFAULT/enable_metadata_proxy': value => $enable_metadata_proxy;
|
'DEFAULT/enable_metadata_proxy': value => $enable_metadata_proxy;
|
||||||
'DEFAULT/router_delete_namespaces': value => $router_delete_namespaces;
|
'DEFAULT/router_delete_namespaces': value => $router_delete_namespaces;
|
||||||
|
'DEFAULT/agent_mode': value => $agent_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
if $network_device_mtu {
|
if $network_device_mtu {
|
||||||
|
@ -83,21 +83,27 @@
|
|||||||
# (optional) Firewall driver for realizing neutron security group function.
|
# (optional) Firewall driver for realizing neutron security group function.
|
||||||
# Defaults to 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'.
|
# Defaults to 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'.
|
||||||
#
|
#
|
||||||
|
# [*enable_distributed_routing*]
|
||||||
|
# (optional) Set to True on L2 agents to enable support
|
||||||
|
# for distributed virtual routing.
|
||||||
|
# Defaults to false
|
||||||
|
#
|
||||||
class neutron::agents::ml2::ovs (
|
class neutron::agents::ml2::ovs (
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$bridge_uplinks = [],
|
$bridge_uplinks = [],
|
||||||
$bridge_mappings = [],
|
$bridge_mappings = [],
|
||||||
$integration_bridge = 'br-int',
|
$integration_bridge = 'br-int',
|
||||||
$enable_tunneling = false,
|
$enable_tunneling = false,
|
||||||
$tunnel_types = [],
|
$tunnel_types = [],
|
||||||
$local_ip = false,
|
$local_ip = false,
|
||||||
$tunnel_bridge = 'br-tun',
|
$tunnel_bridge = 'br-tun',
|
||||||
$vxlan_udp_port = 4789,
|
$vxlan_udp_port = 4789,
|
||||||
$polling_interval = 2,
|
$polling_interval = 2,
|
||||||
$l2_population = false,
|
$l2_population = false,
|
||||||
$arp_responder = false,
|
$arp_responder = false,
|
||||||
$firewall_driver = 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'
|
$firewall_driver = 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver',
|
||||||
|
$enable_distributed_routing = false,
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include neutron::params
|
include neutron::params
|
||||||
@ -107,6 +113,10 @@ class neutron::agents::ml2::ovs (
|
|||||||
fail('Local ip for ovs agent must be set when tunneling is enabled')
|
fail('Local ip for ovs agent must be set when tunneling is enabled')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if $enable_distributed_routing and ! $l2_population {
|
||||||
|
fail('L2 population must be enabled when DVR is enabled')
|
||||||
|
}
|
||||||
|
|
||||||
Neutron_plugin_ml2<||> ~> Service['neutron-ovs-agent-service']
|
Neutron_plugin_ml2<||> ~> Service['neutron-ovs-agent-service']
|
||||||
|
|
||||||
if ($bridge_mappings != []) {
|
if ($bridge_mappings != []) {
|
||||||
@ -137,10 +147,11 @@ class neutron::agents::ml2::ovs (
|
|||||||
}
|
}
|
||||||
|
|
||||||
neutron_plugin_ml2 {
|
neutron_plugin_ml2 {
|
||||||
'agent/polling_interval': value => $polling_interval;
|
'agent/polling_interval': value => $polling_interval;
|
||||||
'agent/l2_population': value => $l2_population;
|
'agent/l2_population': value => $l2_population;
|
||||||
'agent/arp_responder': value => $arp_responder;
|
'agent/arp_responder': value => $arp_responder;
|
||||||
'ovs/integration_bridge': value => $integration_bridge;
|
'agent/enable_distributed_routing': value => $enable_distributed_routing;
|
||||||
|
'ovs/integration_bridge': value => $integration_bridge;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($firewall_driver) {
|
if ($firewall_driver) {
|
||||||
|
@ -153,44 +153,71 @@
|
|||||||
# [*mysql_module*]
|
# [*mysql_module*]
|
||||||
# (optional) Deprecated. Does nothing.
|
# (optional) Deprecated. Does nothing.
|
||||||
#
|
#
|
||||||
|
# [*router_distributed*]
|
||||||
|
# (optional) Setting the "router_distributed" flag to "True" will default to the creation
|
||||||
|
# of distributed tenant routers.
|
||||||
|
# Also can be the type of the router on the create request (admin-only attribute).
|
||||||
|
# Defaults to false
|
||||||
|
#
|
||||||
|
# [*l3_ha*]
|
||||||
|
# (optional) Enable high availability for virtual routers.
|
||||||
|
# Defaults to false
|
||||||
|
#
|
||||||
|
# [*max_l3_agents_per_router*]
|
||||||
|
# (optional) Maximum number of l3 agents which a HA router will be scheduled on. If set to '0', a router will be scheduled on every agent.
|
||||||
|
# Defaults to '3'
|
||||||
|
#
|
||||||
|
# [*min_l3_agents_per_router*]
|
||||||
|
# (optional) Minimum number of l3 agents which a HA router will be scheduled on.
|
||||||
|
# Defaults to '2'
|
||||||
|
#
|
||||||
|
# [*l3_ha_net_cidr*]
|
||||||
|
# (optional) CIDR of the administrative network if HA mode is enabled.
|
||||||
|
# Defaults to '169.254.192.0/18'
|
||||||
|
#
|
||||||
class neutron::server (
|
class neutron::server (
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$manage_service = true,
|
$manage_service = true,
|
||||||
$auth_password = false,
|
$auth_password = false,
|
||||||
$auth_type = 'keystone',
|
$auth_type = 'keystone',
|
||||||
$auth_host = 'localhost',
|
$auth_host = 'localhost',
|
||||||
$auth_port = '35357',
|
$auth_port = '35357',
|
||||||
$auth_admin_prefix = false,
|
$auth_admin_prefix = false,
|
||||||
$auth_tenant = 'services',
|
$auth_tenant = 'services',
|
||||||
$auth_user = 'neutron',
|
$auth_user = 'neutron',
|
||||||
$auth_protocol = 'http',
|
$auth_protocol = 'http',
|
||||||
$auth_uri = false,
|
$auth_uri = false,
|
||||||
$database_connection = 'sqlite:////var/lib/neutron/ovs.sqlite',
|
$database_connection = 'sqlite:////var/lib/neutron/ovs.sqlite',
|
||||||
$database_max_retries = 10,
|
$database_max_retries = 10,
|
||||||
$database_idle_timeout = 3600,
|
$database_idle_timeout = 3600,
|
||||||
$database_retry_interval = 10,
|
$database_retry_interval = 10,
|
||||||
$database_min_pool_size = 1,
|
$database_min_pool_size = 1,
|
||||||
$database_max_pool_size = 10,
|
$database_max_pool_size = 10,
|
||||||
$database_max_overflow = 20,
|
$database_max_overflow = 20,
|
||||||
$sync_db = false,
|
$sync_db = false,
|
||||||
$api_workers = $::processorcount,
|
$api_workers = $::processorcount,
|
||||||
$rpc_workers = $::processorcount,
|
$rpc_workers = $::processorcount,
|
||||||
$agent_down_time = '75',
|
$agent_down_time = '75',
|
||||||
$router_scheduler_driver = 'neutron.scheduler.l3_agent_scheduler.ChanceScheduler',
|
$router_scheduler_driver = 'neutron.scheduler.l3_agent_scheduler.ChanceScheduler',
|
||||||
|
$router_distributed = false,
|
||||||
|
$l3_ha = false,
|
||||||
|
$max_l3_agents_per_router = 3,
|
||||||
|
$min_l3_agents_per_router = 2,
|
||||||
|
$l3_ha_net_cidr = '169.254.192.0/18',
|
||||||
# DEPRECATED PARAMETERS
|
# DEPRECATED PARAMETERS
|
||||||
$mysql_module = undef,
|
$mysql_module = undef,
|
||||||
$sql_connection = undef,
|
$sql_connection = undef,
|
||||||
$connection = undef,
|
$connection = undef,
|
||||||
$sql_max_retries = undef,
|
$sql_max_retries = undef,
|
||||||
$max_retries = undef,
|
$max_retries = undef,
|
||||||
$sql_idle_timeout = undef,
|
$sql_idle_timeout = undef,
|
||||||
$idle_timeout = undef,
|
$idle_timeout = undef,
|
||||||
$sql_reconnect_interval = undef,
|
$sql_reconnect_interval = undef,
|
||||||
$retry_interval = undef,
|
$retry_interval = undef,
|
||||||
$log_dir = undef,
|
$log_dir = undef,
|
||||||
$log_file = undef,
|
$log_file = undef,
|
||||||
$report_interval = undef,
|
$report_interval = undef,
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include neutron::params
|
include neutron::params
|
||||||
@ -200,6 +227,19 @@ class neutron::server (
|
|||||||
Neutron_config<||> ~> Service['neutron-server']
|
Neutron_config<||> ~> Service['neutron-server']
|
||||||
Neutron_api_config<||> ~> Service['neutron-server']
|
Neutron_api_config<||> ~> Service['neutron-server']
|
||||||
|
|
||||||
|
if $l3_ha {
|
||||||
|
if $min_l3_agents_per_router <= $max_l3_agents_per_router or $max_l3_agents_per_router == '0' {
|
||||||
|
neutron_config {
|
||||||
|
'DEFAULT/ha_enabled': value => true;
|
||||||
|
'DEFAULT/max_l3_agents_per_router': value => $max_l3_agents_per_router;
|
||||||
|
'DEFAULT/min_l3_agents_per_router': value => $min_l3_agents_per_router;
|
||||||
|
'DEFAULT/l3_ha_net_cidr': value => $l3_ha_net_cidr;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
fail('min_l3_agents_per_router should be less than or equal to max_l3_agents_per_router.')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if $mysql_module {
|
if $mysql_module {
|
||||||
warning('The mysql_module parameter is deprecated. The latest 2.x mysql module will be used.')
|
warning('The mysql_module parameter is deprecated. The latest 2.x mysql module will be used.')
|
||||||
}
|
}
|
||||||
@ -296,6 +336,7 @@ class neutron::server (
|
|||||||
'DEFAULT/rpc_workers': value => $rpc_workers;
|
'DEFAULT/rpc_workers': value => $rpc_workers;
|
||||||
'DEFAULT/agent_down_time': value => $agent_down_time;
|
'DEFAULT/agent_down_time': value => $agent_down_time;
|
||||||
'DEFAULT/router_scheduler_driver': value => $router_scheduler_driver;
|
'DEFAULT/router_scheduler_driver': value => $router_scheduler_driver;
|
||||||
|
'DEFAULT/router_distributed': value => $router_distributed;
|
||||||
'database/connection': value => $database_connection_real, secret => true;
|
'database/connection': value => $database_connection_real, secret => true;
|
||||||
'database/idle_timeout': value => $database_idle_timeout_real;
|
'database/idle_timeout': value => $database_idle_timeout_real;
|
||||||
'database/retry_interval': value => $database_retry_interval_real;
|
'database/retry_interval': value => $database_retry_interval_real;
|
||||||
|
@ -22,7 +22,12 @@ describe 'neutron::agents::l3' do
|
|||||||
:periodic_fuzzy_delay => '5',
|
:periodic_fuzzy_delay => '5',
|
||||||
:enable_metadata_proxy => true,
|
:enable_metadata_proxy => true,
|
||||||
:network_device_mtu => nil,
|
:network_device_mtu => nil,
|
||||||
:router_delete_namespaces => false }
|
:router_delete_namespaces => false,
|
||||||
|
:ha_enabled => false,
|
||||||
|
:ha_vrrp_auth_type => 'PASS',
|
||||||
|
:ha_vrrp_auth_password => nil,
|
||||||
|
:ha_vrrp_advert_int => '3',
|
||||||
|
:agent_mode => 'legacy' }
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
@ -83,6 +88,27 @@ describe 'neutron::agents::l3' do
|
|||||||
should contain_service('neutron-l3').without_ensure
|
should contain_service('neutron-l3').without_ensure
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'with DVR' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:agent_mode => 'dvr')
|
||||||
|
end
|
||||||
|
it 'should enable DVR mode' do
|
||||||
|
should contain_neutron_l3_agent_config('DEFAULT/agent_mode').with_value(p[:agent_mode])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with HA routers' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:ha_enabled => true,
|
||||||
|
:ha_vrrp_auth_password => 'secrete')
|
||||||
|
end
|
||||||
|
it 'should configure VRRP' do
|
||||||
|
should contain_neutron_l3_agent_config('DEFAULT/ha_vrrp_auth_type').with_value(p[:ha_vrrp_auth_type])
|
||||||
|
should contain_neutron_l3_agent_config('DEFAULT/ha_vrrp_auth_password').with_value(p[:ha_vrrp_auth_password])
|
||||||
|
should contain_neutron_l3_agent_config('DEFAULT/ha_vrrp_advert_int').with_value(p[:ha_vrrp_advert_int])
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'neutron l3 agent with network_device_mtu specified' do
|
shared_examples_for 'neutron l3 agent with network_device_mtu specified' do
|
||||||
|
@ -7,18 +7,19 @@ describe 'neutron::agents::ml2::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :default_params do
|
let :default_params do
|
||||||
{ :package_ensure => 'present',
|
{ :package_ensure => 'present',
|
||||||
:enabled => true,
|
:enabled => true,
|
||||||
:bridge_uplinks => [],
|
:bridge_uplinks => [],
|
||||||
:bridge_mappings => [],
|
:bridge_mappings => [],
|
||||||
:integration_bridge => 'br-int',
|
:integration_bridge => 'br-int',
|
||||||
:enable_tunneling => false,
|
:enable_tunneling => false,
|
||||||
:local_ip => false,
|
:local_ip => false,
|
||||||
:tunnel_bridge => 'br-tun',
|
:tunnel_bridge => 'br-tun',
|
||||||
:polling_interval => 2,
|
:polling_interval => 2,
|
||||||
:l2_population => false,
|
:l2_population => false,
|
||||||
:arp_responder => false,
|
:arp_responder => false,
|
||||||
:firewall_driver => 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver' }
|
:enable_distributed_routing => false,
|
||||||
|
:firewall_driver => 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver' }
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
@ -90,6 +91,16 @@ describe 'neutron::agents::ml2::ovs' do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'when enabling DVR' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:enable_distributed_routing => true,
|
||||||
|
:l2_population => true )
|
||||||
|
end
|
||||||
|
it 'should enable DVR' do
|
||||||
|
should contain_neutron_plugin_ml2('agent/enable_distributed_routing').with_value(true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context 'when supplying bridge mappings for provider networks' do
|
context 'when supplying bridge mappings for provider networks' do
|
||||||
before :each do
|
before :each do
|
||||||
params.merge!(:bridge_uplinks => ['br-ex:eth2'],:bridge_mappings => ['default:br-ex'])
|
params.merge!(:bridge_uplinks => ['br-ex:eth2'],:bridge_mappings => ['default:br-ex'])
|
||||||
@ -151,6 +162,18 @@ describe 'neutron::agents::ml2::ovs' do
|
|||||||
should contain_neutron_plugin_ml2('agent/vxlan_udp_port').with_value(params[:vxlan_udp_port])
|
should contain_neutron_plugin_ml2('agent/vxlan_udp_port').with_value(params[:vxlan_udp_port])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'when l2 population is disabled and DVR enabled' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:enable_distributed_routing => true,
|
||||||
|
:l2_population => false )
|
||||||
|
end
|
||||||
|
it 'should fail' do
|
||||||
|
expect do
|
||||||
|
subject
|
||||||
|
end.to raise_error(Puppet::Error, /L2 population must be enabled when DVR is enabled/)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -12,23 +12,28 @@ describe 'neutron::server' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :default_params do
|
let :default_params do
|
||||||
{ :package_ensure => 'present',
|
{ :package_ensure => 'present',
|
||||||
:enabled => true,
|
:enabled => true,
|
||||||
:auth_type => 'keystone',
|
:auth_type => 'keystone',
|
||||||
:auth_host => 'localhost',
|
:auth_host => 'localhost',
|
||||||
:auth_port => '35357',
|
:auth_port => '35357',
|
||||||
:auth_tenant => 'services',
|
:auth_tenant => 'services',
|
||||||
:auth_user => 'neutron',
|
:auth_user => 'neutron',
|
||||||
:database_connection => 'sqlite:////var/lib/neutron/ovs.sqlite',
|
:database_connection => 'sqlite:////var/lib/neutron/ovs.sqlite',
|
||||||
:database_max_retries => '10',
|
:database_max_retries => '10',
|
||||||
:database_idle_timeout => '3600',
|
:database_idle_timeout => '3600',
|
||||||
:database_retry_interval => '10',
|
:database_retry_interval => '10',
|
||||||
:database_min_pool_size => '1',
|
:database_min_pool_size => '1',
|
||||||
:database_max_pool_size => '10',
|
:database_max_pool_size => '10',
|
||||||
:database_max_overflow => '20',
|
:database_max_overflow => '20',
|
||||||
:sync_db => false,
|
:sync_db => false,
|
||||||
:agent_down_time => '75',
|
:agent_down_time => '75',
|
||||||
:router_scheduler_driver => 'neutron.scheduler.l3_agent_scheduler.ChanceScheduler',
|
:router_scheduler_driver => 'neutron.scheduler.l3_agent_scheduler.ChanceScheduler',
|
||||||
|
:router_distributed => false,
|
||||||
|
:l3_ha => false,
|
||||||
|
:max_l3_agents_per_router => '3',
|
||||||
|
:min_l3_agents_per_router => '2',
|
||||||
|
:l3_ha_net_cidr => '169.254.192.0/18'
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -100,6 +105,48 @@ describe 'neutron::server' do
|
|||||||
should contain_service('neutron-server').without_ensure
|
should contain_service('neutron-server').without_ensure
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'with DVR enabled' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:router_distributed => true)
|
||||||
|
end
|
||||||
|
it 'should enable DVR' do
|
||||||
|
should contain_neutron_config('DEFAULT/router_distributed').with_value(true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with HA routers enabled' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:l3_ha => true)
|
||||||
|
end
|
||||||
|
it 'should enable HA routers' do
|
||||||
|
should contain_neutron_config('DEFAULT/ha_enabled').with_value(true)
|
||||||
|
should contain_neutron_config('DEFAULT/max_l3_agents_per_router').with_value('3')
|
||||||
|
should contain_neutron_config('DEFAULT/min_l3_agents_per_router').with_value('2')
|
||||||
|
should contain_neutron_config('DEFAULT/l3_ha_net_cidr').with_value('169.254.192.0/18')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with HA routers enabled with unlimited l3 agents per router' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:l3_ha => true,
|
||||||
|
:max_l3_agents_per_router => '0' )
|
||||||
|
end
|
||||||
|
it 'should enable HA routers' do
|
||||||
|
should contain_neutron_config('DEFAULT/max_l3_agents_per_router').with_value('0')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with HA routers enabled and wrong parameters' do
|
||||||
|
before :each do
|
||||||
|
params.merge!(:l3_ha => true,
|
||||||
|
:max_l3_agents_per_router => '2',
|
||||||
|
:min_l3_agents_per_router => '3' )
|
||||||
|
end
|
||||||
|
it 'should fail to configure HA routerd' do
|
||||||
|
expect { subject }.to raise_error(Puppet::Error, /min_l3_agents_per_router should be less than or equal to max_l3_agents_per_router./)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'a neutron server with auth_admin_prefix set' do
|
shared_examples_for 'a neutron server with auth_admin_prefix set' do
|
||||||
|
Loading…
x
Reference in New Issue
Block a user