305 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			305 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| require 'spec_helper'
 | |
| 
 | |
| describe 'neutron::agents::ml2::ovs' do
 | |
| 
 | |
|   let :pre_condition do
 | |
|     "class { 'neutron': rabbit_password => 'passw0rd' }"
 | |
|   end
 | |
| 
 | |
|   let :default_params do
 | |
|     { :package_ensure             => 'present',
 | |
|       :enabled                    => true,
 | |
|       :bridge_uplinks             => [],
 | |
|       :bridge_mappings            => [],
 | |
|       :integration_bridge         => 'br-int',
 | |
|       :enable_tunneling           => false,
 | |
|       :local_ip                   => false,
 | |
|       :tunnel_bridge              => 'br-tun',
 | |
|       :drop_flows_on_start        => false,
 | |
|       :firewall_driver            => 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver',
 | |
|       :manage_vswitch             => true,
 | |
|       }
 | |
|   end
 | |
| 
 | |
|   let :test_facts do
 | |
|     { :operatingsystem           => 'default',
 | |
|       :operatingsystemrelease    => 'default'
 | |
|     }
 | |
|   end
 | |
| 
 | |
|   let :params do
 | |
|     {}
 | |
|   end
 | |
| 
 | |
|   shared_examples_for 'neutron plugin ovs agent with ml2 plugin' do
 | |
|     let :p do
 | |
|       default_params.merge(params)
 | |
|     end
 | |
| 
 | |
|     it { is_expected.to contain_class('neutron::params') }
 | |
| 
 | |
|     it 'configures plugins/ml2/openvswitch_agent.ini' do
 | |
|       is_expected.to contain_neutron_agent_ovs('agent/polling_interval').with_value('<SERVICE DEFAULT>')
 | |
|       is_expected.to contain_neutron_agent_ovs('agent/l2_population').with_value('<SERVICE DEFAULT>')
 | |
|       is_expected.to contain_neutron_agent_ovs('agent/arp_responder').with_value('<SERVICE DEFAULT>')
 | |
|       is_expected.to contain_neutron_agent_ovs('agent/prevent_arp_spoofing').with_value('<SERVICE DEFAULT>')
 | |
|       is_expected.to contain_neutron_agent_ovs('agent/drop_flows_on_start').with_value(p[:drop_flows_on_start])
 | |
|       is_expected.to contain_neutron_agent_ovs('agent/extensions').with_value(['<SERVICE DEFAULT>'])
 | |
|       is_expected.to contain_neutron_agent_ovs('ovs/integration_bridge').with_value(p[:integration_bridge])
 | |
|       is_expected.to contain_neutron_agent_ovs('securitygroup/firewall_driver').\
 | |
|         with_value(p[:firewall_driver])
 | |
|       is_expected.to contain_neutron_agent_ovs('ovs/enable_tunneling').with_value(false)
 | |
|       is_expected.to contain_neutron_agent_ovs('ovs/tunnel_bridge').with_ensure('absent')
 | |
|       is_expected.to contain_neutron_agent_ovs('ovs/local_ip').with_ensure('absent')
 | |
|       is_expected.to contain_neutron_agent_ovs('ovs/int_peer_patch_port').with_ensure('absent')
 | |
|       is_expected.to contain_neutron_agent_ovs('ovs/tun_peer_patch_port').with_ensure('absent')
 | |
|     end
 | |
| 
 | |
|     it 'installs neutron ovs agent package' do
 | |
|       if platform_params.has_key?(:ovs_agent_package)
 | |
|         is_expected.to contain_package('neutron-ovs-agent').with(
 | |
|           :name   => platform_params[:ovs_agent_package],
 | |
|           :ensure => p[:package_ensure],
 | |
|           :tag    => ['openstack', 'neutron-package'],
 | |
|         )
 | |
|       else
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     it 'configures neutron ovs agent service' do
 | |
|       is_expected.to contain_service('neutron-ovs-agent-service').with(
 | |
|         :name    => platform_params[:ovs_agent_service],
 | |
|         :enable  => true,
 | |
|         :ensure  => 'running',
 | |
|         :require => 'Class[Neutron]',
 | |
|         :tag     => 'neutron-service',
 | |
|       )
 | |
|       is_expected.to contain_service('neutron-ovs-agent-service').that_subscribes_to( [ 'Package[neutron]', 'Package[neutron-ovs-agent]' ] )
 | |
|     end
 | |
| 
 | |
|     context 'with manage_service as false' do
 | |
|       before :each do
 | |
|         params.merge!(:manage_service => false)
 | |
|       end
 | |
|       it 'should not start/stop service' do
 | |
|         is_expected.to contain_service('neutron-ovs-agent-service').without_ensure
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when supplying a firewall driver' do
 | |
