add unit tests for network controller

Signed-off-by: Emilien Macchi <emilien.macchi@enovance.com>
This commit is contained in:
Emilien Macchi 2014-01-04 16:17:00 +01:00
parent 22e0fd4d4b
commit 25aeba0702
2 changed files with 97 additions and 3 deletions

View File

@ -32,9 +32,9 @@ class privatecloud::network::controller(
$encoded_password = uriescape($neutron_db_password)
class { 'neutron::server':
auth_password => $os_params::ks_neutron_password,
auth_host => $os_params::ks_keystone_admin_host,
auth_port => $os_params::ks_keystone_public_port,
auth_password => $ks_neutron_password,
auth_host => $ks_keystone_admin_host,
auth_port => $ks_keystone_public_port,
connection => "mysql://${encoded_user}:${encoded_password}@${neutron_db_host}/neutron?charset=utf8",
api_workers => $::processorcount
}

View File

@ -0,0 +1,94 @@
#
# 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 privatecloud::network::controller class
#
require 'spec_helper'
describe 'privatecloud::network::controller' do
shared_examples_for 'openstack network controller' do
let :pre_condition do
"class { 'privatecloud::network':
rabbit_hosts => ['10.0.0.1'],
rabbit_password => 'secrete',
tunnel_eth => '10.0.1.1',
api_eth => '10.0.0.1',
verbose => true,
debug => true }"
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,
: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'
)
should contain_class('neutron::agents::ovs').with(
:enable_tunneling => true,
:local_ip => '10.0.1.1'
)
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',
:api_workers => '2'
)
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