51a9db9e95
... which were added during this cycle. Depends-on: https://review.opendev.org/874797 Change-Id: Icc563fd7f167a337b98be3c651463e0091efafdb
461 lines
16 KiB
Ruby
461 lines
16 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'neutron::server' do
|
|
let :pre_condition do
|
|
"class { 'neutron': }
|
|
class { 'neutron::keystone::authtoken':
|
|
password => 'passw0rd',
|
|
}"
|
|
end
|
|
|
|
let :params do
|
|
{}
|
|
end
|
|
|
|
let :default_params do
|
|
{
|
|
:package_ensure => 'present',
|
|
:enabled => true,
|
|
:auth_strategy => 'keystone',
|
|
:sync_db => false,
|
|
}
|
|
end
|
|
|
|
shared_examples 'neutron::server' do
|
|
let :p do
|
|
default_params.merge(params)
|
|
end
|
|
|
|
it { should contain_class('neutron::db') }
|
|
it { should contain_class('neutron::params') }
|
|
it { should contain_class('neutron::policy') }
|
|
|
|
it 'installs neutron server package' do
|
|
if platform_params.has_key?(:server_package)
|
|
should contain_package('neutron-server').with(
|
|
:name => platform_params[:server_package],
|
|
:ensure => p[:package_ensure],
|
|
:tag => ['openstack', 'neutron-package'],
|
|
)
|
|
should contain_package('neutron-server').that_requires('Anchor[neutron::install::begin]')
|
|
should contain_package('neutron-server').that_notifies('Anchor[neutron::install::end]')
|
|
else
|
|
should contain_package('neutron').that_requires('Anchor[neutron::install::begin]')
|
|
should contain_package('neutron').that_notifies('Anchor[neutron::install::end]')
|
|
end
|
|
end
|
|
|
|
it 'configures neutron server service' do
|
|
if platform_params.has_key?(:server_service)
|
|
should contain_service('neutron-server').with(
|
|
:name => platform_params[:server_service],
|
|
:enable => true,
|
|
:ensure => 'running',
|
|
:tag => ['neutron-service', 'neutron-server-eventlet'],
|
|
)
|
|
should contain_service('neutron-server').that_subscribes_to('Anchor[neutron::service::begin]')
|
|
should contain_service('neutron-server').that_notifies('Anchor[neutron::service::end]')
|
|
else
|
|
should contain_service('neutron-api').with(
|
|
:name => platform_params[:api_service_name],
|
|
:enable => true,
|
|
:ensure => 'running',
|
|
:tag => ['neutron-service', 'neutron-server-eventlet'],
|
|
)
|
|
should contain_service('neutron-api').that_subscribes_to('Anchor[neutron::service::begin]')
|
|
should contain_service('neutron-api').that_notifies('Anchor[neutron::service::end]')
|
|
|
|
should contain_service('neutron-rpc-server').with(
|
|
:name => platform_params[:rpc_service_name],
|
|
:enable => true,
|
|
:ensure => 'running',
|
|
:tag => ['neutron-service'],
|
|
)
|
|
should contain_service('neutron-rpc-server').that_subscribes_to('Anchor[neutron::service::begin]')
|
|
should contain_service('neutron-rpc-server').that_notifies('Anchor[neutron::service::end]')
|
|
end
|
|
|
|
should_not contain_class('neutron::db::sync')
|
|
should contain_neutron_config('DEFAULT/api_workers').with_value(facts[:os_workers])
|
|
should contain_neutron_config('DEFAULT/rpc_workers').with_value(facts[:os_workers])
|
|
should contain_neutron_config('DEFAULT/rpc_state_report_workers').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/rpc_response_max_timeout').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/agent_down_time').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/enable_new_agents').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/network_scheduler_driver').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/router_scheduler_driver').with_value('<SERVICE DEFAULT>')
|
|
should contain_oslo__middleware('neutron_config').with(
|
|
:enable_proxy_headers_parsing => '<SERVICE DEFAULT>',
|
|
:max_request_body_size => '<SERVICE DEFAULT>',
|
|
)
|
|
should contain_neutron_config('ovs/integration_bridge').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('ovs/igmp_snooping_enable').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('ovs/igmp_flood').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('ovs/igmp_flood_reports').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('ovs/igmp_flood_unregistered').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/enable_default_route_ecmp').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/enable_default_route_bfd').with_value('<SERVICE DEFAULT>')
|
|
end
|
|
|
|
context 'with manage_service as false' do
|
|
before :each do
|
|
params.merge!(:manage_service => false)
|
|
end
|
|
|
|
it 'should not manage the service' do
|
|
if platform_params.has_key?(:server_service)
|
|
should_not contain_service('neutron-server')
|
|
else
|
|
should_not contain_service('neutron-api')
|
|
should_not contain_service('neutron-rpc-server')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with DVR enabled for new routers' do
|
|
before :each do
|
|
params.merge!(:router_distributed => true)
|
|
end
|
|
|
|
it 'should enable DVR for new routers' do
|
|
should contain_neutron_config('DEFAULT/router_distributed').with_value(true)
|
|
end
|
|
end
|
|
|
|
context 'with DVR disabled' do
|
|
before :each do
|
|
params.merge!(:enable_dvr => false)
|
|
end
|
|
|
|
it 'should disable DVR' do
|
|
should contain_neutron_config('DEFAULT/enable_dvr').with_value(false)
|
|
end
|
|
end
|
|
|
|
context 'with HA routers enabled' do
|
|
before :each do
|
|
params.merge!(
|
|
:l3_ha => true,
|
|
:max_l3_agents_per_router => 3,
|
|
)
|
|
end
|
|
|
|
it 'should enable HA routers' do
|
|
should contain_neutron_config('DEFAULT/l3_ha').with_value(true)
|
|
should contain_neutron_config('DEFAULT/max_l3_agents_per_router').with_value(3)
|
|
should contain_neutron_config('DEFAULT/l3_ha_net_cidr').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/l3_ha_network_type').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/l3_ha_network_physical_name').with_value('<SERVICE DEFAULT>')
|
|
end
|
|
end
|
|
|
|
context 'with HA routers disabled' do
|
|
before :each do
|
|
params.merge!(:l3_ha => false)
|
|
end
|
|
|
|
it 'should disable HA routers' do
|
|
should contain_neutron_config('DEFAULT/l3_ha').with_value(false)
|
|
should contain_neutron_config('DEFAULT/max_l3_agents_per_router').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/l3_ha_net_cidr').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/l3_ha_network_type').with_value('<SERVICE DEFAULT>')
|
|
should contain_neutron_config('DEFAULT/l3_ha_network_physical_name').with_value('<SERVICE DEFAULT>')
|
|
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 options' do
|
|
before :each do
|
|
params.merge!({
|
|
:l3_ha_network_type => 'vlan',
|
|
:l3_ha_network_physical_name => 'datacentre'
|
|
})
|
|
end
|
|
|
|
it 'should configure the HA routers options' do
|
|
should contain_neutron_config('DEFAULT/l3_ha_network_type').with_value('vlan')
|
|
should contain_neutron_config('DEFAULT/l3_ha_network_physical_name').with_value('datacentre')
|
|
end
|
|
end
|
|
|
|
context 'with allow_automatic_l3agent_failover in neutron.conf' do
|
|
it 'should configure allow_automatic_l3agent_failover' do
|
|
should contain_neutron_config('DEFAULT/allow_automatic_l3agent_failover').with_value('<SERVICE DEFAULT>')
|
|
end
|
|
end
|
|
|
|
context 'with allow_automatic_dhcp_failover in neutron.conf' do
|
|
it 'should configure allow_automatic_dhcp_failover' do
|
|
should contain_neutron_config('DEFAULT/allow_automatic_dhcp_failover').with_value('<SERVICE DEFAULT>')
|
|
end
|
|
end
|
|
|
|
context 'with network_auto_schedule in neutron.conf' do
|
|
it 'should configure network_auto_schedule' do
|
|
should contain_neutron_config('DEFAULT/network_auto_schedule').with_value('<SERVICE DEFAULT>')
|
|
end
|
|
end
|
|
|
|
context 'with a bad dhcp_load_type value' do
|
|
before :each do
|
|
params.merge!(:dhcp_load_type => 'badvalue')
|
|
end
|
|
|
|
it { should raise_error(Puppet::Error) }
|
|
end
|
|
|
|
context 'with multiple service providers' do
|
|
before :each do
|
|
params.merge!(
|
|
{ :service_providers => ['provider1', 'provider2'] }
|
|
)
|
|
end
|
|
|
|
it 'configures neutron.conf' do
|
|
should contain_neutron_config(
|
|
'service_providers/service_provider'
|
|
).with_value(['provider1', 'provider2'])
|
|
end
|
|
end
|
|
|
|
context 'with availability zone hints set' do
|
|
before :each do
|
|
params.merge!({
|
|
:dhcp_load_type => 'networks',
|
|
:router_scheduler_driver => 'neutron.scheduler.l3_agent_scheduler.AZLeastRoutersScheduler',
|
|
:network_scheduler_driver => 'neutron.scheduler.dhcp_agent_scheduler.AZAwareWeightScheduler',
|
|
:default_availability_zones => ['zone1', 'zone2']
|
|
})
|
|
end
|
|
|
|
it 'should configure neutron server for availability zones' do
|
|
should contain_neutron_config('DEFAULT/default_availability_zones').with_value('zone1,zone2')
|
|
should contain_neutron_config('DEFAULT/network_scheduler_driver').with_value('neutron.scheduler.dhcp_agent_scheduler.AZAwareWeightScheduler')
|
|
should contain_neutron_config('DEFAULT/router_scheduler_driver').with_value('neutron.scheduler.l3_agent_scheduler.AZLeastRoutersScheduler')
|
|
should contain_neutron_config('DEFAULT/dhcp_load_type').with_value('networks')
|
|
end
|
|
end
|
|
|
|
context 'with enable_proxy_headers_parsing' do
|
|
before :each do
|
|
params.merge!( :enable_proxy_headers_parsing => true )
|
|
end
|
|
|
|
it { should contain_oslo__middleware('neutron_config').with(
|
|
:enable_proxy_headers_parsing => true,
|
|
)}
|
|
end
|
|
|
|
context 'with max_request_body_size' do
|
|
before :each do
|
|
params.merge!( :max_request_body_size => '102400' )
|
|
end
|
|
|
|
it { should contain_oslo__middleware('neutron_config').with(
|
|
:max_request_body_size => '102400',
|
|
)}
|
|
end
|
|
|
|
context 'when running neutron-api in wsgi' do
|
|
before :each do
|
|
params.merge!(
|
|
:service_name => false,
|
|
:api_service_name => 'httpd',
|
|
:rpc_service_name => 'neutron-rpc-server',
|
|
)
|
|
end
|
|
|
|
let :pre_condition do
|
|
"class { 'neutron': }
|
|
include apache
|
|
class { 'neutron::keystone::authtoken':
|
|
password => 'passw0rd',
|
|
}"
|
|
end
|
|
|
|
it 'configures neutron-api service with Apache' do
|
|
if platform_params.has_key?(:server_service)
|
|
should contain_service('neutron-server').with(
|
|
:ensure => 'stopped',
|
|
:name => platform_params[:server_service],
|
|
:enable => false,
|
|
:tag => ['neutron-service'],
|
|
)
|
|
else
|
|
should contain_service('neutron-api').with(
|
|
:ensure => 'stopped',
|
|
:name => platform_params[:api_service_name],
|
|
:enable => false,
|
|
:tag => ['neutron-service'],
|
|
)
|
|
end
|
|
|
|
should contain_service('neutron-rpc-server').with(
|
|
:ensure => 'running',
|
|
:name => 'neutron-rpc-server',
|
|
:enable => true,
|
|
:tag => ['neutron-service'],
|
|
)
|
|
end
|
|
end
|
|
|
|
context 'when service_name is customized' do
|
|
before :each do
|
|
params.merge!({ :service_name => 'foobar' })
|
|
end
|
|
|
|
it 'configures neutron-api service with custom name' do
|
|
should contain_service('neutron-server').with(
|
|
:name => 'foobar',
|
|
:enable => true,
|
|
:ensure => 'running',
|
|
:tag => ['neutron-service'],
|
|
)
|
|
end
|
|
end
|
|
|
|
context 'with ovs_integration_bridge set' do
|
|
before :each do
|
|
params.merge!({:ovs_integration_bridge => 'br-int' })
|
|
end
|
|
|
|
it { should contain_neutron_config('ovs/integration_bridge').with_value('br-int') }
|
|
end
|
|
|
|
context 'with IGMP snooping enabled' do
|
|
before :each do
|
|
params.merge!(:igmp_snooping_enable => true)
|
|
end
|
|
|
|
it 'configure neutron.conf' do
|
|
should contain_neutron_config('ovs/igmp_snooping_enable').with_value(true)
|
|
end
|
|
end
|
|
|
|
context 'with IGMP flood enabled' do
|
|
before :each do
|
|
params.merge!({
|
|
:igmp_flood => true,
|
|
:igmp_flood_reports => true,
|
|
:igmp_flood_unregistered => true,
|
|
})
|
|
end
|
|
|
|
it 'configure neutron.conf' do
|
|
should contain_neutron_config('ovs/igmp_flood').with_value(true)
|
|
should contain_neutron_config('ovs/igmp_flood_reports').with_value(true)
|
|
should contain_neutron_config('ovs/igmp_flood_unregistered').with_value(true)
|
|
end
|
|
end
|
|
|
|
context 'with default route options' do
|
|
before :each do
|
|
params.merge!({
|
|
:enable_default_route_ecmp => false,
|
|
:enable_default_route_bfd => false,
|
|
})
|
|
end
|
|
|
|
it 'configure neutron.conf' do
|
|
should contain_neutron_config('DEFAULT/enable_default_route_ecmp').with_value(false)
|
|
should contain_neutron_config('DEFAULT/enable_default_route_bfd').with_value(false)
|
|
end
|
|
end
|
|
|
|
context 'with VPNaaS package installation' do
|
|
before do
|
|
params.merge!(
|
|
:ensure_vpnaas_package => true,
|
|
)
|
|
end
|
|
|
|
it 'should install VPNaaS package' do
|
|
should contain_package('neutron-vpnaas-agent').with(
|
|
:ensure => 'installed',
|
|
:name => platform_params[:vpnaas_agent_package],
|
|
:tag => ['openstack', 'neutron-package'],
|
|
)
|
|
end
|
|
end
|
|
|
|
context 'with Dynamic routing package installation' do
|
|
before do
|
|
params.merge!( :ensure_dr_package => true )
|
|
end
|
|
|
|
it 'should install dynamic routing package' do
|
|
should contain_package('neutron-dynamic-routing').with(
|
|
:ensure => 'installed',
|
|
:name => platform_params[:dynamic_routing_package],
|
|
:tag => ['openstack', 'neutron-package'],
|
|
)
|
|
end
|
|
end
|
|
|
|
context 'without database synchronization' do
|
|
before do
|
|
params.merge!(
|
|
:sync_db => true
|
|
)
|
|
end
|
|
|
|
it 'includes neutron::db::sync' do
|
|
should contain_class('neutron::db::sync')
|
|
end
|
|
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())
|
|
end
|
|
|
|
let (:platform_params) do
|
|
case facts[:os]['family']
|
|
when 'Debian'
|
|
if facts[:os]['name'] == 'Ubuntu'
|
|
{
|
|
:server_package => 'neutron-server',
|
|
:server_service => 'neutron-server',
|
|
:rpc_service_name => 'neutron-rpc-server',
|
|
:dynamic_routing_package => 'python3-neutron-dynamic-routing',
|
|
:vpnaas_agent_package => 'python3-neutron-vpnaas',
|
|
}
|
|
else
|
|
{
|
|
:api_service_name => 'neutron-api',
|
|
:rpc_service_name => 'neutron-rpc-server',
|
|
:dynamic_routing_package => 'python3-neutron-dynamic-routing',
|
|
:vpnaas_agent_package => 'python3-neutron-vpnaas',
|
|
}
|
|
end
|
|
when 'RedHat'
|
|
{
|
|
:server_service => 'neutron-server',
|
|
:rpc_service_name => 'neutron-rpc-server',
|
|
:dynamic_routing_package => 'python3-neutron-dynamic-routing',
|
|
:vpnaas_agent_package => 'openstack-neutron-vpnaas',
|
|
}
|
|
end
|
|
end
|
|
|
|
it_behaves_like 'neutron::server'
|
|
end
|
|
end
|
|
end
|