|       before :each do
 | |
|         params.merge!(:firewall_driver => false)
 | |
|       end
 | |
|       it 'should configure firewall driver' do
 | |
|         is_expected.to contain_neutron_agent_ovs('securitygroup/firewall_driver').with_ensure('absent')
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when enabling ARP responder' do
 | |
|       before :each do
 | |
|         params.merge!(:arp_responder => true)
 | |
|       end
 | |
|       it 'should enable ARP responder' do
 | |
|         is_expected.to contain_neutron_agent_ovs('agent/arp_responder').with_value(true)
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when disabling ARP Spoofing Protection' do
 | |
|       before :each do
 | |
|         params.merge!(:prevent_arp_spoofing => false)
 | |
|       end
 | |
|       it 'should disable ARP Spoofing Protection' do
 | |
|         is_expected.to contain_neutron_agent_ovs('agent/prevent_arp_spoofing').with_value(false)
 | |
|       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
 | |
|         is_expected.to contain_neutron_agent_ovs('agent/enable_distributed_routing').with_value(true)
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when supplying bridge mappings for provider networks' do
 | |
|       before :each do
 | |
|         params.merge!(:bridge_uplinks => ['br-ex:eth2'],:bridge_mappings => ['default:br-ex'])
 | |
|       end
 | |
| 
 | |
|       it 'should require vswitch::ovs' do
 | |
|         is_expected.to contain_class('vswitch::ovs')
 | |
|       end
 | |
| 
 | |
|       it 'configures bridge mappings' do
 | |
|         is_expected.to contain_neutron_agent_ovs('ovs/bridge_mappings')
 | |
|       end
 | |
| 
 | |
|       it 'should configure bridge mappings' do
 | |
|         is_expected.to contain_neutron__plugins__ovs__bridge(params[:bridge_mappings].join(',')).with(
 | |
|           :before => 'Service[neutron-ovs-agent-service]'
 | |
|         )
 | |
|       end
 | |
| 
 | |
|       it 'should configure bridge uplinks' do
 | |
|         is_expected.to contain_neutron__plugins__ovs__port(params[:bridge_uplinks].join(',')).with(
 | |
|           :before => 'Service[neutron-ovs-agent-service]'
 | |
|         )
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when supplying bridge mappings for provider networks with manage vswitch set to false' do
 | |
|       before :each do
 | |
|         params.merge!(:bridge_uplinks => ['br-ex:eth2'],:bridge_mappings => ['default:br-ex'], :manage_vswitch => false)
 | |
|       end
 | |
| 
 | |
|       it 'should not require vswitch::ovs' do
 | |
|         is_expected.not_to contain_class('vswitch::ovs')
 | |
|       end
 | |
| 
 | |
|       it 'configures bridge mappings' do
 | |
|         is_expected.to contain_neutron_agent_ovs('ovs/bridge_mappings')
 | |
|       end
 | |
| 
 | |
|       it 'should not configure bridge mappings' do
 | |
|         is_expected.not_to contain_neutron__plugins__ovs__bridge(params[:bridge_mappings].join(',')).with(
 | |
|           :before => 'Service[neutron-ovs-agent-service]'
 | |
|         )
 | |
|       end
 | |
| 
 | |
|       it 'should not configure bridge uplinks' do
 | |
|         is_expected.not_to contain_neutron__plugins__ovs__port(params[:bridge_uplinks].join(',')).with(
 | |
|           :before => 'Service[neutron-ovs-agent-service]'
 | |
|         )
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when supplying extensions for ML2 plugin' do
 | |
|       before :each do
 | |
|         params.merge!(:extensions => ['qos'])
 | |
|       end
 | |
| 
 | |
|       it 'configures extensions' do
 | |
|         is_expected.to contain_neutron_agent_ovs('agent/extensions').with_value(params[:extensions].join(','))
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     context 'when enabling tunneling' do
 | |
|       context 'without local ip address' do
 | |
|         before :each do
 | |
|           params.merge!(:enable_tunneling => true)
 | |
|         end
 | |
| 
 | |
|         it_raises 'a Puppet::Error', /Local ip for ovs agent must be set when tunneling is enabled/
 | |
|       end
 | |
|       context 'with default params' do
 | |
|         before :each do
 | |
|           params.merge!(:enable_tunneling => true, :local_ip => '127.0.0.1' )
 | |
|         end
 | |
|         it 'should configure ovs for tunneling' do
 | |
|           is_expected.to contain_neutron_agent_ovs('ovs/enable_tunneling').with_value(true)
 | |
|           is_expected.to contain_neutron_agent_ovs('ovs/tunnel_bridge').with_value(default_params[:tunnel_bridge])
 | |
