+++ /dev/null
-require 'spec_helper'
-
-describe 'neutron::agents::ml2::linuxbridge' do
-
- let :pre_condition do
- "class { 'neutron': rabbit_password => 'passw0rd' }"
- end
-
- let :default_params do
- { :package_ensure => 'present',
- :enabled => true,
- :tunnel_types => [],
- :local_ip => false,
- :vxlan_group => '224.0.0.1',
- :vxlan_ttl => false,
- :vxlan_tos => false,
- :polling_interval => 2,
- :l2_population => false,
- :physical_interface_mappings => [],
- :firewall_driver => 'neutron.agent.linux.iptables_firewall.IptablesFirewallDriver' }
- end
-
- let :params do
- {}
- end
-
- shared_examples_for 'neutron plugin linuxbridge agent with ml2 plugin' do
-
- context 'with default parameters' do
- it { should contain_class('neutron::params') }
-
- it 'configures ml2_conf.ini' do
- should contain_neutron_plugin_linuxbridge('agent/polling_interval').with_value(default_params[:polling_interval])
- should contain_neutron_plugin_linuxbridge('linux_bridge/physical_interface_mappings').with_value(default_params[:physical_interface_mappings].join(','))
- should contain_neutron_plugin_linuxbridge('securitygroup/firewall_driver').with_value(default_params[:firewall_driver])
- end
-
- it 'installs neutron linuxbridge agent package' do
- if platform_params.has_key?(:linuxbridge_agent_package)
- linuxbridge_agent_package = platform_params[:linuxbridge_agent_package]
- else
- linuxbridge_agent_package = platform_params[:linuxbridge_server_package]
- end
-
- should contain_package('neutron-plugin-linuxbridge-agent').with(
- :name => linuxbridge_agent_package,
- :ensure => default_params[:package_ensure]
- )
-
- should contain_package('neutron-plugin-linuxbridge-agent').with_before(/Neutron_plugin_linuxbridge\[.+\]/)
- end
-
- it 'configures neutron linuxbridge agent service' do
- should contain_service('neutron-plugin-linuxbridge-agent').with(
- :name => platform_params[:linuxbridge_agent_service],
- :enable => true,
- :ensure => 'running',
- :require => 'Class[Neutron]'
- )
- end
-
- it 'does not configre VXLAN tunneling' do
- should contain_neutron_plugin_linuxbridge('vxlan/enable_vxlan').with_value(false)
- should contain_neutron_plugin_linuxbridge('vxlan/local_ip').with_ensure('absent')
- should contain_neutron_plugin_linuxbridge('vxlan/vxlan_group').with_ensure('absent')
- should contain_neutron_plugin_linuxbridge('vxlan/l2_population').with_ensure('absent')
- end
- end
-
- context 'with VXLAN tunneling enabled' do
- before do
- params.merge!({
- :tunnel_types => ['vxlan'],
- :local_ip => '192.168.0.10'
- })
- end
-
- context 'when providing all parameters' do
- it 'configures ml2_conf.ini' do
- should contain_neutron_plugin_linuxbridge('vxlan/enable_vxlan').with_value(true)
- should contain_neutron_plugin_linuxbridge('vxlan/local_ip').with_value(params[:local_ip])
- should contain_neutron_plugin_linuxbridge('vxlan/vxlan_group').with_value(default_params[:vxlan_group])
- should contain_neutron_plugin_linuxbridge('vxlan/vxlan_ttl').with_ensure('absent')
- should contain_neutron_plugin_linuxbridge('vxlan/vxlan_tos').with_ensure('absent')
- should contain_neutron_plugin_linuxbridge('vxlan/l2_population').with_value(default_params[:l2_population])
- end
- end
-
- context 'when not providing or overriding some parameters' do
- before do
- params.merge!({
- :vxlan_group => '224.0.0.2',
- :vxlan_ttl => 10,
- :vxlan_tos => 2,
- :l2_population => true,
- })
- end
-
- it 'configures ml2_conf.ini' do
- should contain_neutron_plugin_linuxbridge('vxlan/enable_vxlan').with_value(true)
- should contain_neutron_plugin_linuxbridge('vxlan/local_ip').with_value(params[:local_ip])
- should contain_neutron_plugin_linuxbridge('vxlan/vxlan_group').with_value(params[:vxlan_group])
- should contain_neutron_plugin_linuxbridge('vxlan/vxlan_ttl').with_value(params[:vxlan_ttl])
- should contain_neutron_plugin_linuxbridge('vxlan/vxlan_tos').with_value(params[:vxlan_tos])
- should contain_neutron_plugin_linuxbridge('vxlan/l2_population').with_value(params[:l2_population])
- end
- end
- end
-
- context 'when providing the physical_interface_mappings parameter' do
- before do
- params.merge!(:physical_interface_mappings => ['physnet0:eth0', 'physnet1:eth1'])
- end
-
- it 'configures physical interface mappings' do
- should contain_neutron_plugin_linuxbridge('linux_bridge/physical_interface_mappings').with_value(
- params[:physical_interface_mappings].join(',')
- )
- end
- end
-
- context 'with firewall_driver parameter set to false' do
- before :each do
- params.merge!(:firewall_driver => false)
- end
- it 'removes firewall driver configuration' do
- should contain_neutron_plugin_linuxbridge('securitygroup/firewall_driver').with_ensure('absent')
- end
- end
- end
-
- context 'on Debian platforms' do
- let :facts do
- { :osfamily => 'Debian' }
- end
-
- let :platform_params do
- { :linuxbridge_agent_package => 'neutron-plugin-linuxbridge-agent',
- :linuxbridge_agent_service => 'neutron-plugin-linuxbridge-agent' }
- end
-
- it_configures 'neutron plugin linuxbridge agent with ml2 plugin'
- end
-
- context 'on RedHat platforms' do
- let :facts do
- { :osfamily => 'RedHat' }
- end
-
- let :platform_params do
- { :linuxbridge_server_package => 'openstack-neutron-linuxbridge',
- :linuxbridge_agent_service => 'neutron-linuxbridge-agent' }
- end
-
- it_configures 'neutron plugin linuxbridge agent with ml2 plugin'
- end
-end