
I revert a last patch I did about veth_mtu param. veth_mtu enforces mtu on veths (between br-int and physnets only). It's not useful in our case, where this is the external network which is tagged, so we only need to enforce the MTU within the VM, using DHCP options. Close bug #270 Signed-off-by: Emilien Macchi <emilien.macchi@enovance.com>
120 lines
4.4 KiB
Ruby
120 lines
4.4 KiB
Ruby
#
|
|
# Copyright (C) 2014 eNovance SAS <licensing@enovance.com>
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
#
|
|
# Unit tests for cloud::network::controller class
|
|
#
|
|
require 'spec_helper'
|
|
|
|
describe 'cloud::network::controller' do
|
|
|
|
shared_examples_for 'openstack network controller' do
|
|
|
|
let :pre_condition do
|
|
"class { 'cloud::network':
|
|
rabbit_hosts => ['10.0.0.1'],
|
|
rabbit_password => 'secrete',
|
|
tunnel_eth => '10.0.1.1',
|
|
api_eth => '10.0.0.1',
|
|
provider_vlan_ranges => ['physnet1:1000:2999'],
|
|
provider_bridge_mappings => ['physnet1:br-eth1'],
|
|
verbose => true,
|
|
debug => true,
|
|
use_syslog => true,
|
|
log_facility => 'LOG_LOCAL0' }"
|
|
end
|
|
|
|
let :params do
|
|
{ :neutron_db_host => '10.0.0.1',
|
|
:neutron_db_user => 'neutron',
|
|
:neutron_db_password => 'secrete',
|
|
:ks_neutron_password => 'secrete',
|
|
:ks_keystone_admin_host => '10.0.0.1',
|
|
:ks_keystone_public_port => '5000',
|
|
:api_eth => '10.0.0.1' }
|
|
end
|
|
|
|
it 'configure neutron common' do
|
|
should contain_class('neutron').with(
|
|
:allow_overlapping_ips => true,
|
|
:dhcp_agents_per_network => '2',
|
|
:verbose => true,
|
|
:debug => true,
|
|
:log_facility => 'LOG_LOCAL0',
|
|
:use_syslog => true,
|
|
:rabbit_user => 'neutron',
|
|
:rabbit_hosts => ['10.0.0.1'],
|
|
:rabbit_password => 'secrete',
|
|
:rabbit_virtual_host => '/',
|
|
:bind_host => '10.0.0.1',
|
|
:core_plugin => 'neutron.plugins.ml2.plugin.Ml2Plugin',
|
|
:service_plugins => ['neutron.services.loadbalancer.plugin.LoadBalancerPlugin','neutron.services.metering.metering_plugin.MeteringPlugin','neutron.services.l3_router.l3_router_plugin.L3RouterPlugin']
|
|
|
|
)
|
|
should contain_class('neutron::agents::ovs').with(
|
|
:enable_tunneling => true,
|
|
:tunnel_types => ['gre'],
|
|
:bridge_mappings => ['physnet1:br-eth1'],
|
|
:local_ip => '10.0.1.1'
|
|
)
|
|
should contain_class('neutron::plugins::ml2').with(
|
|
:type_drivers => ['gre','vlan'],
|
|
:tenant_network_types => ['gre'],
|
|
:mechanism_drivers => ['openvswitch','l2population'],
|
|
:tunnel_id_ranges => ['1:10000'],
|
|
:network_vlan_ranges => ['physnet1:1000:2999'],
|
|
:enable_security_group => 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'
|
|
)
|
|
end
|
|
|
|
it 'configure neutron server' do
|
|
should contain_class('neutron::server').with(
|
|
:auth_password => 'secrete',
|
|
:auth_host => '10.0.0.1',
|
|
:auth_port => '5000',
|
|
:connection => 'mysql://neutron:secrete@10.0.0.1/neutron?charset=utf8',
|
|
:sql_connection => 'mysql://neutron:secrete@10.0.0.1/neutron?charset=utf8',
|
|
:api_workers => '2'
|
|
)
|
|
end
|
|
|
|
it 'checks if Neutron DB is populated' do
|
|
should contain_exec('neutron_db_sync').with(
|
|
:command => '/usr/bin/neutron-db-manage --config-file /etc/neutron/neutron.conf --config-file /etc/neutron/plugins/ml2/ml2_conf.ini upgrade head',
|
|
:unless => '/usr/bin/mysql neutron -h 10.0.0.1 -u neutron -psecrete -e "show tables" | /bin/grep Tables'
|
|
)
|
|
end
|
|
|
|
end
|
|
|
|
context 'on Debian platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'Debian',
|
|
:processorcount => '2' }
|
|
end
|
|
|
|
it_configures 'openstack network controller'
|
|
end
|
|
|
|
context 'on RedHat platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'RedHat',
|
|
:processorcount => '2' }
|
|
end
|
|
|
|
it_configures 'openstack network controller'
|
|
end
|
|
|
|
end
|