|           is_expected.to contain_neutron_agent_ovs('ovs/local_ip').with_value('127.0.0.1')
 | |
|           is_expected.to contain_neutron_agent_ovs('ovs/int_peer_patch_port').with_value('<SERVICE DEFAULT>')
 | |
|           is_expected.to contain_neutron_agent_ovs('ovs/tun_peer_patch_port').with_value('<SERVICE DEFAULT>')
 | |
|         end
 | |
|       end
 | |
| 
 | |
|       context 'with vxlan tunneling' do
 | |
|         before :each do
 | |
|           params.merge!(:enable_tunneling => true,
 | |
|                         :local_ip => '127.0.0.1',
 | |
|                         :tunnel_types => ['vxlan'],
 | |
|                         :vxlan_udp_port => '4789')
 | |
|         end
 | |
| 
 | |
|         it 'should perform vxlan network configuration' do
 | |
|           is_expected.to contain_neutron_agent_ovs('agent/tunnel_types').with_value(params[:tunnel_types])
 | |
|           is_expected.to contain_neutron_agent_ovs('agent/vxlan_udp_port').with_value(params[:vxlan_udp_port])
 | |
|         end
 | |
|       end
 | |
| 
 | |
|       context 'when l2 population is disabled and DVR and tunneling enabled' do
 | |
|         before :each do
 | |
|           params.merge!(:enable_distributed_routing => true,
 | |
|                         :l2_population              => false,
 | |
|                         :enable_tunneling           => true,
 | |
|                         :local_ip                   => '127.0.0.1' )
 | |
|         end
 | |
| 
 | |
|         it_raises 'a Puppet::Error', /L2 population must be enabled when DVR and tunneling are enabled/
 | |
|       end
 | |
| 
 | |
|       context 'when DVR is enabled and l2 population and tunneling are disabled' do
 | |
|         before :each do
 | |
|           params.merge!(:enable_distributed_routing => true,
 | |
|                         :l2_population              => false,
 | |
|                         :enable_tunneling           => false )
 | |
|         end
 | |
| 
 | |
|         it 'should enable DVR without L2 population' do
 | |
|           is_expected.to contain_neutron_agent_ovs('agent/enable_distributed_routing').with_value(true)
 | |
|           is_expected.to contain_neutron_agent_ovs('agent/l2_population').with_value(false)
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   context 'on Debian platforms' do
 | |
|     let :facts do
 | |
|       @default_facts.merge(test_facts.merge({
 | |
|          :osfamily => 'Debian',
 | |
|          :os_package_type => 'debian'
 | |
|       }))
 | |
|     end
 | |
| 
 | |
|     let :platform_params do
 | |
|       { :ovs_agent_package => 'neutron-openvswitch-agent',
 | |
|         :ovs_agent_service => 'neutron-openvswitch-agent' }
 | |
|     end
 | |
| 
 | |
|     it_configures 'neutron plugin ovs agent with ml2 plugin'
 | |
|   end
 | |
| 
 | |
|   context 'on Ubuntu platforms' do
 | |
|     let :facts do
 | |
|       @default_facts.merge(test_facts.merge({
 | |
|          :osfamily => 'Debian',
 | |
|          :os_package_type => 'ubuntu'
 | |
|       }))
 | |
|     end
 | |
| 
 | |
|     let :platform_params do
 | |
|       { :ovs_agent_package => 'neutron-plugin-openvswitch-agent',
 | |
|         :ovs_agent_service => 'neutron-plugin-openvswitch-agent' }
 | |
|     end
 | |
| 
 | |
|     it_configures 'neutron plugin ovs agent with ml2 plugin'
 | |
|   end
 | |
| 
 | |
|   context 'on RedHat platforms' do
 | |
|     let :facts do
 | |
|       @default_facts.merge(test_facts.merge({
 | |
|          :osfamily               => 'RedHat',
 | |
|          :operatingsystemrelease => '7'
 | |
|       }))
 | |
|     end
 | |
| 
 | |
|     let :platform_params do
 | |
|       { :ovs_cleanup_service => 'neutron-ovs-cleanup',
 | |
|         :ovs_agent_service   => 'neutron-openvswitch-agent' }
 | |
|     end
 | |
| 
 | |
|     it_configures 'neutron plugin ovs agent with ml2 plugin'
 | |
| 
 | |
|     it 'configures neutron ovs cleanup service' do
 | |
|       is_expected.to contain_service('ovs-cleanup-service').with(
 | |
|         :name    => platform_params[:ovs_cleanup_service],
 | |
|         :enable  => true
 | |
|       )
 | |
|       is_expected.to contain_package('neutron-ovs-agent').with_before(/Service\[ovs-cleanup-service\]/)
 | |
|     end
 | |
|   end
 | |
| end
 | 
