Rename quantum to neutron.
Global replacement of all Quantum references with Neutron. Change-Id: I74ad15e382589ced6f47d0783e3e952627fcd0f7
This commit is contained in:
parent
a8fd302d6f
commit
c5005c221f
@ -9,4 +9,4 @@ fixtures:
|
|||||||
"nova": "git://github.com/stackforge/puppet-nova.git"
|
"nova": "git://github.com/stackforge/puppet-nova.git"
|
||||||
"vswitch": "git://github.com/bodepd/puppet-vswitch"
|
"vswitch": "git://github.com/bodepd/puppet-vswitch"
|
||||||
symlinks:
|
symlinks:
|
||||||
"quantum": "#{source_dir}"
|
"neutron": "#{source_dir}"
|
||||||
|
10
Modulefile
10
Modulefile
@ -1,11 +1,11 @@
|
|||||||
name 'puppet-quantum'
|
name 'puppet-neutron'
|
||||||
version '2.1.1'
|
version '2.1.1'
|
||||||
source 'https://github.com/CiscoSystems/puppet-quantum'
|
source 'https://github.com/CiscoSystems/puppet-neutron'
|
||||||
author 'Joe Topjian,Endre Karlson,Emilien Macchi,Dan Bode,Dmitry Ukov,Edgar Mangana,Robert Starmer,Ian Wells,Daneyon Hansen'
|
author 'Joe Topjian,Endre Karlson,Emilien Macchi,Dan Bode,Dmitry Ukov,Edgar Mangana,Robert Starmer,Ian Wells,Daneyon Hansen'
|
||||||
license 'Apache License 2.0'
|
license 'Apache License 2.0'
|
||||||
summary 'Puppet module for OpenStack Quantum'
|
summary 'Puppet module for OpenStack Neutron'
|
||||||
description 'Puppet module to install and configure the OpenStack network service, Quantum'
|
description 'Puppet module to install and configure the OpenStack network service, Neutron'
|
||||||
project_page 'https://github.com/CiscoSystems/puppet-quantum'
|
project_page 'https://github.com/stackforge/puppet-neutron'
|
||||||
|
|
||||||
# Dependencies
|
# Dependencies
|
||||||
dependency 'puppetlabs/vswitch', '>=0.0.1 <1.0.0'
|
dependency 'puppetlabs/vswitch', '>=0.0.1 <1.0.0'
|
||||||
|
57
README.md
57
README.md
@ -1,11 +1,11 @@
|
|||||||
quantum
|
neutron
|
||||||
===================================
|
===================================
|
||||||
|
|
||||||
#### Table of Contents
|
#### Table of Contents
|
||||||
|
|
||||||
1. [Overview - What is the quantum module?](#overview)
|
1. [Overview - What is the neutron module?](#overview)
|
||||||
2. [Module Description - What does the module do?](#module-description)
|
2. [Module Description - What does the module do?](#module-description)
|
||||||
3. [Setup - Tha basics of getting started with quantum.](#setup)
|
3. [Setup - Tha basics of getting started with neutron.](#setup)
|
||||||
4. [Implementation - An under-the-hood peek at what the module is doing.](#implementation)
|
4. [Implementation - An under-the-hood peek at what the module is doing.](#implementation)
|
||||||
5. [Limitations - OS compatibility, etc.](#limitations)
|
5. [Limitations - OS compatibility, etc.](#limitations)
|
||||||
6. [Development - Guide for contributing to the module](#development)
|
6. [Development - Guide for contributing to the module](#development)
|
||||||
@ -15,68 +15,68 @@ quantum
|
|||||||
Overview
|
Overview
|
||||||
--------
|
--------
|
||||||
|
|
||||||
The quantum module is a part of [Stackforge](https://github.com/stackforge), an effort by the Openstack infrastructure team to provide continuous integration testing and code review for Openstack and Openstack community projects not part of the core software. The module itself is used to flexibly configure and manage the newtork service for Openstack.
|
The neutron module is a part of [Stackforge](https://github.com/stackforge), an effort by the Openstack infrastructure team to provide continuous integration testing and code review for Openstack and Openstack community projects not part of the core software. The module itself is used to flexibly configure and manage the newtork service for Openstack.
|
||||||
|
|
||||||
Module Description
|
Module Description
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
The quantum module is an attempt to make Puppet capable of managing the entirety of quantum. This includes manifests to provision such things as keystone endpoints, RPC configurations specific to quantum, database connections, and network driver plugins. Types are shipped as part of the quantum module to assist in manipulation of the Openstack configuration files.
|
The neutron module is an attempt to make Puppet capable of managing the entirety of neutron. This includes manifests to provision such things as keystone endpoints, RPC configurations specific to neutron, database connections, and network driver plugins. Types are shipped as part of the neutron module to assist in manipulation of the Openstack configuration files.
|
||||||
|
|
||||||
This module is tested in combination with other modules needed to build and leverage an entire Openstack installation. These modules can be found, all pulled together in the [openstack module](https://github.com/stackforge/puppet-openstack).
|
This module is tested in combination with other modules needed to build and leverage an entire Openstack installation. These modules can be found, all pulled together in the [openstack module](https://github.com/stackforge/puppet-openstack).
|
||||||
|
|
||||||
Setup
|
Setup
|
||||||
-----
|
-----
|
||||||
|
|
||||||
**What the quantum module affects:**
|
**What the neutron module affects:**
|
||||||
|
|
||||||
* [Quantum](https://wiki.openstack.org/wiki/Quantum), the network service for Openstack.
|
* [Neutron](https://wiki.openstack.org/wiki/Neutron), the network service for Openstack.
|
||||||
|
|
||||||
### Installing quantum
|
### Installing neutron
|
||||||
|
|
||||||
puppet module install puppetlabs/quantum
|
puppet module install puppetlabs/neutron
|
||||||
|
|
||||||
### Beginning with quantum
|
### Beginning with neutron
|
||||||
|
|
||||||
To utilize the quantum module's functionality you will need to declare multiple resources. The following is a modified excerpt from the [openstack module](httpd://github.com/stackforge/puppet-openstack). It provides an example of setting up an Open vSwitch quantum installation. This is not an exhaustive list of all the components needed. We recommend that you consult and understand the [openstack module](https://github.com/stackforge/puppet-openstack) and the [core openstack](http://docs.openstack.org) documentation to assist you in understanding the available deployment options.
|
To utilize the neutron module's functionality you will need to declare multiple resources. The following is a modified excerpt from the [openstack module](httpd://github.com/stackforge/puppet-openstack). It provides an example of setting up an Open vSwitch neutron installation. This is not an exhaustive list of all the components needed. We recommend that you consult and understand the [openstack module](https://github.com/stackforge/puppet-openstack) and the [core openstack](http://docs.openstack.org) documentation to assist you in understanding the available deployment options.
|
||||||
|
|
||||||
```puppet
|
```puppet
|
||||||
# enable the quantum service
|
# enable the neutron service
|
||||||
class { '::quantum':
|
class { '::neutron':
|
||||||
enabled => true,
|
enabled => true,
|
||||||
bind_host => '127.0.0.1',
|
bind_host => '127.0.0.1',
|
||||||
rabbit_host => '127.0.0.1',
|
rabbit_host => '127.0.0.1',
|
||||||
rabbit_user => 'quantum',
|
rabbit_user => 'neutron',
|
||||||
rabbit_password => 'rabbit_secret',
|
rabbit_password => 'rabbit_secret',
|
||||||
verbose => false,
|
verbose => false,
|
||||||
debug => false,
|
debug => false,
|
||||||
}
|
}
|
||||||
|
|
||||||
# configure authentication
|
# configure authentication
|
||||||
class { 'quantum::server':
|
class { 'neutron::server':
|
||||||
auth_host => '127.0.0.1', # the keystone host address
|
auth_host => '127.0.0.1', # the keystone host address
|
||||||
auth_password => 'keystone_quantum_secret',
|
auth_password => 'keystone_neutron_secret',
|
||||||
}
|
}
|
||||||
|
|
||||||
# enable the Open VSwitch plugin server
|
# enable the Open VSwitch plugin server
|
||||||
class { 'quantum::plugins::ovs':
|
class { 'neutron::plugins::ovs':
|
||||||
sql_connection => 'mysql://quantum:quantum_sql_secret@127.0.0.1/quantum?charset=utf8',
|
sql_connection => 'mysql://neutron:neutron_sql_secret@127.0.0.1/neutron?charset=utf8',
|
||||||
tenant_network_type => 'gre',
|
tenant_network_type => 'gre',
|
||||||
network_vlan_ranges => 'physnet:1000:2000',
|
network_vlan_ranges => 'physnet:1000:2000',
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Other quantum network drivers include:
|
Other neutron network drivers include:
|
||||||
|
|
||||||
* dhcp,
|
* dhcp,
|
||||||
* metadata,
|
* metadata,
|
||||||
* and l3.
|
* and l3.
|
||||||
|
|
||||||
Nova will also need to be configured to connect to the quantum service. Setting up the `nova::network::quantum` class sets
|
Nova will also need to be configured to connect to the neutron service. Setting up the `nova::network::neutron` class sets
|
||||||
the `network_api_class` parameter in nova to use quantum instead of nova-network.
|
the `network_api_class` parameter in nova to use neutron instead of nova-network.
|
||||||
|
|
||||||
```puppet
|
```puppet
|
||||||
class { 'nova::network::quantum':
|
class { 'nova::network::neutron':
|
||||||
quantum_admin_password => 'quantum_admin_secret',
|
neutron_admin_password => 'neutron_admin_secret',
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -86,25 +86,26 @@ The `examples` directory also provides a quick tutorial on how to use this modul
|
|||||||
Implementation
|
Implementation
|
||||||
--------------
|
--------------
|
||||||
|
|
||||||
### quantum
|
### neutron
|
||||||
|
|
||||||
quantum is a combination of Puppet manifest and ruby code to deliver configuration and extra functionality through *types* and *providers*.
|
neutron is a combination of Puppet manifest and ruby code to deliver configuration and extra functionality through *types* and *providers*.
|
||||||
|
|
||||||
|
|
||||||
Limitations
|
Limitations
|
||||||
-----------
|
-----------
|
||||||
|
|
||||||
This module supports the following quantum plugins:
|
This module supports the following neutron plugins:
|
||||||
|
|
||||||
* Open vSwitch
|
* Open vSwitch
|
||||||
* linuxbridge
|
* linuxbridge
|
||||||
* cisco-quantum
|
* cisco-neutron
|
||||||
|
|
||||||
The following platforms are supported:
|
The following platforms are supported:
|
||||||
|
|
||||||
* Ubuntu 12.04 (Precise)
|
* Ubuntu 12.04 (Precise)
|
||||||
* Debian (Wheezy)
|
* Debian (Wheezy)
|
||||||
* RHEL 6
|
* RHEL 6
|
||||||
|
* Fedora 18
|
||||||
|
|
||||||
Development
|
Development
|
||||||
-----------
|
-----------
|
||||||
@ -115,4 +116,4 @@ The puppet-openstack modules follow the Openstack development model. Developer d
|
|||||||
|
|
||||||
Contributors
|
Contributors
|
||||||
------------
|
------------
|
||||||
The github [contributor graph](https://github.com/stackforge/puppet-quantum/graphs/contributors).
|
The github [contributor graph](https://github.com/stackforge/puppet-neutron/graphs/contributors).
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
#
|
#
|
||||||
# This manifest is intended to demonstrate how to provision the
|
# This manifest is intended to demonstrate how to provision the
|
||||||
# resources necessary to boot a vm with network connectivity provided
|
# resources necessary to boot a vm with network connectivity provided
|
||||||
# by quantum.
|
# by neutron.
|
||||||
#
|
#
|
||||||
# Note that a quantum_router resouce must declare a dependency on the
|
# Note that a neutron_router resource must declare a dependency on the
|
||||||
# first subnet of the gateway network. Other dependencies for the
|
# first subnet of the gateway network. Other dependencies for the
|
||||||
# resources used in this example can be automatically determined.
|
# resources used in this example can be automatically determined.
|
||||||
#
|
#
|
||||||
@ -12,13 +12,13 @@ keystone_tenant { 'admin':
|
|||||||
ensure => present,
|
ensure => present,
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_network { 'public':
|
neutron_network { 'public':
|
||||||
ensure => present,
|
ensure => present,
|
||||||
router_external => 'True',
|
router_external => 'True',
|
||||||
tenant_name => 'admin',
|
tenant_name => 'admin',
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_subnet { 'public_subnet':
|
neutron_subnet { 'public_subnet':
|
||||||
ensure => 'present',
|
ensure => 'present',
|
||||||
cidr => '172.24.4.224/28',
|
cidr => '172.24.4.224/28',
|
||||||
network_name => 'public',
|
network_name => 'public',
|
||||||
@ -29,12 +29,12 @@ keystone_tenant { 'demo':
|
|||||||
ensure => present,
|
ensure => present,
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_network { 'private':
|
neutron_network { 'private':
|
||||||
ensure => present,
|
ensure => present,
|
||||||
tenant_name => 'demo',
|
tenant_name => 'demo',
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_subnet { 'private_subnet':
|
neutron_subnet { 'private_subnet':
|
||||||
ensure => present,
|
ensure => present,
|
||||||
cidr => '10.0.0.0/24',
|
cidr => '10.0.0.0/24',
|
||||||
network_name => 'private',
|
network_name => 'private',
|
||||||
@ -42,13 +42,13 @@ quantum_subnet { 'private_subnet':
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Tenant-private router - assumes network namespace isolation
|
# Tenant-private router - assumes network namespace isolation
|
||||||
quantum_router { 'demo_router':
|
neutron_router { 'demo_router':
|
||||||
ensure => present,
|
ensure => present,
|
||||||
tenant_name => 'demo',
|
tenant_name => 'demo',
|
||||||
gateway_network_name => 'public',
|
gateway_network_name => 'public',
|
||||||
require => Quantum_subnet['public_subnet'],
|
require => Neutron_subnet['public_subnet'],
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_router_interface { 'demo_router:private_subnet':
|
neutron_router_interface { 'demo_router:private_subnet':
|
||||||
ensure => present,
|
ensure => present,
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# This example script shows how to create a simple subnet for Quantum.
|
# This example script shows how to create a simple subnet for Neutron.
|
||||||
|
|
||||||
source /root/openrc
|
source /root/openrc
|
||||||
quantum net-create mynet
|
neutron net-create mynet
|
||||||
quantum subnet-create --name mynet-subnet mynet 10.0.0.0/24
|
neutron subnet-create --name mynet-subnet mynet 10.0.0.0/24
|
||||||
quantum router-create myrouter
|
neutron router-create myrouter
|
||||||
quantum router-interface-add myrouter mynet-subnet
|
neutron router-interface-add myrouter mynet-subnet
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
### Cloud Controller:
|
### Cloud Controller:
|
||||||
|
|
||||||
# General Quantum stuff
|
# General Neutron stuff
|
||||||
# Configures everything in quantum.conf
|
# Configures everything in neutron.conf
|
||||||
class { 'quantum':
|
class { 'neutron':
|
||||||
verbose => true,
|
verbose => true,
|
||||||
allow_overlapping_ips => true,
|
allow_overlapping_ips => true,
|
||||||
rabbit_password => 'password',
|
rabbit_password => 'password',
|
||||||
@ -11,33 +11,33 @@ class { 'quantum':
|
|||||||
}
|
}
|
||||||
|
|
||||||
# The API server talks to keystone for authorisation
|
# The API server talks to keystone for authorisation
|
||||||
class { 'quantum::server':
|
class { 'neutron::server':
|
||||||
keystone_password => 'password',
|
keystone_password => 'password',
|
||||||
}
|
}
|
||||||
|
|
||||||
# Various agents
|
# Various agents
|
||||||
class { 'quantum::agents::dhcp': }
|
class { 'neutron::agents::dhcp': }
|
||||||
class { 'quantum::agents::l3': }
|
class { 'neutron::agents::l3': }
|
||||||
class { 'quantum::agents::lbaas': }
|
class { 'neutron::agents::lbaas': }
|
||||||
|
|
||||||
# This plugin configures Quantum for OVS on the server
|
# This plugin configures Neutron for OVS on the server
|
||||||
# Agent
|
# Agent
|
||||||
class { 'quantum::agents::ovs':
|
class { 'neutron::agents::ovs':
|
||||||
local_ip => '192.168.1.1',
|
local_ip => '192.168.1.1',
|
||||||
enable_tunneling => true,
|
enable_tunneling => true,
|
||||||
}
|
}
|
||||||
|
|
||||||
# Plugin
|
# Plugin
|
||||||
class { 'quantum::plugins::ovs':
|
class { 'neutron::plugins::ovs':
|
||||||
sql_connection => 'mysql://quantum:password@localhost/quantum',
|
sql_connection => 'mysql://neutron:password@localhost/neutron',
|
||||||
tenant_network_type => 'gre',
|
tenant_network_type => 'gre',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
### Compute Nodes:
|
### Compute Nodes:
|
||||||
# Generally, any machine with a quantum element running on it talks
|
# Generally, any machine with a neutron element running on it talks
|
||||||
# over Rabbit and needs to know if overlapping IPs (namespaces) are in use
|
# over Rabbit and needs to know if overlapping IPs (namespaces) are in use
|
||||||
class { 'quantum':
|
class { 'neutron':
|
||||||
allow_overlapping_ips => true,
|
allow_overlapping_ips => true,
|
||||||
rabbit_password => 'password',
|
rabbit_password => 'password',
|
||||||
rabbit_user => 'guest',
|
rabbit_user => 'guest',
|
||||||
@ -46,13 +46,13 @@ class { 'quantum':
|
|||||||
|
|
||||||
# The agent/plugin combo also needs installed on clients
|
# The agent/plugin combo also needs installed on clients
|
||||||
# Agent
|
# Agent
|
||||||
class { 'quantum::agents::ovs':
|
class { 'neutron::agents::ovs':
|
||||||
local_ip => '192.168.1.11',
|
local_ip => '192.168.1.11',
|
||||||
enable_tunneling => true,
|
enable_tunneling => true,
|
||||||
}
|
}
|
||||||
|
|
||||||
# Plugin
|
# Plugin
|
||||||
class { 'quantum::plugins::ovs':
|
class { 'neutron::plugins::ovs':
|
||||||
sql_connection => 'mysql://quantum:password@192.168.1.1/quantum',
|
sql_connection => 'mysql://neutron:password@192.168.1.1/neutron',
|
||||||
tenant_network_type => 'gre',
|
tenant_network_type => 'gre',
|
||||||
}
|
}
|
@ -1,10 +1,10 @@
|
|||||||
require 'csv'
|
require 'csv'
|
||||||
require 'puppet/util/inifile'
|
require 'puppet/util/inifile'
|
||||||
|
|
||||||
class Puppet::Provider::Quantum < Puppet::Provider
|
class Puppet::Provider::Neutron < Puppet::Provider
|
||||||
|
|
||||||
def self.conf_filename
|
def self.conf_filename
|
||||||
'/etc/quantum/quantum.conf'
|
'/etc/neutron/neutron.conf'
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.withenv(hash, &block)
|
def self.withenv(hash, &block)
|
||||||
@ -21,27 +21,27 @@ class Puppet::Provider::Quantum < Puppet::Provider
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.quantum_credentials
|
def self.neutron_credentials
|
||||||
@quantum_credentials ||= get_quantum_credentials
|
@neutron_credentials ||= get_neutron_credentials
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.get_quantum_credentials
|
def self.get_neutron_credentials
|
||||||
auth_keys = ['auth_host', 'auth_port', 'auth_protocol',
|
auth_keys = ['auth_host', 'auth_port', 'auth_protocol',
|
||||||
'admin_tenant_name', 'admin_user', 'admin_password']
|
'admin_tenant_name', 'admin_user', 'admin_password']
|
||||||
conf = quantum_conf
|
conf = neutron_conf
|
||||||
if conf and conf['keystone_authtoken'] and
|
if conf and conf['keystone_authtoken'] and
|
||||||
auth_keys.all?{|k| !conf['keystone_authtoken'][k].nil?}
|
auth_keys.all?{|k| !conf['keystone_authtoken'][k].nil?}
|
||||||
return Hash[ auth_keys.map \
|
return Hash[ auth_keys.map \
|
||||||
{ |k| [k, conf['keystone_authtoken'][k].strip] } ]
|
{ |k| [k, conf['keystone_authtoken'][k].strip] } ]
|
||||||
else
|
else
|
||||||
raise(Puppet::Error, "File: #{conf_filename} does not contain all \
|
raise(Puppet::Error, "File: #{conf_filename} does not contain all \
|
||||||
required sections. Quantum types will not work if quantum is not \
|
required sections. Neutron types will not work if neutron is not \
|
||||||
correctly configured.")
|
correctly configured.")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def quantum_credentials
|
def neutron_credentials
|
||||||
self.class.quantum_credentials
|
self.class.neutron_credentials
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.auth_endpoint
|
def self.auth_endpoint
|
||||||
@ -49,19 +49,19 @@ correctly configured.")
|
|||||||
end
|
end
|
||||||
|
|
||||||
def self.get_auth_endpoint
|
def self.get_auth_endpoint
|
||||||
q = quantum_credentials
|
q = neutron_credentials
|
||||||
"#{q['auth_protocol']}://#{q['auth_host']}:#{q['auth_port']}/v2.0/"
|
"#{q['auth_protocol']}://#{q['auth_host']}:#{q['auth_port']}/v2.0/"
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.quantum_conf
|
def self.neutron_conf
|
||||||
return @quantum_conf if @quantum_conf
|
return @neutron_conf if @neutron_conf
|
||||||
@quantum_conf = Puppet::Util::IniConfig::File.new
|
@neutron_conf = Puppet::Util::IniConfig::File.new
|
||||||
@quantum_conf.read(conf_filename)
|
@neutron_conf.read(conf_filename)
|
||||||
@quantum_conf
|
@neutron_conf
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.auth_quantum(*args)
|
def self.auth_neutron(*args)
|
||||||
q = quantum_credentials
|
q = neutron_credentials
|
||||||
authenv = {
|
authenv = {
|
||||||
:OS_AUTH_URL => self.auth_endpoint,
|
:OS_AUTH_URL => self.auth_endpoint,
|
||||||
:OS_USERNAME => q['admin_user'],
|
:OS_USERNAME => q['admin_user'],
|
||||||
@ -70,14 +70,14 @@ correctly configured.")
|
|||||||
}
|
}
|
||||||
begin
|
begin
|
||||||
withenv authenv do
|
withenv authenv do
|
||||||
quantum(args)
|
neutron(args)
|
||||||
end
|
end
|
||||||
rescue Exception => e
|
rescue Exception => e
|
||||||
if (e.message =~ /\[Errno 111\] Connection refused/) or
|
if (e.message =~ /\[Errno 111\] Connection refused/) or
|
||||||
(e.message =~ /\(HTTP 400\)/)
|
(e.message =~ /\(HTTP 400\)/)
|
||||||
sleep 10
|
sleep 10
|
||||||
withenv authenv do
|
withenv authenv do
|
||||||
quantum(args)
|
neutron(args)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
raise(e)
|
raise(e)
|
||||||
@ -85,18 +85,18 @@ correctly configured.")
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def auth_quantum(*args)
|
def auth_neutron(*args)
|
||||||
self.class.auth_quantum(args)
|
self.class.auth_neutron(args)
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.reset
|
def self.reset
|
||||||
@quantum_conf = nil
|
@neutron_conf = nil
|
||||||
@quantum_credentials = nil
|
@neutron_credentials = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.list_quantum_resources(type)
|
def self.list_neutron_resources(type)
|
||||||
ids = []
|
ids = []
|
||||||
list = auth_quantum("#{type}-list", '--format=csv',
|
list = auth_neutron("#{type}-list", '--format=csv',
|
||||||
'--column=id', '--quote=none')
|
'--column=id', '--quote=none')
|
||||||
(list.split("\n")[1..-1] || []).compact.collect do |line|
|
(list.split("\n")[1..-1] || []).compact.collect do |line|
|
||||||
ids << line.strip
|
ids << line.strip
|
||||||
@ -104,9 +104,9 @@ correctly configured.")
|
|||||||
return ids
|
return ids
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.get_quantum_resource_attrs(type, id)
|
def self.get_neutron_resource_attrs(type, id)
|
||||||
attrs = {}
|
attrs = {}
|
||||||
net = auth_quantum("#{type}-show", '--format=shell', id)
|
net = auth_neutron("#{type}-show", '--format=shell', id)
|
||||||
last_key = nil
|
last_key = nil
|
||||||
(net.split("\n") || []).compact.collect do |line|
|
(net.split("\n") || []).compact.collect do |line|
|
||||||
if line.include? '='
|
if line.include? '='
|
||||||
@ -124,7 +124,7 @@ correctly configured.")
|
|||||||
|
|
||||||
def self.list_router_ports(router_name_or_id)
|
def self.list_router_ports(router_name_or_id)
|
||||||
results = []
|
results = []
|
||||||
cmd_output = auth_quantum("router-port-list",
|
cmd_output = auth_neutron("router-port-list",
|
||||||
'--format=csv',
|
'--format=csv',
|
||||||
router_name_or_id)
|
router_name_or_id)
|
||||||
if ! cmd_output
|
if ! cmd_output
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.type(:quantum_api_config).provide(
|
Puppet::Type.type(:neutron_api_config).provide(
|
||||||
:ini_setting,
|
:ini_setting,
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
) do
|
) do
|
||||||
@ -16,7 +16,7 @@ Puppet::Type.type(:quantum_api_config).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def file_path
|
def file_path
|
||||||
'/etc/quantum/api-paste.ini'
|
'/etc/neutron/api-paste.ini'
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.type(:quantum_config).provide(
|
Puppet::Type.type(:neutron_config).provide(
|
||||||
:ini_setting,
|
:ini_setting,
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
) do
|
) do
|
||||||
@ -16,7 +16,7 @@ Puppet::Type.type(:quantum_config).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def file_path
|
def file_path
|
||||||
'/etc/quantum/quantum.conf'
|
'/etc/neutron/neutron.conf'
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.type(:quantum_dhcp_agent_config).provide(
|
Puppet::Type.type(:neutron_dhcp_agent_config).provide(
|
||||||
:ini_setting,
|
:ini_setting,
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
) do
|
) do
|
||||||
@ -16,7 +16,7 @@ Puppet::Type.type(:quantum_dhcp_agent_config).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def file_path
|
def file_path
|
||||||
'/etc/quantum/dhcp_agent.ini'
|
'/etc/neutron/dhcp_agent.ini'
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.type(:quantum_l3_agent_config).provide(
|
Puppet::Type.type(:neutron_l3_agent_config).provide(
|
||||||
:ini_setting,
|
:ini_setting,
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
) do
|
) do
|
||||||
@ -16,7 +16,7 @@ Puppet::Type.type(:quantum_l3_agent_config).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def file_path
|
def file_path
|
||||||
'/etc/quantum/l3_agent.ini'
|
'/etc/neutron/l3_agent.ini'
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
@ -1,6 +1,6 @@
|
|||||||
Puppet::Type.type(:quantum_l3_ovs_bridge).provide(:quantum) do
|
Puppet::Type.type(:neutron_l3_ovs_bridge).provide(:neutron) do
|
||||||
desc <<-EOT
|
desc <<-EOT
|
||||||
Quantum provider to manage quantum_l3_ovs_bridge type.
|
Neutron provider to manage neutron_l3_ovs_bridge type.
|
||||||
|
|
||||||
The provider ensures that the gateway ip of the subnet is
|
The provider ensures that the gateway ip of the subnet is
|
||||||
configured on the ovs bridge.
|
configured on the ovs bridge.
|
||||||
@ -12,7 +12,7 @@ Puppet::Type.type(:quantum_l3_ovs_bridge).provide(:quantum) do
|
|||||||
|
|
||||||
def gateway_ip
|
def gateway_ip
|
||||||
if @gateway_ip == nil
|
if @gateway_ip == nil
|
||||||
subnet = Puppet::Type.type('quantum_subnet').instances.find do |instance|
|
subnet = Puppet::Type.type('neutron_subnet').instances.find do |instance|
|
||||||
instance.provider.name == @resource[:subnet_name]
|
instance.provider.name == @resource[:subnet_name]
|
||||||
end
|
end
|
||||||
if subnet
|
if subnet
|
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_lbaas_agent_config).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/lbaas_agent.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_metadata_agent_config).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/metadata_agent.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -1,27 +1,27 @@
|
|||||||
require File.join(File.dirname(__FILE__), '..','..','..',
|
require File.join(File.dirname(__FILE__), '..','..','..',
|
||||||
'puppet/provider/quantum')
|
'puppet/provider/neutron')
|
||||||
|
|
||||||
Puppet::Type.type(:quantum_network).provide(
|
Puppet::Type.type(:neutron_network).provide(
|
||||||
:quantum,
|
:neutron,
|
||||||
:parent => Puppet::Provider::Quantum
|
:parent => Puppet::Provider::Neutron
|
||||||
) do
|
) do
|
||||||
desc <<-EOT
|
desc <<-EOT
|
||||||
Quantum provider to manage quantum_network type.
|
Neutron provider to manage neutron_network type.
|
||||||
|
|
||||||
Assumes that the quantum service is configured on the same host.
|
Assumes that the neutron service is configured on the same host.
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
commands :quantum => 'quantum'
|
commands :neutron => 'neutron'
|
||||||
|
|
||||||
mk_resource_methods
|
mk_resource_methods
|
||||||
|
|
||||||
def self.quantum_type
|
def self.neutron_type
|
||||||
'net'
|
'net'
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.instances
|
def self.instances
|
||||||
list_quantum_resources(quantum_type).collect do |id|
|
list_neutron_resources(neutron_type).collect do |id|
|
||||||
attrs = get_quantum_resource_attrs(quantum_type, id)
|
attrs = get_neutron_resource_attrs(neutron_type, id)
|
||||||
new(
|
new(
|
||||||
:ensure => :present,
|
:ensure => :present,
|
||||||
:name => attrs['name'],
|
:name => attrs['name'],
|
||||||
@ -84,7 +84,7 @@ Puppet::Type.type(:quantum_network).provide(
|
|||||||
network_opts << "--router:external=#{@resource[:router_external]}"
|
network_opts << "--router:external=#{@resource[:router_external]}"
|
||||||
end
|
end
|
||||||
|
|
||||||
results = auth_quantum('net-create', '--format=shell',
|
results = auth_neutron('net-create', '--format=shell',
|
||||||
network_opts, resource[:name])
|
network_opts, resource[:name])
|
||||||
|
|
||||||
if results =~ /Created a new network:/
|
if results =~ /Created a new network:/
|
||||||
@ -107,20 +107,20 @@ Puppet::Type.type(:quantum_network).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
auth_quantum('net-delete', name)
|
auth_neutron('net-delete', name)
|
||||||
@property_hash[:ensure] = :absent
|
@property_hash[:ensure] = :absent
|
||||||
end
|
end
|
||||||
|
|
||||||
def admin_state_up=(value)
|
def admin_state_up=(value)
|
||||||
auth_quantum('net-update', "--admin_state_up=#{value}", name)
|
auth_neutron('net-update', "--admin_state_up=#{value}", name)
|
||||||
end
|
end
|
||||||
|
|
||||||
def shared=(value)
|
def shared=(value)
|
||||||
auth_quantum('net-update', "--shared=#{value}", name)
|
auth_neutron('net-update', "--shared=#{value}", name)
|
||||||
end
|
end
|
||||||
|
|
||||||
def router_external=(value)
|
def router_external=(value)
|
||||||
auth_quantum('net-update', "--router:external=#{value}", name)
|
auth_neutron('net-update', "--router:external=#{value}", name)
|
||||||
end
|
end
|
||||||
|
|
||||||
[
|
[
|
22
lib/puppet/provider/neutron_plugin_cisco/ini_setting.rb
Normal file
22
lib/puppet/provider/neutron_plugin_cisco/ini_setting.rb
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_plugin_cisco).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/plugins/cisco/cisco_plugins.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_plugin_cisco_credentials).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/plugins/cisco/credentials.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_plugin_cisco_db_conn).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/plugins/cisco/db_conn.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_plugin_cisco_l2network).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/plugins/cisco/l2network_plugin.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_plugin_linuxbridge).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/plugins/linuxbridge/linuxbridge_conf.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
22
lib/puppet/provider/neutron_plugin_ovs/ini_setting.rb
Normal file
22
lib/puppet/provider/neutron_plugin_ovs/ini_setting.rb
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
Puppet::Type.type(:neutron_plugin_ovs).provide(
|
||||||
|
:ini_setting,
|
||||||
|
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
||||||
|
) do
|
||||||
|
|
||||||
|
def section
|
||||||
|
resource[:name].split('/', 2).first
|
||||||
|
end
|
||||||
|
|
||||||
|
def setting
|
||||||
|
resource[:name].split('/', 2).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def separator
|
||||||
|
'='
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_path
|
||||||
|
'/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini'
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -1,23 +1,23 @@
|
|||||||
require File.join(File.dirname(__FILE__), '..','..','..',
|
require File.join(File.dirname(__FILE__), '..','..','..',
|
||||||
'puppet/provider/quantum')
|
'puppet/provider/neutron')
|
||||||
|
|
||||||
Puppet::Type.type(:quantum_router).provide(
|
Puppet::Type.type(:neutron_router).provide(
|
||||||
:quantum,
|
:neutron,
|
||||||
:parent => Puppet::Provider::Quantum
|
:parent => Puppet::Provider::Neutron
|
||||||
) do
|
) do
|
||||||
desc <<-EOT
|
desc <<-EOT
|
||||||
Quantum provider to manage quantum_router type.
|
Neutron provider to manage neutron_router type.
|
||||||
|
|
||||||
Assumes that the quantum service is configured on the same host.
|
Assumes that the neutron service is configured on the same host.
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
commands :quantum => 'quantum'
|
commands :neutron => 'neutron'
|
||||||
|
|
||||||
mk_resource_methods
|
mk_resource_methods
|
||||||
|
|
||||||
def self.instances
|
def self.instances
|
||||||
list_quantum_resources('router').collect do |id|
|
list_neutron_resources('router').collect do |id|
|
||||||
attrs = get_quantum_resource_attrs('router', id)
|
attrs = get_neutron_resource_attrs('router', id)
|
||||||
new(
|
new(
|
||||||
:ensure => :present,
|
:ensure => :present,
|
||||||
:name => attrs['name'],
|
:name => attrs['name'],
|
||||||
@ -58,7 +58,7 @@ Puppet::Type.type(:quantum_router).provide(
|
|||||||
opts << "--tenant_id=#{@resource[:tenant_id]}"
|
opts << "--tenant_id=#{@resource[:tenant_id]}"
|
||||||
end
|
end
|
||||||
|
|
||||||
results = auth_quantum("router-create", '--format=shell',
|
results = auth_neutron("router-create", '--format=shell',
|
||||||
opts, resource[:name])
|
opts, resource[:name])
|
||||||
|
|
||||||
if results =~ /Created a new router:/
|
if results =~ /Created a new router:/
|
||||||
@ -74,11 +74,11 @@ Puppet::Type.type(:quantum_router).provide(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if @resource[:gateway_network_name]
|
if @resource[:gateway_network_name]
|
||||||
results = auth_quantum('router-gateway-set',
|
results = auth_neutron('router-gateway-set',
|
||||||
@resource[:name],
|
@resource[:name],
|
||||||
@resource[:gateway_network_name])
|
@resource[:gateway_network_name])
|
||||||
if results =~ /Set gateway for router/
|
if results =~ /Set gateway for router/
|
||||||
attrs = self.class.get_quantum_resource_attrs('router',
|
attrs = self.class.get_neutron_resource_attrs('router',
|
||||||
@resource[:name])
|
@resource[:name])
|
||||||
@property_hash[:external_gateway_info] = \
|
@property_hash[:external_gateway_info] = \
|
||||||
attrs['external_gateway_info']
|
attrs['external_gateway_info']
|
||||||
@ -95,13 +95,13 @@ EOT
|
|||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
auth_quantum('router-delete', name)
|
auth_neutron('router-delete', name)
|
||||||
@property_hash[:ensure] = :absent
|
@property_hash[:ensure] = :absent
|
||||||
end
|
end
|
||||||
|
|
||||||
def gateway_network_name
|
def gateway_network_name
|
||||||
if @gateway_network_name == nil and gateway_network_id
|
if @gateway_network_name == nil and gateway_network_id
|
||||||
Puppet::Type.type('quantum_network').instances.each do |instance|
|
Puppet::Type.type('neutron_network').instances.each do |instance|
|
||||||
if instance.provider.id == gateway_network_id
|
if instance.provider.id == gateway_network_id
|
||||||
@gateway_network_name = instance.provider.name
|
@gateway_network_name = instance.provider.name
|
||||||
end
|
end
|
||||||
@ -112,9 +112,9 @@ EOT
|
|||||||
|
|
||||||
def gateway_network_name=(value)
|
def gateway_network_name=(value)
|
||||||
if value == ''
|
if value == ''
|
||||||
auth_quantum('router-gateway-clear', name)
|
auth_neutron('router-gateway-clear', name)
|
||||||
else
|
else
|
||||||
auth_quantum('router-gateway-set', name, value)
|
auth_neutron('router-gateway-set', name, value)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -132,7 +132,7 @@ EOT
|
|||||||
end
|
end
|
||||||
|
|
||||||
def admin_state_up=(value)
|
def admin_state_up=(value)
|
||||||
auth_quantum('router-update', "--admin-state-up=#{value}", name)
|
auth_neutron('router-update', "--admin-state-up=#{value}", name)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
@ -1,14 +1,14 @@
|
|||||||
require File.join(File.dirname(__FILE__), '..','..','..',
|
require File.join(File.dirname(__FILE__), '..','..','..',
|
||||||
'puppet/provider/quantum')
|
'puppet/provider/neutron')
|
||||||
|
|
||||||
Puppet::Type.type(:quantum_router_interface).provide(
|
Puppet::Type.type(:neutron_router_interface).provide(
|
||||||
:quantum,
|
:neutron,
|
||||||
:parent => Puppet::Provider::Quantum
|
:parent => Puppet::Provider::Neutron
|
||||||
) do
|
) do
|
||||||
desc <<-EOT
|
desc <<-EOT
|
||||||
Quantum provider to manage quantum_router_interface type.
|
Neutron provider to manage neutron_router_interface type.
|
||||||
|
|
||||||
Assumes that the quantum service is configured on the same host.
|
Assumes that the neutron service is configured on the same host.
|
||||||
|
|
||||||
It is not possible to manage an interface for the subnet used by
|
It is not possible to manage an interface for the subnet used by
|
||||||
the gateway network, and such an interface will appear in the list
|
the gateway network, and such an interface will appear in the list
|
||||||
@ -17,17 +17,17 @@ Puppet::Type.type(:quantum_router_interface).provide(
|
|||||||
|
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
commands :quantum => 'quantum'
|
commands :neutron => 'neutron'
|
||||||
|
|
||||||
mk_resource_methods
|
mk_resource_methods
|
||||||
|
|
||||||
def self.instances
|
def self.instances
|
||||||
subnet_name_hash = {}
|
subnet_name_hash = {}
|
||||||
Puppet::Type.type('quantum_subnet').instances.each do |instance|
|
Puppet::Type.type('neutron_subnet').instances.each do |instance|
|
||||||
subnet_name_hash[instance.provider.id] = instance.provider.name
|
subnet_name_hash[instance.provider.id] = instance.provider.name
|
||||||
end
|
end
|
||||||
instances_ = []
|
instances_ = []
|
||||||
Puppet::Type.type('quantum_router').instances.each do |instance|
|
Puppet::Type.type('neutron_router').instances.each do |instance|
|
||||||
list_router_ports(instance.provider.id).each do |port_hash|
|
list_router_ports(instance.provider.id).each do |port_hash|
|
||||||
router_name = instance.provider.name
|
router_name = instance.provider.name
|
||||||
subnet_name = subnet_name_hash[port_hash['subnet_id']]
|
subnet_name = subnet_name_hash[port_hash['subnet_id']]
|
||||||
@ -56,7 +56,7 @@ Puppet::Type.type(:quantum_router_interface).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def create
|
def create
|
||||||
results = auth_quantum("router-interface-add", '--format=shell',
|
results = auth_neutron("router-interface-add", '--format=shell',
|
||||||
resource[:name].split(':', 2))
|
resource[:name].split(':', 2))
|
||||||
|
|
||||||
if results =~ /Added interface to router/
|
if results =~ /Added interface to router/
|
||||||
@ -83,7 +83,7 @@ Puppet::Type.type(:quantum_router_interface).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
auth_quantum('router-interface-delete', router_name, subnet_name)
|
auth_neutron('router-interface-delete', router_name, subnet_name)
|
||||||
@property_hash[:ensure] = :absent
|
@property_hash[:ensure] = :absent
|
||||||
end
|
end
|
||||||
|
|
@ -1,27 +1,27 @@
|
|||||||
require File.join(File.dirname(__FILE__), '..','..','..',
|
require File.join(File.dirname(__FILE__), '..','..','..',
|
||||||
'puppet/provider/quantum')
|
'puppet/provider/neutron')
|
||||||
|
|
||||||
Puppet::Type.type(:quantum_subnet).provide(
|
Puppet::Type.type(:neutron_subnet).provide(
|
||||||
:quantum,
|
:neutron,
|
||||||
:parent => Puppet::Provider::Quantum
|
:parent => Puppet::Provider::Neutron
|
||||||
) do
|
) do
|
||||||
desc <<-EOT
|
desc <<-EOT
|
||||||
Quantum provider to manage quantum_subnet type.
|
Neutron provider to manage neutron_subnet type.
|
||||||
|
|
||||||
Assumes that the quantum service is configured on the same host.
|
Assumes that the neutron service is configured on the same host.
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
commands :quantum => 'quantum'
|
commands :neutron => 'neutron'
|
||||||
|
|
||||||
mk_resource_methods
|
mk_resource_methods
|
||||||
|
|
||||||
def self.quantum_type
|
def self.neutron_type
|
||||||
'subnet'
|
'subnet'
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.instances
|
def self.instances
|
||||||
list_quantum_resources(quantum_type).collect do |id|
|
list_neutron_resources(neutron_type).collect do |id|
|
||||||
attrs = get_quantum_resource_attrs(quantum_type, id)
|
attrs = get_neutron_resource_attrs(neutron_type, id)
|
||||||
new(
|
new(
|
||||||
:ensure => :present,
|
:ensure => :present,
|
||||||
:name => attrs['name'],
|
:name => attrs['name'],
|
||||||
@ -81,7 +81,7 @@ Puppet::Type.type(:quantum_subnet).provide(
|
|||||||
opts << resource[:network_id]
|
opts << resource[:network_id]
|
||||||
end
|
end
|
||||||
|
|
||||||
results = auth_quantum('subnet-create', '--format=shell',
|
results = auth_neutron('subnet-create', '--format=shell',
|
||||||
opts, resource[:cidr])
|
opts, resource[:cidr])
|
||||||
|
|
||||||
if results =~ /Created a new subnet:/
|
if results =~ /Created a new subnet:/
|
||||||
@ -106,16 +106,16 @@ Puppet::Type.type(:quantum_subnet).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
auth_quantum('subnet-delete', name)
|
auth_neutron('subnet-delete', name)
|
||||||
@property_hash[:ensure] = :absent
|
@property_hash[:ensure] = :absent
|
||||||
end
|
end
|
||||||
|
|
||||||
def gateway_ip=(value)
|
def gateway_ip=(value)
|
||||||
auth_quantum('subnet-update', "--gateway-ip=#{value}", name)
|
auth_neutron('subnet-update', "--gateway-ip=#{value}", name)
|
||||||
end
|
end
|
||||||
|
|
||||||
def enable_dhcp=(value)
|
def enable_dhcp=(value)
|
||||||
auth_quantum('subnet-update', "--enable-dhcp=#{value}", name)
|
auth_neutron('subnet-update', "--enable-dhcp=#{value}", name)
|
||||||
end
|
end
|
||||||
|
|
||||||
[
|
[
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_lbaas_agent_config).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/lbaas_agent.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_metadata_agent_config).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/metadata_agent.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_plugin_cisco).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/plugins/cisco/cisco_plugins.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_plugin_cisco_credentials).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/plugins/cisco/credentials.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_plugin_cisco_db_conn).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/plugins/cisco/db_conn.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_plugin_cisco_l2network).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/plugins/cisco/l2network_plugin.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_plugin_linuxbridge).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/plugins/linuxbridge/linuxbridge_conf.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,22 +0,0 @@
|
|||||||
Puppet::Type.type(:quantum_plugin_ovs).provide(
|
|
||||||
:ini_setting,
|
|
||||||
:parent => Puppet::Type.type(:ini_setting).provider(:ruby)
|
|
||||||
) do
|
|
||||||
|
|
||||||
def section
|
|
||||||
resource[:name].split('/', 2).first
|
|
||||||
end
|
|
||||||
|
|
||||||
def setting
|
|
||||||
resource[:name].split('/', 2).last
|
|
||||||
end
|
|
||||||
|
|
||||||
def separator
|
|
||||||
'='
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
'/etc/quantum/plugins/openvswitch/ovs_quantum_plugin.ini'
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_api_config) do
|
Puppet::Type.newtype(:neutron_api_config) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
@ -1,9 +1,9 @@
|
|||||||
Puppet::Type.newtype(:quantum_config) do
|
Puppet::Type.newtype(:neutron_config) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
newparam(:name, :namevar => true) do
|
newparam(:name, :namevar => true) do
|
||||||
desc 'Section/setting name to manage from quantum.conf'
|
desc 'Section/setting name to manage from neutron.conf'
|
||||||
newvalues(/\S+\/\S+/)
|
newvalues(/\S+\/\S+/)
|
||||||
end
|
end
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_dhcp_agent_config) do
|
Puppet::Type.newtype(:neutron_dhcp_agent_config) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_l3_agent_config) do
|
Puppet::Type.newtype(:neutron_l3_agent_config) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_l3_ovs_bridge) do
|
Puppet::Type.newtype(:neutron_l3_ovs_bridge) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -12,14 +12,14 @@ Puppet::Type.newtype(:quantum_l3_ovs_bridge) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:service) do
|
autorequire(:service) do
|
||||||
['quantum-server']
|
['neutron-server']
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:vs_bridge) do
|
autorequire(:vs_bridge) do
|
||||||
[self[:name]]
|
[self[:name]]
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:quantum_subnet) do
|
autorequire(:neutron_subnet) do
|
||||||
[self[:subnet_name]] if self[:subnet_name]
|
[self[:subnet_name]] if self[:subnet_name]
|
||||||
end
|
end
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_lbaas_agent_config) do
|
Puppet::Type.newtype(:neutron_lbaas_agent_config) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_metadata_agent_config) do
|
Puppet::Type.newtype(:neutron_metadata_agent_config) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_network) do
|
Puppet::Type.newtype(:neutron_network) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -66,9 +66,9 @@ Puppet::Type.newtype(:quantum_network) do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Require the quantum-server service to be running
|
# Require the neutron-server service to be running
|
||||||
autorequire(:service) do
|
autorequire(:service) do
|
||||||
['quantum-server']
|
['neutron-server']
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:keystone_tenant) do
|
autorequire(:keystone_tenant) do
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_plugin_cisco) do
|
Puppet::Type.newtype(:neutron_plugin_cisco) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -8,7 +8,7 @@ Puppet::Type.newtype(:quantum_plugin_cisco) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:file) do
|
autorequire(:file) do
|
||||||
['/etc/quantum/plugins/cisco']
|
['/etc/neutron/plugins/cisco']
|
||||||
end
|
end
|
||||||
|
|
||||||
newproperty(:value) do
|
newproperty(:value) do
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_plugin_cisco_credentials) do
|
Puppet::Type.newtype(:neutron_plugin_cisco_credentials) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -8,7 +8,7 @@ Puppet::Type.newtype(:quantum_plugin_cisco_credentials) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:file) do
|
autorequire(:file) do
|
||||||
['/etc/quantum/plugins/cisco']
|
['/etc/neutron/plugins/cisco']
|
||||||
end
|
end
|
||||||
|
|
||||||
newproperty(:value) do
|
newproperty(:value) do
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_plugin_cisco_db_conn) do
|
Puppet::Type.newtype(:neutron_plugin_cisco_db_conn) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -8,7 +8,7 @@ Puppet::Type.newtype(:quantum_plugin_cisco_db_conn) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:file) do
|
autorequire(:file) do
|
||||||
['/etc/quantum/plugins/cisco']
|
['/etc/neutron/plugins/cisco']
|
||||||
end
|
end
|
||||||
|
|
||||||
newproperty(:value) do
|
newproperty(:value) do
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_plugin_cisco_l2network) do
|
Puppet::Type.newtype(:neutron_plugin_cisco_l2network) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -8,7 +8,7 @@ Puppet::Type.newtype(:quantum_plugin_cisco_l2network) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:file) do
|
autorequire(:file) do
|
||||||
['/etc/quantum/plugins/cisco']
|
['/etc/neutron/plugins/cisco']
|
||||||
end
|
end
|
||||||
|
|
||||||
newproperty(:value) do
|
newproperty(:value) do
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_plugin_linuxbridge) do
|
Puppet::Type.newtype(:neutron_plugin_linuxbridge) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
@ -1,9 +1,9 @@
|
|||||||
Puppet::Type.newtype(:quantum_plugin_ovs) do
|
Puppet::Type.newtype(:neutron_plugin_ovs) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
newparam(:name, :namevar => true) do
|
newparam(:name, :namevar => true) do
|
||||||
desc 'Section/setting name to manage from ovs_quantum_plugin.ini'
|
desc 'Section/setting name to manage from ovs_neutron_plugin.ini'
|
||||||
newvalues(/\S+\/\S+/)
|
newvalues(/\S+\/\S+/)
|
||||||
end
|
end
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_router) do
|
Puppet::Type.newtype(:neutron_router) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -65,14 +65,14 @@ Puppet::Type.newtype(:quantum_router) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:service) do
|
autorequire(:service) do
|
||||||
['quantum-server']
|
['neutron-server']
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:keystone_tenant) do
|
autorequire(:keystone_tenant) do
|
||||||
[self[:tenant_name]] if self[:tenant_name]
|
[self[:tenant_name]] if self[:tenant_name]
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:quantum_network) do
|
autorequire(:neutron_network) do
|
||||||
[self[:gateway_network_name]] if self[:gateway_network_name]
|
[self[:gateway_network_name]] if self[:gateway_network_name]
|
||||||
end
|
end
|
||||||
|
|
@ -1,8 +1,8 @@
|
|||||||
Puppet::Type.newtype(:quantum_router_interface) do
|
Puppet::Type.newtype(:neutron_router_interface) do
|
||||||
|
|
||||||
desc <<-EOT
|
desc <<-EOT
|
||||||
This is currently used to model the creation of
|
This is currently used to model the creation of
|
||||||
quantum router interfaces.
|
neutron router interfaces.
|
||||||
|
|
||||||
Router interfaces are an association between a router and a
|
Router interfaces are an association between a router and a
|
||||||
subnet.
|
subnet.
|
||||||
@ -33,14 +33,14 @@ Puppet::Type.newtype(:quantum_router_interface) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:service) do
|
autorequire(:service) do
|
||||||
['quantum-server']
|
['neutron-server']
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:quantum_router) do
|
autorequire(:neutron_router) do
|
||||||
self[:name].split(':', 2).first
|
self[:name].split(':', 2).first
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:quantum_subnet) do
|
autorequire(:neutron_subnet) do
|
||||||
self[:name].split(':', 2).last
|
self[:name].split(':', 2).last
|
||||||
end
|
end
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
Puppet::Type.newtype(:quantum_subnet) do
|
Puppet::Type.newtype(:neutron_subnet) do
|
||||||
|
|
||||||
ensurable
|
ensurable
|
||||||
|
|
||||||
@ -76,14 +76,14 @@ Puppet::Type.newtype(:quantum_subnet) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:service) do
|
autorequire(:service) do
|
||||||
['quantum-server']
|
['neutron-server']
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:keystone_tenant) do
|
autorequire(:keystone_tenant) do
|
||||||
[self[:tenant_name]] if self[:tenant_name]
|
[self[:tenant_name]] if self[:tenant_name]
|
||||||
end
|
end
|
||||||
|
|
||||||
autorequire(:quantum_network) do
|
autorequire(:neutron_network) do
|
||||||
[self[:network_name]] if self[:network_name]
|
[self[:network_name]] if self[:network_name]
|
||||||
end
|
end
|
||||||
|
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::agents::dhcp
|
# == Class: neutron::agents::dhcp
|
||||||
#
|
#
|
||||||
# Setups Quantum DHCP agent.
|
# Setups Neutron DHCP agent.
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
@ -15,21 +15,21 @@
|
|||||||
#
|
#
|
||||||
# [*state_path*]
|
# [*state_path*]
|
||||||
# (optional) Where to store dnsmasq state files. This directory must be
|
# (optional) Where to store dnsmasq state files. This directory must be
|
||||||
# writable by the user executing the agent. Defaults to '/var/lib/quantum'.
|
# writable by the user executing the agent. Defaults to '/var/lib/neutron'.
|
||||||
#
|
#
|
||||||
# [*resync_interval*]
|
# [*resync_interval*]
|
||||||
# (optional) The DHCP agent will resync its state with Quantum to recover
|
# (optional) The DHCP agent will resync its state with Neutron to recover
|
||||||
# from any transient notification or rpc errors. The interval is number of
|
# from any transient notification or rpc errors. The interval is number of
|
||||||
# seconds between attempts. Defaults to 30.
|
# seconds between attempts. Defaults to 30.
|
||||||
#
|
#
|
||||||
# [*interface_driver*]
|
# [*interface_driver*]
|
||||||
# (optional) Defaults to 'quantum.agent.linux.interface.OVSInterfaceDriver'.
|
# (optional) Defaults to 'neutron.agent.linux.interface.OVSInterfaceDriver'.
|
||||||
#
|
#
|
||||||
# [*dhcp_driver*]
|
# [*dhcp_driver*]
|
||||||
# (optional) Defaults to 'quantum.agent.linux.dhcp.Dnsmasq'.
|
# (optional) Defaults to 'neutron.agent.linux.dhcp.Dnsmasq'.
|
||||||
#
|
#
|
||||||
# [*root_helper*]
|
# [*root_helper*]
|
||||||
# (optional) Defaults to 'sudo quantum-rootwrap /etc/quantum/rootwrap.conf'.
|
# (optional) Defaults to 'sudo neutron-rootwrap /etc/neutron/rootwrap.conf'.
|
||||||
# Addresses bug: https://bugs.launchpad.net/neutron/+bug/1182616
|
# Addresses bug: https://bugs.launchpad.net/neutron/+bug/1182616
|
||||||
# Note: This can safely be removed once the module only targets the Havana release.
|
# Note: This can safely be removed once the module only targets the Havana release.
|
||||||
#
|
#
|
||||||
@ -38,28 +38,28 @@
|
|||||||
# CONFIG_NET_NS=y and iproute2 package that supports namespaces).
|
# CONFIG_NET_NS=y and iproute2 package that supports namespaces).
|
||||||
# Defaults to true.
|
# Defaults to true.
|
||||||
#
|
#
|
||||||
class quantum::agents::dhcp (
|
class neutron::agents::dhcp (
|
||||||
$package_ensure = present,
|
$package_ensure = present,
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$debug = false,
|
$debug = false,
|
||||||
$state_path = '/var/lib/quantum',
|
$state_path = '/var/lib/neutron',
|
||||||
$resync_interval = 30,
|
$resync_interval = 30,
|
||||||
$interface_driver = 'quantum.agent.linux.interface.OVSInterfaceDriver',
|
$interface_driver = 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
$dhcp_driver = 'quantum.agent.linux.dhcp.Dnsmasq',
|
$dhcp_driver = 'neutron.agent.linux.dhcp.Dnsmasq',
|
||||||
$root_helper = 'sudo quantum-rootwrap /etc/quantum/rootwrap.conf',
|
$root_helper = 'sudo neutron-rootwrap /etc/neutron/rootwrap.conf',
|
||||||
$use_namespaces = true
|
$use_namespaces = true
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
Quantum_config<||> ~> Service['quantum-dhcp-service']
|
Neutron_config<||> ~> Service['neutron-dhcp-service']
|
||||||
Quantum_dhcp_agent_config<||> ~> Service['quantum-dhcp-service']
|
Neutron_dhcp_agent_config<||> ~> Service['neutron-dhcp-service']
|
||||||
|
|
||||||
case $dhcp_driver {
|
case $dhcp_driver {
|
||||||
/\.Dnsmasq/: {
|
/\.Dnsmasq/: {
|
||||||
Package['dnsmasq'] -> Package<| title == 'quantum-dhcp-agent' |>
|
Package['dnsmasq'] -> Package<| title == 'neutron-dhcp-agent' |>
|
||||||
package { 'dnsmasq':
|
package { 'dnsmasq':
|
||||||
name => $::quantum::params::dnsmasq_packages,
|
name => $::neutron::params::dnsmasq_packages,
|
||||||
ensure => present,
|
ensure => present,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -68,10 +68,10 @@ class quantum::agents::dhcp (
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# The DHCP agent loads both quantum.ini and its own file.
|
# The DHCP agent loads both neutron.ini and its own file.
|
||||||
# This only lists config specific to the agent. quantum.ini supplies
|
# This only lists config specific to the agent. neutron.ini supplies
|
||||||
# the rest.
|
# the rest.
|
||||||
quantum_dhcp_agent_config {
|
neutron_dhcp_agent_config {
|
||||||
'DEFAULT/debug': value => $debug;
|
'DEFAULT/debug': value => $debug;
|
||||||
'DEFAULT/state_path': value => $state_path;
|
'DEFAULT/state_path': value => $state_path;
|
||||||
'DEFAULT/resync_interval': value => $resync_interval;
|
'DEFAULT/resync_interval': value => $resync_interval;
|
||||||
@ -81,18 +81,18 @@ class quantum::agents::dhcp (
|
|||||||
'DEFAULT/root_helper': value => $root_helper;
|
'DEFAULT/root_helper': value => $root_helper;
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::quantum::params::dhcp_agent_package {
|
if $::neutron::params::dhcp_agent_package {
|
||||||
Package['quantum'] -> Package['quantum-dhcp-agent']
|
Package['neutron'] -> Package['neutron-dhcp-agent']
|
||||||
Package['quantum-dhcp-agent'] -> Quantum_config<||>
|
Package['neutron-dhcp-agent'] -> Neutron_config<||>
|
||||||
Package['quantum-dhcp-agent'] -> Quantum_dhcp_agent_config<||>
|
Package['neutron-dhcp-agent'] -> Neutron_dhcp_agent_config<||>
|
||||||
package { 'quantum-dhcp-agent':
|
package { 'neutron-dhcp-agent':
|
||||||
name => $::quantum::params::dhcp_agent_package,
|
name => $::neutron::params::dhcp_agent_package,
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Some platforms (RedHat) do not provide a quantum DHCP agent package.
|
# Some platforms (RedHat) do not provide a neutron DHCP agent package.
|
||||||
# The quantum DHCP agent config file is provided by the quantum package.
|
# The neutron DHCP agent config file is provided by the neutron package.
|
||||||
Package['quantum'] -> Quantum_dhcp_agent_config<||>
|
Package['neutron'] -> Neutron_dhcp_agent_config<||>
|
||||||
}
|
}
|
||||||
|
|
||||||
if $enabled {
|
if $enabled {
|
||||||
@ -101,10 +101,10 @@ class quantum::agents::dhcp (
|
|||||||
$ensure = 'stopped'
|
$ensure = 'stopped'
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'quantum-dhcp-service':
|
service { 'neutron-dhcp-service':
|
||||||
name => $::quantum::params::dhcp_agent_service,
|
name => $::neutron::params::dhcp_agent_service,
|
||||||
enable => $enabled,
|
enable => $enabled,
|
||||||
ensure => $ensure,
|
ensure => $ensure,
|
||||||
require => Class['quantum'],
|
require => Class['neutron'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::agents::l3
|
# == Class: neutron::agents::l3
|
||||||
#
|
#
|
||||||
# Installs and configures the Quantum L3 service
|
# Installs and configures the Neutron L3 service
|
||||||
#
|
#
|
||||||
# TODO: create ability to have multiple L3 services
|
# TODO: create ability to have multiple L3 services
|
||||||
#
|
#
|
||||||
@ -27,15 +27,15 @@
|
|||||||
# Defaults to false
|
# Defaults to false
|
||||||
#
|
#
|
||||||
# [*interface_driver*]
|
# [*interface_driver*]
|
||||||
# (optional) Driver to interface with quantum
|
# (optional) Driver to interface with neutron
|
||||||
# Defaults to OVSInterfaceDriver
|
# Defaults to OVSInterfaceDriver
|
||||||
#
|
#
|
||||||
# [*router_id*]
|
# [*router_id*]
|
||||||
# (optional) The ID of the external router in quantum
|
# (optional) The ID of the external router in neutron
|
||||||
# Defaults to blank
|
# Defaults to blank
|
||||||
#
|
#
|
||||||
# [*gateway_external_network_id*]
|
# [*gateway_external_network_id*]
|
||||||
# (optional) The ID of the external network in quantum
|
# (optional) The ID of the external network in neutron
|
||||||
# Defaults to blank
|
# Defaults to blank
|
||||||
#
|
#
|
||||||
# [*handle_internal_only_routers*]
|
# [*handle_internal_only_routers*]
|
||||||
@ -63,13 +63,13 @@
|
|||||||
# (optional) can be set to False if the Nova metadata server is not available
|
# (optional) can be set to False if the Nova metadata server is not available
|
||||||
# Defaults to True
|
# Defaults to True
|
||||||
#
|
#
|
||||||
class quantum::agents::l3 (
|
class neutron::agents::l3 (
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$debug = false,
|
$debug = false,
|
||||||
$external_network_bridge = 'br-ex',
|
$external_network_bridge = 'br-ex',
|
||||||
$use_namespaces = true,
|
$use_namespaces = true,
|
||||||
$interface_driver = 'quantum.agent.linux.interface.OVSInterfaceDriver',
|
$interface_driver = 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
$router_id = undef,
|
$router_id = undef,
|
||||||
$gateway_external_network_id = undef,
|
$gateway_external_network_id = undef,
|
||||||
$handle_internal_only_routers = true,
|
$handle_internal_only_routers = true,
|
||||||
@ -80,12 +80,12 @@ class quantum::agents::l3 (
|
|||||||
$enable_metadata_proxy = true
|
$enable_metadata_proxy = true
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
Quantum_config<||> ~> Service['quantum-l3']
|
Neutron_config<||> ~> Service['neutron-l3']
|
||||||
Quantum_l3_agent_config<||> ~> Service['quantum-l3']
|
Neutron_l3_agent_config<||> ~> Service['neutron-l3']
|
||||||
|
|
||||||
quantum_l3_agent_config {
|
neutron_l3_agent_config {
|
||||||
'DEFAULT/debug': value => $debug;
|
'DEFAULT/debug': value => $debug;
|
||||||
'DEFAULT/external_network_bridge': value => $external_network_bridge;
|
'DEFAULT/external_network_bridge': value => $external_network_bridge;
|
||||||
'DEFAULT/use_namespaces': value => $use_namespaces;
|
'DEFAULT/use_namespaces': value => $use_namespaces;
|
||||||
@ -100,17 +100,17 @@ class quantum::agents::l3 (
|
|||||||
'DEFAULT/enable_metadata_proxy': value => $enable_metadata_proxy;
|
'DEFAULT/enable_metadata_proxy': value => $enable_metadata_proxy;
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::quantum::params::l3_agent_package {
|
if $::neutron::params::l3_agent_package {
|
||||||
Package['quantum-l3'] -> Quantum_l3_agent_config<||>
|
Package['neutron-l3'] -> Neutron_l3_agent_config<||>
|
||||||
package { 'quantum-l3':
|
package { 'neutron-l3':
|
||||||
name => $::quantum::params::l3_agent_package,
|
name => $::neutron::params::l3_agent_package,
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
require => Package['quantum'],
|
require => Package['neutron'],
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Some platforms (RedHat) does not provide a quantum L3 agent package.
|
# Some platforms (RedHat) does not provide a neutron L3 agent package.
|
||||||
# The quantum L3 agent config file is provided by the quantum package.
|
# The neutron L3 agent config file is provided by the neutron package.
|
||||||
Package['quantum'] -> Quantum_l3_agent_config<||>
|
Package['neutron'] -> Neutron_l3_agent_config<||>
|
||||||
}
|
}
|
||||||
|
|
||||||
if $enabled {
|
if $enabled {
|
||||||
@ -119,10 +119,10 @@ class quantum::agents::l3 (
|
|||||||
$ensure = 'stopped'
|
$ensure = 'stopped'
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'quantum-l3':
|
service { 'neutron-l3':
|
||||||
name => $::quantum::params::l3_agent_service,
|
name => $::neutron::params::l3_agent_service,
|
||||||
enable => $enabled,
|
enable => $enabled,
|
||||||
ensure => $ensure,
|
ensure => $ensure,
|
||||||
require => Class['quantum'],
|
require => Class['neutron'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::agents:lbaas:
|
# == Class: neutron::agents:lbaas:
|
||||||
#
|
#
|
||||||
# Setups Quantum Load Balancing agent.
|
# Setups Neutron Load Balancing agent.
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
@ -14,10 +14,10 @@
|
|||||||
# (optional) Show debugging output in log. Defaults to false.
|
# (optional) Show debugging output in log. Defaults to false.
|
||||||
#
|
#
|
||||||
# [*interface_driver*]
|
# [*interface_driver*]
|
||||||
# (optional) Defaults to 'quantum.agent.linux.interface.OVSInterfaceDriver'.
|
# (optional) Defaults to 'neutron.agent.linux.interface.OVSInterfaceDriver'.
|
||||||
#
|
#
|
||||||
# [*device_driver*]
|
# [*device_driver*]
|
||||||
# (optional) Defaults to 'quantum.plugins.services.agent_loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver'.
|
# (optional) Defaults to 'neutron.plugins.services.agent_loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver'.
|
||||||
#
|
#
|
||||||
# [*use_namespaces*]
|
# [*use_namespaces*]
|
||||||
# (optional) Allow overlapping IP (Must have kernel build with
|
# (optional) Allow overlapping IP (Must have kernel build with
|
||||||
@ -27,26 +27,26 @@
|
|||||||
# [*user_group*]
|
# [*user_group*]
|
||||||
# (optional) The user group. Defaults to nogroup.
|
# (optional) The user group. Defaults to nogroup.
|
||||||
#
|
#
|
||||||
class quantum::agents::lbaas (
|
class neutron::agents::lbaas (
|
||||||
$package_ensure = present,
|
$package_ensure = present,
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$debug = false,
|
$debug = false,
|
||||||
$interface_driver = 'quantum.agent.linux.interface.OVSInterfaceDriver',
|
$interface_driver = 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
$device_driver = 'quantum.plugins.services.agent_loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
$device_driver = 'neutron.plugins.services.agent_loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
||||||
$use_namespaces = true,
|
$use_namespaces = true,
|
||||||
$user_group = 'nogroup',
|
$user_group = 'nogroup',
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
Quantum_config<||> ~> Service['quantum-lbaas-service']
|
Neutron_config<||> ~> Service['neutron-lbaas-service']
|
||||||
Quantum_lbaas_agent_config<||> ~> Service['quantum-lbaas-service']
|
Neutron_lbaas_agent_config<||> ~> Service['neutron-lbaas-service']
|
||||||
|
|
||||||
case $device_driver {
|
case $device_driver {
|
||||||
/\.haproxy/: {
|
/\.haproxy/: {
|
||||||
Package['haproxy'] -> Package<| title == 'quantum-lbaas-agent' |>
|
Package['haproxy'] -> Package<| title == 'neutron-lbaas-agent' |>
|
||||||
package { 'haproxy':
|
package { 'haproxy':
|
||||||
name => $::quantum::params::haproxy_package,
|
name => $::neutron::params::haproxy_package,
|
||||||
ensure => present,
|
ensure => present,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -55,10 +55,10 @@ class quantum::agents::lbaas (
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# The LBaaS agent loads both quantum.ini and its own file.
|
# The LBaaS agent loads both neutron.ini and its own file.
|
||||||
# This only lists config specific to the agent. quantum.ini supplies
|
# This only lists config specific to the agent. neutron.ini supplies
|
||||||
# the rest.
|
# the rest.
|
||||||
quantum_lbaas_agent_config {
|
neutron_lbaas_agent_config {
|
||||||
'DEFAULT/debug': value => $debug;
|
'DEFAULT/debug': value => $debug;
|
||||||
'DEFAULT/interface_driver': value => $interface_driver;
|
'DEFAULT/interface_driver': value => $interface_driver;
|
||||||
'DEFAULT/device_driver': value => $device_driver;
|
'DEFAULT/device_driver': value => $device_driver;
|
||||||
@ -66,18 +66,18 @@ class quantum::agents::lbaas (
|
|||||||
'DEFAULT/user_group': value => $user_group;
|
'DEFAULT/user_group': value => $user_group;
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::quantum::params::lbaas_agent_package {
|
if $::neutron::params::lbaas_agent_package {
|
||||||
Package['quantum'] -> Package['quantum-lbaas-agent']
|
Package['neutron'] -> Package['neutron-lbaas-agent']
|
||||||
Package['quantum-lbaas-agent'] -> Quantum_config<||>
|
Package['neutron-lbaas-agent'] -> Neutron_config<||>
|
||||||
Package['quantum-lbaas-agent'] -> Quantum_lbaas_agent_config<||>
|
Package['neutron-lbaas-agent'] -> Neutron_lbaas_agent_config<||>
|
||||||
package { 'quantum-lbaas-agent':
|
package { 'neutron-lbaas-agent':
|
||||||
name => $::quantum::params::lbaas_agent_package,
|
name => $::neutron::params::lbaas_agent_package,
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Some platforms (RedHat) do not provide a quantum LBaaS agent package.
|
# Some platforms (RedHat) do not provide a neutron LBaaS agent package.
|
||||||
# The quantum LBaaS agent config file is provided by the quantum package.
|
# The neutron LBaaS agent config file is provided by the neutron package.
|
||||||
Package['quantum'] -> Quantum_lbaas_agent_config<||>
|
Package['neutron'] -> Neutron_lbaas_agent_config<||>
|
||||||
}
|
}
|
||||||
|
|
||||||
if $enabled {
|
if $enabled {
|
||||||
@ -86,10 +86,10 @@ class quantum::agents::lbaas (
|
|||||||
$ensure = 'stopped'
|
$ensure = 'stopped'
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'quantum-lbaas-service':
|
service { 'neutron-lbaas-service':
|
||||||
name => $::quantum::params::lbaas_agent_service,
|
name => $::neutron::params::lbaas_agent_service,
|
||||||
enable => $enabled,
|
enable => $enabled,
|
||||||
ensure => $ensure,
|
ensure => $ensure,
|
||||||
require => Class['quantum'],
|
require => Class['neutron'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::agents::linuxbridge
|
# == Class: neutron::agents::linuxbridge
|
||||||
#
|
#
|
||||||
# Setups linuxbridge quantum agent.
|
# Setups linuxbridge neutron agent.
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
@ -10,8 +10,8 @@
|
|||||||
# network interfaces.
|
# network interfaces.
|
||||||
#
|
#
|
||||||
# [*firewall_driver*]
|
# [*firewall_driver*]
|
||||||
# (optional) Firewall driver for realizing quantum security group function.
|
# (optional) Firewall driver for realizing neutron security group function.
|
||||||
# Defaults to 'quantum.agent.linux.iptables_firewall.IptablesFirewallDriver'.
|
# Defaults to 'neutron.agent.linux.iptables_firewall.IptablesFirewallDriver'.
|
||||||
#
|
#
|
||||||
# [*package_ensure*]
|
# [*package_ensure*]
|
||||||
# (optional) Ensure state for package. Defaults to 'present'.
|
# (optional) Ensure state for package. Defaults to 'present'.
|
||||||
@ -19,31 +19,31 @@
|
|||||||
# [*enable*]
|
# [*enable*]
|
||||||
# (optional) Enable state for service. Defaults to 'true'.
|
# (optional) Enable state for service. Defaults to 'true'.
|
||||||
#
|
#
|
||||||
class quantum::agents::linuxbridge (
|
class neutron::agents::linuxbridge (
|
||||||
$physical_interface_mappings,
|
$physical_interface_mappings,
|
||||||
$firewall_driver = 'quantum.agent.linux.iptables_firewall.IptablesFirewallDriver',
|
$firewall_driver = 'neutron.agent.linux.iptables_firewall.IptablesFirewallDriver',
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enable = true
|
$enable = true
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
Quantum_config<||> ~> Service['quantum-plugin-linuxbridge-service']
|
Neutron_config<||> ~> Service['neutron-plugin-linuxbridge-service']
|
||||||
Quantum_plugin_linuxbridge<||> ~> Service<| title == 'quantum-plugin-linuxbridge-service' |>
|
Neutron_plugin_linuxbridge<||> ~> Service<| title == 'neutron-plugin-linuxbridge-service' |>
|
||||||
|
|
||||||
if $::quantum::params::linuxbridge_agent_package {
|
if $::neutron::params::linuxbridge_agent_package {
|
||||||
Package['quantum'] -> Package['quantum-plugin-linuxbridge-agent']
|
Package['neutron'] -> Package['neutron-plugin-linuxbridge-agent']
|
||||||
Package['quantum-plugin-linuxbridge-agent'] -> Quantum_plugin_linuxbridge<||>
|
Package['neutron-plugin-linuxbridge-agent'] -> Neutron_plugin_linuxbridge<||>
|
||||||
Package['quantum-plugin-linuxbridge-agent'] -> Service['quantum-plugin-linuxbridge-service']
|
Package['neutron-plugin-linuxbridge-agent'] -> Service['neutron-plugin-linuxbridge-service']
|
||||||
package { 'quantum-plugin-linuxbridge-agent':
|
package { 'neutron-plugin-linuxbridge-agent':
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
name => $::quantum::params::linuxbridge_agent_package,
|
name => $::neutron::params::linuxbridge_agent_package,
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Some platforms (RedHat) do not provide a separate quantum plugin
|
# Some platforms (RedHat) do not provide a separate neutron plugin
|
||||||
# linuxbridge agent package. The configuration file for the linuxbridge
|
# linuxbridge agent package. The configuration file for the linuxbridge
|
||||||
# agent is provided by the quantum linuxbridge plugin package.
|
# agent is provided by the neutron linuxbridge plugin package.
|
||||||
Package['quantum-plugin-linuxbridge'] -> Quantum_plugin_linuxbridge<||>
|
Package['neutron-plugin-linuxbridge'] -> Neutron_plugin_linuxbridge<||>
|
||||||
}
|
}
|
||||||
|
|
||||||
if $enable {
|
if $enable {
|
||||||
@ -52,14 +52,14 @@ class quantum::agents::linuxbridge (
|
|||||||
$service_ensure = 'stopped'
|
$service_ensure = 'stopped'
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_plugin_linuxbridge {
|
neutron_plugin_linuxbridge {
|
||||||
'LINUX_BRIDGE/physical_interface_mappings': value => $physical_interface_mappings;
|
'LINUX_BRIDGE/physical_interface_mappings': value => $physical_interface_mappings;
|
||||||
'SECURITYGROUP/firewall_driver': value => $firewall_driver;
|
'SECURITYGROUP/firewall_driver': value => $firewall_driver;
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'quantum-plugin-linuxbridge-service':
|
service { 'neutron-plugin-linuxbridge-service':
|
||||||
ensure => $service_ensure,
|
ensure => $service_ensure,
|
||||||
name => $::quantum::params::linuxbridge_agent_service,
|
name => $::neutron::params::linuxbridge_agent_service,
|
||||||
enable => $enable,
|
enable => $enable,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,24 +1,24 @@
|
|||||||
class quantum::agents::metadata (
|
class neutron::agents::metadata (
|
||||||
$auth_password,
|
$auth_password,
|
||||||
$shared_secret,
|
$shared_secret,
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$debug = false,
|
$debug = false,
|
||||||
$auth_tenant = 'services',
|
$auth_tenant = 'services',
|
||||||
$auth_user = 'quantum',
|
$auth_user = 'neutron',
|
||||||
$auth_url = 'http://localhost:35357/v2.0',
|
$auth_url = 'http://localhost:35357/v2.0',
|
||||||
$auth_region = 'RegionOne',
|
$auth_region = 'RegionOne',
|
||||||
$metadata_ip = '127.0.0.1',
|
$metadata_ip = '127.0.0.1',
|
||||||
$metadata_port = '8775'
|
$metadata_port = '8775'
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
Package['quantum'] -> Quantum_metadata_agent_config<||>
|
Package['neutron'] -> Neutron_metadata_agent_config<||>
|
||||||
Quantum_config<||> ~> Service['quantum-metadata']
|
Neutron_config<||> ~> Service['neutron-metadata']
|
||||||
Quantum_metadata_agent_config<||> ~> Service['quantum-metadata']
|
Neutron_metadata_agent_config<||> ~> Service['neutron-metadata']
|
||||||
|
|
||||||
quantum_metadata_agent_config {
|
neutron_metadata_agent_config {
|
||||||
'DEFAULT/debug': value => $debug;
|
'DEFAULT/debug': value => $debug;
|
||||||
'DEFAULT/auth_url': value => $auth_url;
|
'DEFAULT/auth_url': value => $auth_url;
|
||||||
'DEFAULT/auth_region': value => $auth_region;
|
'DEFAULT/auth_region': value => $auth_region;
|
||||||
@ -30,13 +30,13 @@ class quantum::agents::metadata (
|
|||||||
'DEFAULT/metadata_proxy_shared_secret': value => $shared_secret;
|
'DEFAULT/metadata_proxy_shared_secret': value => $shared_secret;
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::quantum::params::metadata_agent_package {
|
if $::neutron::params::metadata_agent_package {
|
||||||
Package['quantum-metadata'] -> Quantum_metadata_agent_config<||>
|
Package['neutron-metadata'] -> Neutron_metadata_agent_config<||>
|
||||||
Package['quantum-metadata'] -> Service['quantum-metadata']
|
Package['neutron-metadata'] -> Service['neutron-metadata']
|
||||||
package { 'quantum-metadata':
|
package { 'neutron-metadata':
|
||||||
name => $::quantum::params::metadata_agent_package,
|
name => $::neutron::params::metadata_agent_package,
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
require => Package['quantum'],
|
require => Package['neutron'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,10 +46,10 @@ class quantum::agents::metadata (
|
|||||||
$ensure = 'stopped'
|
$ensure = 'stopped'
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'quantum-metadata':
|
service { 'neutron-metadata':
|
||||||
name => $::quantum::params::metadata_agent_service,
|
name => $::neutron::params::metadata_agent_service,
|
||||||
enable => $enabled,
|
enable => $enabled,
|
||||||
ensure => $ensure,
|
ensure => $ensure,
|
||||||
require => Class['quantum'],
|
require => Class['neutron'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,14 +1,14 @@
|
|||||||
# == Class: quantum::agents::ovs
|
# == Class: neutron::agents::ovs
|
||||||
#
|
#
|
||||||
# Setups OVS quantum agent.
|
# Setups OVS neutron agent.
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
# [*firewall_driver*]
|
# [*firewall_driver*]
|
||||||
# (optional) Firewall driver for realizing quantum security group function.
|
# (optional) Firewall driver for realizing neutron security group function.
|
||||||
# Defaults to 'quantum.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'.
|
# Defaults to 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'.
|
||||||
#
|
#
|
||||||
class quantum::agents::ovs (
|
class neutron::agents::ovs (
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$bridge_uplinks = [],
|
$bridge_uplinks = [],
|
||||||
@ -18,23 +18,23 @@ class quantum::agents::ovs (
|
|||||||
$local_ip = false,
|
$local_ip = false,
|
||||||
$tunnel_bridge = 'br-tun',
|
$tunnel_bridge = 'br-tun',
|
||||||
$polling_interval = 2,
|
$polling_interval = 2,
|
||||||
$firewall_driver = 'quantum.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'
|
$firewall_driver = 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver'
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
require vswitch::ovs
|
require vswitch::ovs
|
||||||
|
|
||||||
if $enable_tunneling and ! $local_ip {
|
if $enable_tunneling and ! $local_ip {
|
||||||
fail('Local ip for ovs agent must be set when tunneling is enabled')
|
fail('Local ip for ovs agent must be set when tunneling is enabled')
|
||||||
}
|
}
|
||||||
|
|
||||||
Quantum_config<||> ~> Service['quantum-plugin-ovs-service']
|
Neutron_config<||> ~> Service['neutron-plugin-ovs-service']
|
||||||
Quantum_plugin_ovs<||> ~> Service['quantum-plugin-ovs-service']
|
Neutron_plugin_ovs<||> ~> Service['neutron-plugin-ovs-service']
|
||||||
|
|
||||||
if ($bridge_mappings != []) {
|
if ($bridge_mappings != []) {
|
||||||
# bridge_mappings are used to describe external networks that are
|
# bridge_mappings are used to describe external networks that are
|
||||||
# *directly* attached to this machine.
|
# *directly* attached to this machine.
|
||||||
# (This has nothing to do with VM-VM comms over quantum virtual networks.)
|
# (This has nothing to do with VM-VM comms over neutron virtual networks.)
|
||||||
# Typically, the network node - running L3 agent - will want one external
|
# Typically, the network node - running L3 agent - will want one external
|
||||||
# network (often this is on the control node) and the other nodes (all the
|
# network (often this is on the control node) and the other nodes (all the
|
||||||
# compute nodes) will want none at all. The only other reason you will
|
# compute nodes) will want none at all. The only other reason you will
|
||||||
@ -45,49 +45,49 @@ class quantum::agents::ovs (
|
|||||||
# mappings and uplinks; they're what the OVS switches will get named.)
|
# mappings and uplinks; they're what the OVS switches will get named.)
|
||||||
|
|
||||||
# Set config for bridges that we're going to create
|
# Set config for bridges that we're going to create
|
||||||
# The OVS quantum plugin will talk in terms of the networks in the bridge_mappings
|
# The OVS neutron plugin will talk in terms of the networks in the bridge_mappings
|
||||||
$br_map_str = join($bridge_mappings, ',')
|
$br_map_str = join($bridge_mappings, ',')
|
||||||
quantum_plugin_ovs {
|
neutron_plugin_ovs {
|
||||||
'OVS/bridge_mappings': value => $br_map_str;
|
'OVS/bridge_mappings': value => $br_map_str;
|
||||||
}
|
}
|
||||||
quantum::plugins::ovs::bridge{ $bridge_mappings:
|
neutron::plugins::ovs::bridge{ $bridge_mappings:
|
||||||
before => Service['quantum-plugin-ovs-service'],
|
before => Service['neutron-plugin-ovs-service'],
|
||||||
}
|
}
|
||||||
quantum::plugins::ovs::port{ $bridge_uplinks:
|
neutron::plugins::ovs::port{ $bridge_uplinks:
|
||||||
before => Service['quantum-plugin-ovs-service'],
|
before => Service['neutron-plugin-ovs-service'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_plugin_ovs {
|
neutron_plugin_ovs {
|
||||||
'AGENT/polling_interval': value => $polling_interval;
|
'AGENT/polling_interval': value => $polling_interval;
|
||||||
'OVS/integration_bridge': value => $integration_bridge;
|
'OVS/integration_bridge': value => $integration_bridge;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($firewall_driver) {
|
if ($firewall_driver) {
|
||||||
quantum_plugin_ovs { 'SECURITYGROUP/firewall_driver':
|
neutron_plugin_ovs { 'SECURITYGROUP/firewall_driver':
|
||||||
value => $firewall_driver
|
value => $firewall_driver
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
quantum_plugin_ovs { 'SECURITYGROUP/firewall_driver': ensure => absent }
|
neutron_plugin_ovs { 'SECURITYGROUP/firewall_driver': ensure => absent }
|
||||||
}
|
}
|
||||||
|
|
||||||
vs_bridge { $integration_bridge:
|
vs_bridge { $integration_bridge:
|
||||||
ensure => present,
|
ensure => present,
|
||||||
before => Service['quantum-plugin-ovs-service'],
|
before => Service['neutron-plugin-ovs-service'],
|
||||||
}
|
}
|
||||||
|
|
||||||
if $enable_tunneling {
|
if $enable_tunneling {
|
||||||
vs_bridge { $tunnel_bridge:
|
vs_bridge { $tunnel_bridge:
|
||||||
ensure => present,
|
ensure => present,
|
||||||
before => Service['quantum-plugin-ovs-service'],
|
before => Service['neutron-plugin-ovs-service'],
|
||||||
}
|
}
|
||||||
quantum_plugin_ovs {
|
neutron_plugin_ovs {
|
||||||
'OVS/enable_tunneling': value => true;
|
'OVS/enable_tunneling': value => true;
|
||||||
'OVS/tunnel_bridge': value => $tunnel_bridge;
|
'OVS/tunnel_bridge': value => $tunnel_bridge;
|
||||||
'OVS/local_ip': value => $local_ip;
|
'OVS/local_ip': value => $local_ip;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
quantum_plugin_ovs {
|
neutron_plugin_ovs {
|
||||||
'OVS/enable_tunneling': value => false;
|
'OVS/enable_tunneling': value => false;
|
||||||
'OVS/tunnel_bridge': ensure => absent;
|
'OVS/tunnel_bridge': ensure => absent;
|
||||||
'OVS/local_ip': ensure => absent;
|
'OVS/local_ip': ensure => absent;
|
||||||
@ -95,23 +95,23 @@ class quantum::agents::ovs (
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if $::quantum::params::ovs_agent_package {
|
if $::neutron::params::ovs_agent_package {
|
||||||
Package['quantum-plugin-ovs-agent'] -> Quantum_plugin_ovs<||>
|
Package['neutron-plugin-ovs-agent'] -> Neutron_plugin_ovs<||>
|
||||||
package { 'quantum-plugin-ovs-agent':
|
package { 'neutron-plugin-ovs-agent':
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
name => $::quantum::params::ovs_agent_package,
|
name => $::neutron::params::ovs_agent_package,
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Some platforms (RedHat) do not provide a separate
|
# Some platforms (RedHat) do not provide a separate
|
||||||
# quantum plugin ovs agent package. The configuration file for
|
# neutron plugin ovs agent package. The configuration file for
|
||||||
# the ovs agent is provided by the quantum ovs plugin package.
|
# the ovs agent is provided by the neutron ovs plugin package.
|
||||||
Package['quantum-plugin-ovs'] -> Quantum_plugin_ovs<||>
|
Package['neutron-plugin-ovs'] -> Neutron_plugin_ovs<||>
|
||||||
Package['quantum-plugin-ovs'] -> Service['ovs-cleanup-service']
|
Package['neutron-plugin-ovs'] -> Service['ovs-cleanup-service']
|
||||||
|
|
||||||
if ! defined(Package['quantum-plugin-ovs']) {
|
if ! defined(Package['neutron-plugin-ovs']) {
|
||||||
package { 'quantum-plugin-ovs':
|
package { 'neutron-plugin-ovs':
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
name => $::quantum::params::ovs_server_package,
|
name => $::neutron::params::ovs_server_package,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -122,17 +122,17 @@ class quantum::agents::ovs (
|
|||||||
$service_ensure = 'stopped'
|
$service_ensure = 'stopped'
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'quantum-plugin-ovs-service':
|
service { 'neutron-plugin-ovs-service':
|
||||||
ensure => $service_ensure,
|
ensure => $service_ensure,
|
||||||
name => $::quantum::params::ovs_agent_service,
|
name => $::neutron::params::ovs_agent_service,
|
||||||
enable => $enabled,
|
enable => $enabled,
|
||||||
require => Class['quantum'],
|
require => Class['neutron'],
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::quantum::params::ovs_cleanup_service {
|
if $::neutron::params::ovs_cleanup_service {
|
||||||
service {'ovs-cleanup-service':
|
service {'ovs-cleanup-service':
|
||||||
ensure => $service_ensure,
|
ensure => $service_ensure,
|
||||||
name => $::quantum::params::ovs_cleanup_service,
|
name => $::neutron::params::ovs_cleanup_service,
|
||||||
enable => $enabled,
|
enable => $enabled,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::client
|
# == Class: neutron::client
|
||||||
#
|
#
|
||||||
# Manages the quantum client package on systems
|
# Manages the neutron client package on systems
|
||||||
#
|
#
|
||||||
# === Parameters:
|
# === Parameters:
|
||||||
#
|
#
|
||||||
@ -8,14 +8,14 @@
|
|||||||
# (optional) The state of the package
|
# (optional) The state of the package
|
||||||
# Defaults to present
|
# Defaults to present
|
||||||
#
|
#
|
||||||
class quantum::client (
|
class neutron::client (
|
||||||
$package_ensure = present
|
$package_ensure = present
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
package { 'python-quantumclient':
|
package { 'python-neutronclient':
|
||||||
name => $::quantum::params::client_package_name,
|
name => $::neutron::params::client_package_name,
|
||||||
ensure => $package_ensure
|
ensure => $package_ensure
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
#
|
#
|
||||||
class quantum::db::mysql (
|
class neutron::db::mysql (
|
||||||
$password,
|
$password,
|
||||||
$dbname = 'quantum',
|
$dbname = 'neutron',
|
||||||
$user = 'quantum',
|
$user = 'neutron',
|
||||||
$host = '127.0.0.1',
|
$host = '127.0.0.1',
|
||||||
$allowed_hosts = undef,
|
$allowed_hosts = undef,
|
||||||
$charset = 'latin1',
|
$charset = 'latin1',
|
||||||
@ -27,7 +27,7 @@ class quantum::db::mysql (
|
|||||||
}
|
}
|
||||||
|
|
||||||
if $real_allowed_hosts {
|
if $real_allowed_hosts {
|
||||||
quantum::db::mysql::host_access { $real_allowed_hosts:
|
neutron::db::mysql::host_access { $real_allowed_hosts:
|
||||||
user => $user,
|
user => $user,
|
||||||
password => $password,
|
password => $password,
|
||||||
database => $dbname,
|
database => $dbname,
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# Used to grant access to the quantum mysql DB
|
# Used to grant access to the neutron mysql DB
|
||||||
#
|
#
|
||||||
define quantum::db::mysql::host_access ($user, $password, $database) {
|
define neutron::db::mysql::host_access ($user, $password, $database) {
|
||||||
database_user { "${user}@${name}":
|
database_user { "${user}@${name}":
|
||||||
password_hash => mysql_password($password),
|
password_hash => mysql_password($password),
|
||||||
provider => 'mysql',
|
provider => 'mysql',
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
# == Class: quantum
|
# == Class: neutron
|
||||||
#
|
#
|
||||||
# Installs the quantum package and configures
|
# Installs the neutron package and configures
|
||||||
# /etc/quantum/quantum.conf
|
# /etc/neutron/neutron.conf
|
||||||
#
|
#
|
||||||
# === Parameters:
|
# === Parameters:
|
||||||
#
|
#
|
||||||
# [*enabled*]
|
# [*enabled*]
|
||||||
# (required) Whether or not to enable the quantum service
|
# (required) Whether or not to enable the neutron service
|
||||||
# true/false
|
# true/false
|
||||||
#
|
#
|
||||||
# [*package_ensure*]
|
# [*package_ensure*]
|
||||||
@ -30,8 +30,8 @@
|
|||||||
# Defaults to 9696
|
# Defaults to 9696
|
||||||
#
|
#
|
||||||
# [*core_plugin*]
|
# [*core_plugin*]
|
||||||
# (optional) Quantum plugin provider
|
# (optional) Neutron plugin provider
|
||||||
# Defaults to OVSQquantumPluginV2 (openvswitch)
|
# Defaults to OVSQneutronPluginV2 (openvswitch)
|
||||||
#
|
#
|
||||||
# [*auth_strategy*]
|
# [*auth_strategy*]
|
||||||
# (optional) How to authenticate
|
# (optional) How to authenticate
|
||||||
@ -59,7 +59,7 @@
|
|||||||
#
|
#
|
||||||
# [*control_exchange*]
|
# [*control_exchange*]
|
||||||
# (optional) What RPC queue/exchange to use
|
# (optional) What RPC queue/exchange to use
|
||||||
# Defaults to quantum
|
# Defaults to neutron
|
||||||
|
|
||||||
# [*rpc_backend*]
|
# [*rpc_backend*]
|
||||||
# (optional) what rpc/queuing service to use
|
# (optional) what rpc/queuing service to use
|
||||||
@ -92,23 +92,23 @@
|
|||||||
# [*qpid_reconnect_interval_max*]
|
# [*qpid_reconnect_interval_max*]
|
||||||
# (optional) various QPID options
|
# (optional) various QPID options
|
||||||
#
|
#
|
||||||
class quantum (
|
class neutron (
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$verbose = false,
|
$verbose = false,
|
||||||
$debug = false,
|
$debug = false,
|
||||||
$bind_host = '0.0.0.0',
|
$bind_host = '0.0.0.0',
|
||||||
$bind_port = '9696',
|
$bind_port = '9696',
|
||||||
$core_plugin = 'quantum.plugins.openvswitch.ovs_quantum_plugin.OVSQuantumPluginV2',
|
$core_plugin = 'neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2',
|
||||||
$auth_strategy = 'keystone',
|
$auth_strategy = 'keystone',
|
||||||
$base_mac = 'fa:16:3e:00:00:00',
|
$base_mac = 'fa:16:3e:00:00:00',
|
||||||
$mac_generation_retries = 16,
|
$mac_generation_retries = 16,
|
||||||
$dhcp_lease_duration = 120,
|
$dhcp_lease_duration = 120,
|
||||||
$allow_bulk = true,
|
$allow_bulk = true,
|
||||||
$allow_overlapping_ips = false,
|
$allow_overlapping_ips = false,
|
||||||
$root_helper = 'sudo quantum-rootwrap /etc/quantum/rootwrap.conf',
|
$root_helper = 'sudo neutron-rootwrap /etc/neutron/rootwrap.conf',
|
||||||
$control_exchange = 'quantum',
|
$control_exchange = 'neutron',
|
||||||
$rpc_backend = 'quantum.openstack.common.rpc.impl_kombu',
|
$rpc_backend = 'neutron.openstack.common.rpc.impl_kombu',
|
||||||
$rabbit_password = false,
|
$rabbit_password = false,
|
||||||
$rabbit_host = 'localhost',
|
$rabbit_host = 'localhost',
|
||||||
$rabbit_hosts = false,
|
$rabbit_hosts = false,
|
||||||
@ -130,30 +130,30 @@ class quantum (
|
|||||||
$qpid_reconnect_interval = 0
|
$qpid_reconnect_interval = 0
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
Package['quantum'] -> Quantum_config<||>
|
Package['neutron'] -> Neutron_config<||>
|
||||||
|
|
||||||
File {
|
File {
|
||||||
require => Package['quantum'],
|
require => Package['neutron'],
|
||||||
owner => 'root',
|
owner => 'root',
|
||||||
group => 'quantum',
|
group => 'neutron',
|
||||||
mode => '0640',
|
mode => '0640',
|
||||||
}
|
}
|
||||||
|
|
||||||
file { '/etc/quantum':
|
file { '/etc/neutron':
|
||||||
ensure => directory,
|
ensure => directory,
|
||||||
mode => '0750',
|
mode => '0750',
|
||||||
}
|
}
|
||||||
|
|
||||||
file { '/etc/quantum/quantum.conf': }
|
file { '/etc/neutron/neutron.conf': }
|
||||||
|
|
||||||
package { 'quantum':
|
package { 'neutron':
|
||||||
name => $::quantum::params::package_name,
|
name => $::neutron::params::package_name,
|
||||||
ensure => $package_ensure
|
ensure => $package_ensure
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'DEFAULT/verbose': value => $verbose;
|
'DEFAULT/verbose': value => $verbose;
|
||||||
'DEFAULT/debug': value => $debug;
|
'DEFAULT/debug': value => $debug;
|
||||||
'DEFAULT/bind_host': value => $bind_host;
|
'DEFAULT/bind_host': value => $bind_host;
|
||||||
@ -170,29 +170,29 @@ class quantum (
|
|||||||
'AGENT/root_helper': value => $root_helper;
|
'AGENT/root_helper': value => $root_helper;
|
||||||
}
|
}
|
||||||
|
|
||||||
if $rpc_backend == 'quantum.openstack.common.rpc.impl_kombu' {
|
if $rpc_backend == 'neutron.openstack.common.rpc.impl_kombu' {
|
||||||
if ! $rabbit_password {
|
if ! $rabbit_password {
|
||||||
fail('When rpc_backend is rabbitmq, you must set rabbit password')
|
fail('When rpc_backend is rabbitmq, you must set rabbit password')
|
||||||
}
|
}
|
||||||
if $rabbit_hosts {
|
if $rabbit_hosts {
|
||||||
quantum_config { 'DEFAULT/rabbit_hosts': value => join($rabbit_hosts, ',') }
|
neutron_config { 'DEFAULT/rabbit_hosts': value => join($rabbit_hosts, ',') }
|
||||||
quantum_config { 'DEFAULT/rabbit_ha_queues': value => true }
|
neutron_config { 'DEFAULT/rabbit_ha_queues': value => true }
|
||||||
} else {
|
} else {
|
||||||
quantum_config { 'DEFAULT/rabbit_host': value => $rabbit_host }
|
neutron_config { 'DEFAULT/rabbit_host': value => $rabbit_host }
|
||||||
quantum_config { 'DEFAULT/rabbit_port': value => $rabbit_port }
|
neutron_config { 'DEFAULT/rabbit_port': value => $rabbit_port }
|
||||||
quantum_config { 'DEFAULT/rabbit_hosts': value => "${rabbit_host}:${rabbit_port}" }
|
neutron_config { 'DEFAULT/rabbit_hosts': value => "${rabbit_host}:${rabbit_port}" }
|
||||||
quantum_config { 'DEFAULT/rabbit_ha_queues': value => false }
|
neutron_config { 'DEFAULT/rabbit_ha_queues': value => false }
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'DEFAULT/rabbit_userid': value => $rabbit_user;
|
'DEFAULT/rabbit_userid': value => $rabbit_user;
|
||||||
'DEFAULT/rabbit_password': value => $rabbit_password;
|
'DEFAULT/rabbit_password': value => $rabbit_password;
|
||||||
'DEFAULT/rabbit_virtual_host': value => $rabbit_virtual_host;
|
'DEFAULT/rabbit_virtual_host': value => $rabbit_virtual_host;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if $rpc_backend == 'quantum.openstack.common.rpc.impl_qpid' {
|
if $rpc_backend == 'neutron.openstack.common.rpc.impl_qpid' {
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'DEFAULT/qpid_hostname': value => $qpid_hostname;
|
'DEFAULT/qpid_hostname': value => $qpid_hostname;
|
||||||
'DEFAULT/qpid_port': value => $qpid_port;
|
'DEFAULT/qpid_port': value => $qpid_port;
|
||||||
'DEFAULT/qpid_username': value => $qpid_username;
|
'DEFAULT/qpid_username': value => $qpid_username;
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
class quantum::keystone::auth (
|
class neutron::keystone::auth (
|
||||||
$password,
|
$password,
|
||||||
$auth_name = 'quantum',
|
$auth_name = 'neutron',
|
||||||
$email = 'quantum@localhost',
|
$email = 'neutron@localhost',
|
||||||
$tenant = 'services',
|
$tenant = 'services',
|
||||||
$configure_endpoint = true,
|
$configure_endpoint = true,
|
||||||
$service_type = 'network',
|
$service_type = 'network',
|
||||||
@ -14,7 +14,7 @@ class quantum::keystone::auth (
|
|||||||
$region = 'RegionOne'
|
$region = 'RegionOne'
|
||||||
) {
|
) {
|
||||||
|
|
||||||
Keystone_user_role["${auth_name}@${tenant}"] ~> Service <| name == 'quantum-server' |>
|
Keystone_user_role["${auth_name}@${tenant}"] ~> Service <| name == 'neutron-server' |>
|
||||||
|
|
||||||
if ! $public_port {
|
if ! $public_port {
|
||||||
$real_public_port = $port
|
$real_public_port = $port
|
||||||
@ -35,7 +35,7 @@ class quantum::keystone::auth (
|
|||||||
keystone_service { $auth_name:
|
keystone_service { $auth_name:
|
||||||
ensure => present,
|
ensure => present,
|
||||||
type => $service_type,
|
type => $service_type,
|
||||||
description => 'Quantum Networking Service',
|
description => 'Neutron Networking Service',
|
||||||
}
|
}
|
||||||
|
|
||||||
if $configure_endpoint {
|
if $configure_endpoint {
|
||||||
|
@ -1,34 +1,34 @@
|
|||||||
class quantum::params {
|
class neutron::params {
|
||||||
|
|
||||||
if($::osfamily == 'Redhat') {
|
if($::osfamily == 'Redhat') {
|
||||||
$package_name = 'openstack-quantum'
|
$package_name = 'openstack-neutron'
|
||||||
$server_package = false
|
$server_package = false
|
||||||
$server_service = 'quantum-server'
|
$server_service = 'neutron-server'
|
||||||
|
|
||||||
$ovs_agent_package = false
|
$ovs_agent_package = false
|
||||||
$ovs_agent_service = 'quantum-openvswitch-agent'
|
$ovs_agent_service = 'neutron-openvswitch-agent'
|
||||||
$ovs_server_package = 'openstack-quantum-openvswitch'
|
$ovs_server_package = 'openstack-neutron-openvswitch'
|
||||||
$ovs_cleanup_service = 'quantum-ovs-cleanup'
|
$ovs_cleanup_service = 'neutron-ovs-cleanup'
|
||||||
|
|
||||||
$linuxbridge_agent_package = false
|
$linuxbridge_agent_package = false
|
||||||
$linuxbridge_agent_service = 'quantum-linuxbridge-agent'
|
$linuxbridge_agent_service = 'neutron-linuxbridge-agent'
|
||||||
$linuxbridge_server_package = 'openstack-quantum-linuxbridge'
|
$linuxbridge_server_package = 'openstack-neutron-linuxbridge'
|
||||||
$linuxbridge_config_file = '/etc/quantum/plugins/linuxbridge/linuxbridge_conf.ini'
|
$linuxbridge_config_file = '/etc/neutron/plugins/linuxbridge/linuxbridge_conf.ini'
|
||||||
|
|
||||||
$dhcp_agent_package = false
|
$dhcp_agent_package = false
|
||||||
$dhcp_agent_service = 'quantum-dhcp-agent'
|
$dhcp_agent_service = 'neutron-dhcp-agent'
|
||||||
|
|
||||||
$dnsmasq_packages = ['dnsmasq', 'dnsmasq-utils']
|
$dnsmasq_packages = ['dnsmasq', 'dnsmasq-utils']
|
||||||
|
|
||||||
$lbaas_agent_package = false
|
$lbaas_agent_package = false
|
||||||
$lbaas_agent_service = 'quantum-lbaas-agent'
|
$lbaas_agent_service = 'neutron-lbaas-agent'
|
||||||
|
|
||||||
$haproxy_package = 'haproxy'
|
$haproxy_package = 'haproxy'
|
||||||
|
|
||||||
$l3_agent_package = false
|
$l3_agent_package = false
|
||||||
$l3_agent_service = 'quantum-l3-agent'
|
$l3_agent_service = 'neutron-l3-agent'
|
||||||
|
|
||||||
$metadata_agent_service = 'quantum-metadata-agent'
|
$metadata_agent_service = 'neutron-metadata-agent'
|
||||||
|
|
||||||
$cliff_package = 'python-cliff'
|
$cliff_package = 'python-cliff'
|
||||||
|
|
||||||
@ -36,37 +36,37 @@ class quantum::params {
|
|||||||
|
|
||||||
} elsif($::osfamily == 'Debian') {
|
} elsif($::osfamily == 'Debian') {
|
||||||
|
|
||||||
$package_name = 'quantum-common'
|
$package_name = 'neutron-common'
|
||||||
$server_package = 'quantum-server'
|
$server_package = 'neutron-server'
|
||||||
$server_service = 'quantum-server'
|
$server_service = 'neutron-server'
|
||||||
|
|
||||||
$ovs_agent_package = 'quantum-plugin-openvswitch-agent'
|
$ovs_agent_package = 'neutron-plugin-openvswitch-agent'
|
||||||
$ovs_agent_service = 'quantum-plugin-openvswitch-agent'
|
$ovs_agent_service = 'neutron-plugin-openvswitch-agent'
|
||||||
$ovs_server_package = 'quantum-plugin-openvswitch'
|
$ovs_server_package = 'neutron-plugin-openvswitch'
|
||||||
$ovs_cleanup_service = false
|
$ovs_cleanup_service = false
|
||||||
|
|
||||||
$linuxbridge_agent_package = 'quantum-plugin-linuxbridge-agent'
|
$linuxbridge_agent_package = 'neutron-plugin-linuxbridge-agent'
|
||||||
$linuxbridge_agent_service = 'quantum-plugin-linuxbridge-agent'
|
$linuxbridge_agent_service = 'neutron-plugin-linuxbridge-agent'
|
||||||
$linuxbridge_server_package = 'quantum-plugin-linuxbridge'
|
$linuxbridge_server_package = 'neutron-plugin-linuxbridge'
|
||||||
$linuxbridge_config_file = '/etc/quantum/plugins/linuxbridge/linuxbridge_conf.ini'
|
$linuxbridge_config_file = '/etc/neutron/plugins/linuxbridge/linuxbridge_conf.ini'
|
||||||
|
|
||||||
$dhcp_agent_package = 'quantum-dhcp-agent'
|
$dhcp_agent_package = 'neutron-dhcp-agent'
|
||||||
$dhcp_agent_service = 'quantum-dhcp-agent'
|
$dhcp_agent_service = 'neutron-dhcp-agent'
|
||||||
|
|
||||||
$lbaas_agent_package = 'quantum-lbaas-agent'
|
$lbaas_agent_package = 'neutron-lbaas-agent'
|
||||||
$lbaas_agent_service = 'quantum-lbaas-agent'
|
$lbaas_agent_service = 'neutron-lbaas-agent'
|
||||||
|
|
||||||
$haproxy_package = 'haproxy'
|
$haproxy_package = 'haproxy'
|
||||||
|
|
||||||
$metadata_agent_package = 'quantum-metadata-agent'
|
$metadata_agent_package = 'neutron-metadata-agent'
|
||||||
$metadata_agent_service = 'quantum-metadata-agent'
|
$metadata_agent_service = 'neutron-metadata-agent'
|
||||||
|
|
||||||
$dnsmasq_packages = ['dnsmasq-base', 'dnsmasq-utils']
|
$dnsmasq_packages = ['dnsmasq-base', 'dnsmasq-utils']
|
||||||
|
|
||||||
$isc_dhcp_packages = ['isc-dhcp-server']
|
$isc_dhcp_packages = ['isc-dhcp-server']
|
||||||
|
|
||||||
$l3_agent_package = 'quantum-l3-agent'
|
$l3_agent_package = 'neutron-l3-agent'
|
||||||
$l3_agent_service = 'quantum-l3-agent'
|
$l3_agent_service = 'neutron-l3-agent'
|
||||||
|
|
||||||
$cliff_package = 'python-cliff'
|
$cliff_package = 'python-cliff'
|
||||||
$kernel_headers = "linux-headers-${::kernelrelease}"
|
$kernel_headers = "linux-headers-${::kernelrelease}"
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
|
|
||||||
#
|
#
|
||||||
# Configure the cisco quantum plugin
|
# Configure the cisco neutron plugin
|
||||||
# More info available here:
|
# More info available here:
|
||||||
# https://wiki.openstack.org/wiki/Cisco-quantum
|
# https://wiki.openstack.org/wiki/Cisco-neutron
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
@ -14,11 +14,11 @@
|
|||||||
#
|
#
|
||||||
# [*database_name*]
|
# [*database_name*]
|
||||||
# The name of the db table to use
|
# The name of the db table to use
|
||||||
# Defaults to quantum
|
# Defaults to neutron
|
||||||
#
|
#
|
||||||
# [*database_user*]
|
# [*database_user*]
|
||||||
# The user that will be used to connect to the db
|
# The user that will be used to connect to the db
|
||||||
# Defaults to quantum
|
# Defaults to neutron
|
||||||
#
|
#
|
||||||
# [*database_host*]
|
# [*database_host*]
|
||||||
# The address or hostname of the database
|
# The address or hostname of the database
|
||||||
@ -26,7 +26,7 @@
|
|||||||
#
|
#
|
||||||
# [*keystone_username*]
|
# [*keystone_username*]
|
||||||
# The admin username for the plugin to use
|
# The admin username for the plugin to use
|
||||||
# Defaults to quantum
|
# Defaults to neutron
|
||||||
#
|
#
|
||||||
# [*keystone_auth_url*]
|
# [*keystone_auth_url*]
|
||||||
# The url against which to authenticate
|
# The url against which to authenticate
|
||||||
@ -38,103 +38,103 @@
|
|||||||
#
|
#
|
||||||
# [*vswitch_plugin*]
|
# [*vswitch_plugin*]
|
||||||
# (optional) The openvswitch plugin to use
|
# (optional) The openvswitch plugin to use
|
||||||
# Defaults to ovs_quantum_plugin.OVSQuantumPluginV2
|
# Defaults to ovs_neutron_plugin.OVSNeutronPluginV2
|
||||||
#
|
#
|
||||||
# [*nexus_plugin*]
|
# [*nexus_plugin*]
|
||||||
# (optional) The nexus plugin to use
|
# (optional) The nexus plugin to use
|
||||||
# Defaults to undef. This will not set a nexus plugin to use
|
# Defaults to undef. This will not set a nexus plugin to use
|
||||||
# Can be set to quantum.plugins.cisco.nexus.cisco_nexus_plugin_v2.NexusPlugin
|
# Can be set to neutron.plugins.cisco.nexus.cisco_nexus_plugin_v2.NexusPlugin
|
||||||
#
|
#
|
||||||
# Other parameters are currently not used by the plugin and
|
# Other parameters are currently not used by the plugin and
|
||||||
# can be left unchanged, but in grizzly the plugin will fail
|
# can be left unchanged, but in grizzly the plugin will fail
|
||||||
# to launch if they are not there. The config for Havana will
|
# to launch if they are not there. The config for Havana will
|
||||||
# move to a single config file and this will be simplified.
|
# move to a single config file and this will be simplified.
|
||||||
|
|
||||||
class quantum::plugins::cisco(
|
class neutron::plugins::cisco(
|
||||||
$keystone_password,
|
$keystone_password,
|
||||||
$database_pass,
|
$database_pass,
|
||||||
|
|
||||||
# Database connection
|
# Database connection
|
||||||
$database_name = 'quantum',
|
$database_name = 'neutron',
|
||||||
$database_user = 'quantum',
|
$database_user = 'neutron',
|
||||||
$database_host = '127.0.0.1',
|
$database_host = '127.0.0.1',
|
||||||
|
|
||||||
# Keystone connection
|
# Keystone connection
|
||||||
$keystone_username = 'quantum',
|
$keystone_username = 'neutron',
|
||||||
$keystone_tenant = 'services',
|
$keystone_tenant = 'services',
|
||||||
$keystone_auth_url = 'http://127.0.0.1:35357/v2.0/',
|
$keystone_auth_url = 'http://127.0.0.1:35357/v2.0/',
|
||||||
|
|
||||||
$vswitch_plugin = 'quantum.plugins.openvswitch.ovs_quantum_plugin.OVSQuantumPluginV2',
|
$vswitch_plugin = 'neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2',
|
||||||
$nexus_plugin = undef,
|
$nexus_plugin = undef,
|
||||||
|
|
||||||
# Plugin minimum configuration
|
# Plugin minimum configuration
|
||||||
$vlan_start = '100',
|
$vlan_start = '100',
|
||||||
$vlan_end = '3000',
|
$vlan_end = '3000',
|
||||||
$vlan_name_prefix = 'q-',
|
$vlan_name_prefix = 'q-',
|
||||||
$model_class = 'quantum.plugins.cisco.models.virt_phy_sw_v2.VirtualPhysicalSwitchModelV2',
|
$model_class = 'neutron.plugins.cisco.models.virt_phy_sw_v2.VirtualPhysicalSwitchModelV2',
|
||||||
$max_ports = '100',
|
$max_ports = '100',
|
||||||
$max_port_profiles = '65568',
|
$max_port_profiles = '65568',
|
||||||
$manager_class = 'quantum.plugins.cisco.segmentation.l2network_vlan_mgr_v2.L2NetworkVLANMgr',
|
$manager_class = 'neutron.plugins.cisco.segmentation.l2network_vlan_mgr_v2.L2NetworkVLANMgr',
|
||||||
$max_networks = '65568'
|
$max_networks = '65568'
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
Quantum_plugin_cisco<||> ~> Service['quantum-server']
|
Neutron_plugin_cisco<||> ~> Service['neutron-server']
|
||||||
Quantum_plugin_cisco_db_conn<||> ~> Service['quantum-server']
|
Neutron_plugin_cisco_db_conn<||> ~> Service['neutron-server']
|
||||||
Quantum_plugin_cisco_l2network<||> ~> Service['quantum-server']
|
Neutron_plugin_cisco_l2network<||> ~> Service['neutron-server']
|
||||||
|
|
||||||
ensure_resource('file', '/etc/quantum/plugins', {
|
ensure_resource('file', '/etc/neutron/plugins', {
|
||||||
ensure => directory,
|
ensure => directory,
|
||||||
owner => 'root',
|
owner => 'root',
|
||||||
group => 'quantum',
|
group => 'neutron',
|
||||||
mode => '0640'}
|
mode => '0640'}
|
||||||
)
|
)
|
||||||
|
|
||||||
ensure_resource('file', '/etc/quantum/plugins/cisco', {
|
ensure_resource('file', '/etc/neutron/plugins/cisco', {
|
||||||
ensure => directory,
|
ensure => directory,
|
||||||
owner => 'root',
|
owner => 'root',
|
||||||
group => 'quantum',
|
group => 'neutron',
|
||||||
mode => '0640'}
|
mode => '0640'}
|
||||||
)
|
)
|
||||||
|
|
||||||
# Ensure the quantum package is installed before config is set
|
# Ensure the neutron package is installed before config is set
|
||||||
# under both RHEL and Ubuntu
|
# under both RHEL and Ubuntu
|
||||||
if ($::quantum::params::server_package) {
|
if ($::neutron::params::server_package) {
|
||||||
Package['quantum-server'] -> Quantum_plugin_cisco<||>
|
Package['neutron-server'] -> Neutron_plugin_cisco<||>
|
||||||
Package['quantum-server'] -> Quantum_plugin_cisco_db_conn<||>
|
Package['neutron-server'] -> Neutron_plugin_cisco_db_conn<||>
|
||||||
Package['quantum-server'] -> Quantum_plugin_cisco_l2network<||>
|
Package['neutron-server'] -> Neutron_plugin_cisco_l2network<||>
|
||||||
} else {
|
} else {
|
||||||
Package['quantum'] -> Quantum_plugin_cisco<||>
|
Package['neutron'] -> Neutron_plugin_cisco<||>
|
||||||
Package['quantum'] -> Quantum_plugin_cisco_db_conn<||>
|
Package['neutron'] -> Neutron_plugin_cisco_db_conn<||>
|
||||||
Package['quantum'] -> Quantum_plugin_cisco_l2network<||>
|
Package['neutron'] -> Neutron_plugin_cisco_l2network<||>
|
||||||
}
|
}
|
||||||
|
|
||||||
if $nexus_plugin {
|
if $nexus_plugin {
|
||||||
quantum_plugin_cisco {
|
neutron_plugin_cisco {
|
||||||
'PLUGINS/nexus_plugin' : value => $nexus_plugin;
|
'PLUGINS/nexus_plugin' : value => $nexus_plugin;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if $vswitch_plugin {
|
if $vswitch_plugin {
|
||||||
quantum_plugin_cisco {
|
neutron_plugin_cisco {
|
||||||
'PLUGINS/vswitch_plugin' : value => $vswitch_plugin;
|
'PLUGINS/vswitch_plugin' : value => $vswitch_plugin;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# quantum-server will crash if the inventory section is empty.
|
# neutron-server will crash if the inventory section is empty.
|
||||||
# this is usually used for specifying which physical nexus
|
# this is usually used for specifying which physical nexus
|
||||||
# devices are to be used.
|
# devices are to be used.
|
||||||
quantum_plugin_cisco {
|
neutron_plugin_cisco {
|
||||||
'INVENTORY/dummy' : value => 'dummy';
|
'INVENTORY/dummy' : value => 'dummy';
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_plugin_cisco_db_conn {
|
neutron_plugin_cisco_db_conn {
|
||||||
'DATABASE/name': value => $database_name;
|
'DATABASE/name': value => $database_name;
|
||||||
'DATABASE/user': value => $database_user;
|
'DATABASE/user': value => $database_user;
|
||||||
'DATABASE/pass': value => $database_pass;
|
'DATABASE/pass': value => $database_pass;
|
||||||
'DATABASE/host': value => $database_host;
|
'DATABASE/host': value => $database_host;
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_plugin_cisco_l2network {
|
neutron_plugin_cisco_l2network {
|
||||||
'VLANS/vlan_start': value => $vlan_start;
|
'VLANS/vlan_start': value => $vlan_start;
|
||||||
'VLANS/vlan_end': value => $vlan_end;
|
'VLANS/vlan_end': value => $vlan_end;
|
||||||
'VLANS/vlan_name_prefix': value => $vlan_name_prefix;
|
'VLANS/vlan_name_prefix': value => $vlan_name_prefix;
|
||||||
@ -145,7 +145,7 @@ class quantum::plugins::cisco(
|
|||||||
'SEGMENTATION/manager_class': value => $manager_class;
|
'SEGMENTATION/manager_class': value => $manager_class;
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_plugin_cisco_credentials {
|
neutron_plugin_cisco_credentials {
|
||||||
'keystone/username': value => $keystone_username;
|
'keystone/username': value => $keystone_username;
|
||||||
'keystone/password': value => $keystone_password;
|
'keystone/password': value => $keystone_password;
|
||||||
'keystone/auth_url': value => $keystone_auth_url;
|
'keystone/auth_url': value => $keystone_auth_url;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::plugins::linuxbridge
|
# == Class: neutron::plugins::linuxbridge
|
||||||
#
|
#
|
||||||
# Setups linuxbridge plugin for quantum server.
|
# Setups linuxbridge plugin for neutron server.
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
@ -20,46 +20,46 @@
|
|||||||
# [*package_ensure*]
|
# [*package_ensure*]
|
||||||
# (optional) Ensure state for package. Defaults to 'present'.
|
# (optional) Ensure state for package. Defaults to 'present'.
|
||||||
#
|
#
|
||||||
class quantum::plugins::linuxbridge (
|
class neutron::plugins::linuxbridge (
|
||||||
$sql_connection = 'sqlite:////var/lib/quantum/linuxbridge.sqlite',
|
$sql_connection = 'sqlite:////var/lib/neutron/linuxbridge.sqlite',
|
||||||
$network_vlan_ranges = 'physnet1:1000:2000',
|
$network_vlan_ranges = 'physnet1:1000:2000',
|
||||||
$tenant_network_type = 'vlan',
|
$tenant_network_type = 'vlan',
|
||||||
$package_ensure = 'present'
|
$package_ensure = 'present'
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
|
|
||||||
Package['quantum'] -> Package['quantum-plugin-linuxbridge']
|
Package['neutron'] -> Package['neutron-plugin-linuxbridge']
|
||||||
Package['quantum-plugin-linuxbridge'] -> Quantum_plugin_linuxbridge<||>
|
Package['neutron-plugin-linuxbridge'] -> Neutron_plugin_linuxbridge<||>
|
||||||
Quantum_plugin_linuxbridge<||> ~> Service<| title == 'quantum-server' |>
|
Neutron_plugin_linuxbridge<||> ~> Service<| title == 'neutron-server' |>
|
||||||
Package['quantum-plugin-linuxbridge'] -> Service<| title == 'quantum-server' |>
|
Package['neutron-plugin-linuxbridge'] -> Service<| title == 'neutron-server' |>
|
||||||
|
|
||||||
if $::osfamily == 'Debian' {
|
if $::osfamily == 'Debian' {
|
||||||
file_line { '/etc/default/quantum-server:QUANTUM_PLUGIN_CONFIG':
|
file_line { '/etc/default/neutron-server:NEUTRON_PLUGIN_CONFIG':
|
||||||
path => '/etc/default/quantum-server',
|
path => '/etc/default/neutron-server',
|
||||||
match => '^QUANTUM_PLUGIN_CONFIG=(.*)$',
|
match => '^NEUTRON_PLUGIN_CONFIG=(.*)$',
|
||||||
line => "QUANTUM_PLUGIN_CONFIG=${::quantum::params::linuxbridge_config_file}",
|
line => "NEUTRON_PLUGIN_CONFIG=${::neutron::params::linuxbridge_config_file}",
|
||||||
require => Package['quantum-plugin-linuxbridge'],
|
require => Package['neutron-plugin-linuxbridge'],
|
||||||
notify => Service['quantum-server'],
|
notify => Service['neutron-server'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
package { 'quantum-plugin-linuxbridge':
|
package { 'neutron-plugin-linuxbridge':
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
name => $::quantum::params::linuxbridge_server_package,
|
name => $::neutron::params::linuxbridge_server_package,
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_plugin_linuxbridge {
|
neutron_plugin_linuxbridge {
|
||||||
'DATABASE/sql_connection': value => $sql_connection;
|
'DATABASE/sql_connection': value => $sql_connection;
|
||||||
'VLANS/tenant_network_type': value => $tenant_network_type;
|
'VLANS/tenant_network_type': value => $tenant_network_type;
|
||||||
'VLANS/network_vlan_ranges': value => $network_vlan_ranges;
|
'VLANS/network_vlan_ranges': value => $network_vlan_ranges;
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::osfamily == 'Redhat' {
|
if $::osfamily == 'Redhat' {
|
||||||
file {'/etc/quantum/plugin.ini':
|
file {'/etc/neutron/plugin.ini':
|
||||||
ensure => link,
|
ensure => link,
|
||||||
target => '/etc/quantum/plugins/linuxbridge/linuxbridge_conf.ini',
|
target => '/etc/neutron/plugins/linuxbridge/linuxbridge_conf.ini',
|
||||||
require => Package['quantum-plugin-linuxbridge']
|
require => Package['neutron-plugin-linuxbridge']
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Configure the quantum server to use the OVS plugin.
|
# Configure the neutron server to use the OVS plugin.
|
||||||
# This configures the plugin for the API server, but does nothing
|
# This configures the plugin for the API server, but does nothing
|
||||||
# about configuring the agents that must also run and share a config
|
# about configuring the agents that must also run and share a config
|
||||||
# file with the OVS plugin if both are on the same machine.
|
# file with the OVS plugin if both are on the same machine.
|
||||||
@ -9,9 +9,9 @@
|
|||||||
# (optional) Timeout for SQL to reap connetions.
|
# (optional) Timeout for SQL to reap connetions.
|
||||||
# Defaults to '3600'.
|
# Defaults to '3600'.
|
||||||
#
|
#
|
||||||
class quantum::plugins::ovs (
|
class neutron::plugins::ovs (
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$sql_connection = 'sqlite:////var/lib/quantum/ovs.sqlite',
|
$sql_connection = 'sqlite:////var/lib/neutron/ovs.sqlite',
|
||||||
$sql_max_retries = 10,
|
$sql_max_retries = 10,
|
||||||
$sql_idle_timeout = '3600',
|
$sql_idle_timeout = '3600',
|
||||||
$reconnect_interval = 2,
|
$reconnect_interval = 2,
|
||||||
@ -26,13 +26,13 @@ class quantum::plugins::ovs (
|
|||||||
$tunnel_id_ranges = '1:1000'
|
$tunnel_id_ranges = '1:1000'
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
require vswitch::ovs
|
require vswitch::ovs
|
||||||
|
|
||||||
Package['quantum'] -> Package['quantum-plugin-ovs']
|
Package['neutron'] -> Package['neutron-plugin-ovs']
|
||||||
Package['quantum-plugin-ovs'] -> Quantum_plugin_ovs<||>
|
Package['neutron-plugin-ovs'] -> Neutron_plugin_ovs<||>
|
||||||
Quantum_plugin_ovs<||> ~> Service<| title == 'quantum-server' |>
|
Neutron_plugin_ovs<||> ~> Service<| title == 'neutron-server' |>
|
||||||
Package['quantum-plugin-ovs'] -> Service<| title == 'quantum-server' |>
|
Package['neutron-plugin-ovs'] -> Service<| title == 'neutron-server' |>
|
||||||
|
|
||||||
validate_re($sql_connection, '(sqlite|mysql|postgresql):\/\/(\S+:\S+@\S+\/\S+)?')
|
validate_re($sql_connection, '(sqlite|mysql|postgresql):\/\/(\S+:\S+@\S+\/\S+)?')
|
||||||
|
|
||||||
@ -51,14 +51,14 @@ class quantum::plugins::ovs (
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ! defined(Package['quantum-plugin-ovs']) {
|
if ! defined(Package['neutron-plugin-ovs']) {
|
||||||
package { 'quantum-plugin-ovs':
|
package { 'neutron-plugin-ovs':
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
name => $::quantum::params::ovs_server_package,
|
name => $::neutron::params::ovs_server_package,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_plugin_ovs {
|
neutron_plugin_ovs {
|
||||||
'DATABASE/sql_connection': value => $sql_connection;
|
'DATABASE/sql_connection': value => $sql_connection;
|
||||||
'DATABASE/sql_max_retries': value => $sql_max_retries;
|
'DATABASE/sql_max_retries': value => $sql_max_retries;
|
||||||
'DATABASE/sql_idle_timeout': value => $sql_idle_timeout;
|
'DATABASE/sql_idle_timeout': value => $sql_idle_timeout;
|
||||||
@ -67,7 +67,7 @@ class quantum::plugins::ovs (
|
|||||||
}
|
}
|
||||||
|
|
||||||
if($tenant_network_type == 'gre') {
|
if($tenant_network_type == 'gre') {
|
||||||
quantum_plugin_ovs {
|
neutron_plugin_ovs {
|
||||||
# this is set by the plugin and the agent - since the plugin node has the agent installed
|
# this is set by the plugin and the agent - since the plugin node has the agent installed
|
||||||
# we rely on it setting it.
|
# we rely on it setting it.
|
||||||
# TODO(ijw): do something with a virtualised node
|
# TODO(ijw): do something with a virtualised node
|
||||||
@ -84,23 +84,23 @@ class quantum::plugins::ovs (
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if ! $network_vlan_ranges {
|
if ! $network_vlan_ranges {
|
||||||
quantum_plugin_ovs { 'OVS/network_vlan_ranges': ensure => absent }
|
neutron_plugin_ovs { 'OVS/network_vlan_ranges': ensure => absent }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# This might be set by the user for the gre case where
|
# This might be set by the user for the gre case where
|
||||||
# provider networks are in use
|
# provider networks are in use
|
||||||
if $network_vlan_ranges {
|
if $network_vlan_ranges {
|
||||||
quantum_plugin_ovs {
|
neutron_plugin_ovs {
|
||||||
'OVS/network_vlan_ranges': value => $network_vlan_ranges
|
'OVS/network_vlan_ranges': value => $network_vlan_ranges
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if $::osfamily == 'Redhat' {
|
if $::osfamily == 'Redhat' {
|
||||||
file {'/etc/quantum/plugin.ini':
|
file {'/etc/neutron/plugin.ini':
|
||||||
ensure => link,
|
ensure => link,
|
||||||
target => '/etc/quantum/plugins/openvswitch/ovs_quantum_plugin.ini',
|
target => '/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini',
|
||||||
require => Package['quantum-plugin-ovs']
|
require => Package['neutron-plugin-ovs']
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
define quantum::plugins::ovs::bridge {
|
define neutron::plugins::ovs::bridge {
|
||||||
$mapping = split($name, ':')
|
$mapping = split($name, ':')
|
||||||
$bridge = $mapping[1]
|
$bridge = $mapping[1]
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
define quantum::plugins::ovs::port {
|
define neutron::plugins::ovs::port {
|
||||||
$mapping = split($name, ':')
|
$mapping = split($name, ':')
|
||||||
vs_port {$mapping[1]:
|
vs_port {$mapping[1]:
|
||||||
ensure => present,
|
ensure => present,
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::quota
|
# == Class: neutron::quota
|
||||||
#
|
#
|
||||||
# Setups quantum quota.
|
# Setups neutron quota.
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
@ -40,7 +40,7 @@
|
|||||||
#
|
#
|
||||||
# [*quota_driver*]
|
# [*quota_driver*]
|
||||||
# (optional) Default driver to use for quota checks.
|
# (optional) Default driver to use for quota checks.
|
||||||
# Defaults to 'quantum.quota.ConfDriver'.
|
# Defaults to 'neutron.quota.ConfDriver'.
|
||||||
#
|
#
|
||||||
# [*quota_firewall*]
|
# [*quota_firewall*]
|
||||||
# (optional) Number of firewalls allowed per tenant, -1 for unlimited.
|
# (optional) Number of firewalls allowed per tenant, -1 for unlimited.
|
||||||
@ -54,7 +54,7 @@
|
|||||||
# (optional) Number of firewalls rules allowed per tenant, -1 for unlimited.
|
# (optional) Number of firewalls rules allowed per tenant, -1 for unlimited.
|
||||||
# Defaults to '-1'.
|
# Defaults to '-1'.
|
||||||
#
|
#
|
||||||
class quantum::quota (
|
class neutron::quota (
|
||||||
$default_quota = -1,
|
$default_quota = -1,
|
||||||
$quota_network = 10,
|
$quota_network = 10,
|
||||||
$quota_subnet = 10,
|
$quota_subnet = 10,
|
||||||
@ -65,13 +65,13 @@ class quantum::quota (
|
|||||||
# securitygroup extension
|
# securitygroup extension
|
||||||
$quota_security_group = 10,
|
$quota_security_group = 10,
|
||||||
$quota_security_group_rule = 100,
|
$quota_security_group_rule = 100,
|
||||||
$quota_driver = 'quantum.quota.ConfDriver',
|
$quota_driver = 'neutron.quota.ConfDriver',
|
||||||
$quota_firewall = 1,
|
$quota_firewall = 1,
|
||||||
$quota_firewall_policy = 1,
|
$quota_firewall_policy = 1,
|
||||||
$quota_firewall_rule = -1
|
$quota_firewall_rule = -1
|
||||||
) {
|
) {
|
||||||
|
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'QUOTAS/default_quota': value => $default_quota;
|
'QUOTAS/default_quota': value => $default_quota;
|
||||||
'QUOTAS/quota_network': value => $quota_network;
|
'QUOTAS/quota_network': value => $quota_network;
|
||||||
'QUOTAS/quota_subnet': value => $quota_subnet;
|
'QUOTAS/quota_subnet': value => $quota_subnet;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# == Class: quantum::server
|
# == Class: neutron::server
|
||||||
#
|
#
|
||||||
# Setup and configure the quantum API endpoint
|
# Setup and configure the neutron API endpoint
|
||||||
#
|
#
|
||||||
# === Parameters
|
# === Parameters
|
||||||
#
|
#
|
||||||
@ -17,7 +17,7 @@
|
|||||||
#
|
#
|
||||||
# [*log_dir*]
|
# [*log_dir*]
|
||||||
# (optional) Directory to store logs
|
# (optional) Directory to store logs
|
||||||
# Defaults to /var/log/quantum
|
# Defaults to /var/log/neutron
|
||||||
#
|
#
|
||||||
# [*auth_password*]
|
# [*auth_password*]
|
||||||
# (optional) The password to use for authentication (keystone)
|
# (optional) The password to use for authentication (keystone)
|
||||||
@ -51,13 +51,13 @@
|
|||||||
#
|
#
|
||||||
# [*auth_user*]
|
# [*auth_user*]
|
||||||
# (optional) The name of the auth user
|
# (optional) The name of the auth user
|
||||||
# Defaults to quantum
|
# Defaults to neutron
|
||||||
#
|
#
|
||||||
# [*auth_protocol*]
|
# [*auth_protocol*]
|
||||||
# (optional) The protocol to connect to keystone
|
# (optional) The protocol to connect to keystone
|
||||||
# Defaults to http
|
# Defaults to http
|
||||||
#
|
#
|
||||||
class quantum::server (
|
class neutron::server (
|
||||||
$package_ensure = 'present',
|
$package_ensure = 'present',
|
||||||
$enabled = true,
|
$enabled = true,
|
||||||
$auth_password = false,
|
$auth_password = false,
|
||||||
@ -66,25 +66,25 @@ class quantum::server (
|
|||||||
$auth_port = '35357',
|
$auth_port = '35357',
|
||||||
$auth_admin_prefix = false,
|
$auth_admin_prefix = false,
|
||||||
$auth_tenant = 'services',
|
$auth_tenant = 'services',
|
||||||
$auth_user = 'quantum',
|
$auth_user = 'neutron',
|
||||||
$auth_protocol = 'http',
|
$auth_protocol = 'http',
|
||||||
$log_file = false,
|
$log_file = false,
|
||||||
$log_dir = '/var/log/quantum'
|
$log_dir = '/var/log/neutron'
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include quantum::params
|
include neutron::params
|
||||||
require keystone::python
|
require keystone::python
|
||||||
|
|
||||||
Quantum_config<||> ~> Service['quantum-server']
|
Neutron_config<||> ~> Service['neutron-server']
|
||||||
Quantum_api_config<||> ~> Service['quantum-server']
|
Neutron_api_config<||> ~> Service['neutron-server']
|
||||||
|
|
||||||
if $log_file {
|
if $log_file {
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'DEFAULT/log_file': value => $log_file;
|
'DEFAULT/log_file': value => $log_file;
|
||||||
'DEFAULT/log_dir': ensure => absent;
|
'DEFAULT/log_dir': ensure => absent;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'DEFAULT/log_dir': value => $log_dir;
|
'DEFAULT/log_dir': value => $log_dir;
|
||||||
'DEFAULT/log_file': ensure => absent;
|
'DEFAULT/log_file': ensure => absent;
|
||||||
}
|
}
|
||||||
@ -96,18 +96,18 @@ class quantum::server (
|
|||||||
$service_ensure = 'stopped'
|
$service_ensure = 'stopped'
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($::quantum::params::server_package) {
|
if ($::neutron::params::server_package) {
|
||||||
Package['quantum-server'] -> Quantum_api_config<||>
|
Package['neutron-server'] -> Neutron_api_config<||>
|
||||||
Package['quantum-server'] -> Quantum_config<||>
|
Package['neutron-server'] -> Neutron_config<||>
|
||||||
Package['quantum-server'] -> Service['quantum-server']
|
Package['neutron-server'] -> Service['neutron-server']
|
||||||
package { 'quantum-server':
|
package { 'neutron-server':
|
||||||
name => $::quantum::params::server_package,
|
name => $::neutron::params::server_package,
|
||||||
ensure => $package_ensure
|
ensure => $package_ensure
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Some platforms (RedHat) does not provide a quantum-server package.
|
# Some platforms (RedHat) does not provide a neutron-server package.
|
||||||
# The quantum api config file is provided by the quantum package.
|
# The neutron api config file is provided by the neutron package.
|
||||||
Package['quantum'] -> Quantum_api_config<||>
|
Package['neutron'] -> Neutron_api_config<||>
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($auth_type == 'keystone') {
|
if ($auth_type == 'keystone') {
|
||||||
@ -115,7 +115,7 @@ class quantum::server (
|
|||||||
if ($auth_password == false) {
|
if ($auth_password == false) {
|
||||||
fail('$auth_password must be set when using keystone authentication.')
|
fail('$auth_password must be set when using keystone authentication.')
|
||||||
} else {
|
} else {
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'keystone_authtoken/auth_host': value => $auth_host;
|
'keystone_authtoken/auth_host': value => $auth_host;
|
||||||
'keystone_authtoken/auth_port': value => $auth_port;
|
'keystone_authtoken/auth_port': value => $auth_port;
|
||||||
'keystone_authtoken/auth_protocol': value => $auth_protocol;
|
'keystone_authtoken/auth_protocol': value => $auth_protocol;
|
||||||
@ -124,7 +124,7 @@ class quantum::server (
|
|||||||
'keystone_authtoken/admin_password': value => $auth_password;
|
'keystone_authtoken/admin_password': value => $auth_password;
|
||||||
}
|
}
|
||||||
|
|
||||||
quantum_api_config {
|
neutron_api_config {
|
||||||
'filter:authtoken/auth_host': value => $auth_host;
|
'filter:authtoken/auth_host': value => $auth_host;
|
||||||
'filter:authtoken/auth_port': value => $auth_port;
|
'filter:authtoken/auth_port': value => $auth_port;
|
||||||
'filter:authtoken/auth_protocol': value => $auth_protocol;
|
'filter:authtoken/auth_protocol': value => $auth_protocol;
|
||||||
@ -135,17 +135,17 @@ class quantum::server (
|
|||||||
|
|
||||||
if $auth_admin_prefix {
|
if $auth_admin_prefix {
|
||||||
validate_re($auth_admin_prefix, '^(/.+[^/])?$')
|
validate_re($auth_admin_prefix, '^(/.+[^/])?$')
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'keystone_authtoken/auth_admin_prefix': value => $auth_admin_prefix;
|
'keystone_authtoken/auth_admin_prefix': value => $auth_admin_prefix;
|
||||||
}
|
}
|
||||||
quantum_api_config {
|
neutron_api_config {
|
||||||
'filter:authtoken/auth_admin_prefix': value => $auth_admin_prefix;
|
'filter:authtoken/auth_admin_prefix': value => $auth_admin_prefix;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
quantum_config {
|
neutron_config {
|
||||||
'keystone_authtoken/auth_admin_prefix': ensure => absent;
|
'keystone_authtoken/auth_admin_prefix': ensure => absent;
|
||||||
}
|
}
|
||||||
quantum_api_config {
|
neutron_api_config {
|
||||||
'filter:authtoken/auth_admin_prefix': ensure => absent;
|
'filter:authtoken/auth_admin_prefix': ensure => absent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -153,12 +153,12 @@ class quantum::server (
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'quantum-server':
|
service { 'neutron-server':
|
||||||
name => $::quantum::params::server_service,
|
name => $::neutron::params::server_service,
|
||||||
ensure => $service_ensure,
|
ensure => $service_ensure,
|
||||||
enable => $enabled,
|
enable => $enabled,
|
||||||
hasstatus => true,
|
hasstatus => true,
|
||||||
hasrestart => true,
|
hasrestart => true,
|
||||||
require => Class['quantum'],
|
require => Class['neutron'],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
108
spec/classes/neutron_agents_dhcp_spec.rb
Normal file
108
spec/classes/neutron_agents_dhcp_spec.rb
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe 'neutron::agents::dhcp' do
|
||||||
|
|
||||||
|
let :pre_condition do
|
||||||
|
"class { 'neutron': rabbit_password => 'passw0rd' }"
|
||||||
|
end
|
||||||
|
|
||||||
|
let :params do
|
||||||
|
{}
|
||||||
|
end
|
||||||
|
|
||||||
|
let :default_params do
|
||||||
|
{ :package_ensure => 'present',
|
||||||
|
:enabled => true,
|
||||||
|
:debug => false,
|
||||||
|
:state_path => '/var/lib/neutron',
|
||||||
|
:resync_interval => 30,
|
||||||
|
:interface_driver => 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
|
:dhcp_driver => 'neutron.agent.linux.dhcp.Dnsmasq',
|
||||||
|
:root_helper => 'sudo neutron-rootwrap /etc/neutron/rootwrap.conf',
|
||||||
|
:use_namespaces => true }
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
shared_examples_for 'neutron dhcp agent' do
|
||||||
|
let :p do
|
||||||
|
default_params.merge(params)
|
||||||
|
end
|
||||||
|
|
||||||
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
|
it_configures 'dnsmasq dhcp_driver'
|
||||||
|
|
||||||
|
it 'configures dhcp_agent.ini' do
|
||||||
|
should contain_neutron_dhcp_agent_config('DEFAULT/debug').with_value(p[:debug]);
|
||||||
|
should contain_neutron_dhcp_agent_config('DEFAULT/state_path').with_value(p[:state_path]);
|
||||||
|
should contain_neutron_dhcp_agent_config('DEFAULT/resync_interval').with_value(p[:resync_interval]);
|
||||||
|
should contain_neutron_dhcp_agent_config('DEFAULT/interface_driver').with_value(p[:interface_driver]);
|
||||||
|
should contain_neutron_dhcp_agent_config('DEFAULT/dhcp_driver').with_value(p[:dhcp_driver]);
|
||||||
|
should contain_neutron_dhcp_agent_config('DEFAULT/root_helper').with_value(p[:root_helper]);
|
||||||
|
should contain_neutron_dhcp_agent_config('DEFAULT/use_namespaces').with_value(p[:use_namespaces]);
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'installs neutron dhcp agent package' do
|
||||||
|
if platform_params.has_key?(:dhcp_agent_package)
|
||||||
|
should contain_package('neutron-dhcp-agent').with(
|
||||||
|
:name => platform_params[:dhcp_agent_package],
|
||||||
|
:ensure => p[:package_ensure]
|
||||||
|
)
|
||||||
|
should contain_package('neutron').with_before(/Package\[neutron-dhcp-agent\]/)
|
||||||
|
should contain_package('neutron-dhcp-agent').with_before(/Neutron_dhcp_agent_config\[.+\]/)
|
||||||
|
should contain_package('neutron-dhcp-agent').with_before(/Neutron_config\[.+\]/)
|
||||||
|
else
|
||||||
|
should contain_package('neutron').with_before(/Neutron_dhcp_agent_config\[.+\]/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'configures neutron dhcp agent service' do
|
||||||
|
should contain_service('neutron-dhcp-service').with(
|
||||||
|
:name => platform_params[:dhcp_agent_service],
|
||||||
|
:enable => true,
|
||||||
|
:ensure => 'running',
|
||||||
|
:require => 'Class[Neutron]'
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'dnsmasq dhcp_driver' do
|
||||||
|
it 'installs dnsmasq packages' do
|
||||||
|
if platform_params.has_key?(:dhcp_agent_package)
|
||||||
|
should contain_package('dnsmasq').with_before('Package[neutron-dhcp-agent]')
|
||||||
|
end
|
||||||
|
should contain_package('dnsmasq').with(
|
||||||
|
:ensure => 'present',
|
||||||
|
:name => platform_params[:dnsmasq_packages]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
context 'on Debian platforms' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => 'Debian' }
|
||||||
|
end
|
||||||
|
|
||||||
|
let :platform_params do
|
||||||
|
{ :dnsmasq_packages => ['dnsmasq-base', 'dnsmasq-utils'],
|
||||||
|
:dhcp_agent_package => 'neutron-dhcp-agent',
|
||||||
|
:dhcp_agent_service => 'neutron-dhcp-agent' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it_configures 'neutron dhcp agent'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on RedHat platforms' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => 'RedHat' }
|
||||||
|
end
|
||||||
|
|
||||||
|
let :platform_params do
|
||||||
|
{ :dnsmasq_packages => ['dnsmasq', 'dnsmasq-utils'],
|
||||||
|
:dhcp_agent_service => 'neutron-dhcp-agent' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it_configures 'neutron dhcp agent'
|
||||||
|
end
|
||||||
|
end
|
@ -1,9 +1,9 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::agents::l3' do
|
describe 'neutron::agents::l3' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }"
|
"class { 'neutron': rabbit_password => 'passw0rd' }"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :default_params do
|
let :default_params do
|
||||||
@ -12,7 +12,7 @@ describe 'quantum::agents::l3' do
|
|||||||
:debug => false,
|
:debug => false,
|
||||||
:external_network_bridge => 'br-ex',
|
:external_network_bridge => 'br-ex',
|
||||||
:use_namespaces => true,
|
:use_namespaces => true,
|
||||||
:interface_driver => 'quantum.agent.linux.interface.OVSInterfaceDriver',
|
:interface_driver => 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
:router_id => nil,
|
:router_id => nil,
|
||||||
:gateway_external_network_id => nil,
|
:gateway_external_network_id => nil,
|
||||||
:handle_internal_only_routers => true,
|
:handle_internal_only_routers => true,
|
||||||
@ -27,47 +27,47 @@ describe 'quantum::agents::l3' do
|
|||||||
{ }
|
{ }
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'quantum l3 agent' do
|
shared_examples_for 'neutron l3 agent' do
|
||||||
let :p do
|
let :p do
|
||||||
default_params.merge(params)
|
default_params.merge(params)
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
it 'configures l3_agent.ini' do
|
it 'configures l3_agent.ini' do
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/debug').with_value(p[:debug])
|
should contain_neutron_l3_agent_config('DEFAULT/debug').with_value(p[:debug])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/external_network_bridge').with_value(p[:external_network_bridge])
|
should contain_neutron_l3_agent_config('DEFAULT/external_network_bridge').with_value(p[:external_network_bridge])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/use_namespaces').with_value(p[:use_namespaces])
|
should contain_neutron_l3_agent_config('DEFAULT/use_namespaces').with_value(p[:use_namespaces])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/interface_driver').with_value(p[:interface_driver])
|
should contain_neutron_l3_agent_config('DEFAULT/interface_driver').with_value(p[:interface_driver])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/router_id').with_value(p[:router_id])
|
should contain_neutron_l3_agent_config('DEFAULT/router_id').with_value(p[:router_id])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/gateway_external_network_id').with_value(p[:gateway_external_network_id])
|
should contain_neutron_l3_agent_config('DEFAULT/gateway_external_network_id').with_value(p[:gateway_external_network_id])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/handle_internal_only_routers').with_value(p[:handle_internal_only_routers])
|
should contain_neutron_l3_agent_config('DEFAULT/handle_internal_only_routers').with_value(p[:handle_internal_only_routers])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/metadata_port').with_value(p[:metadata_port])
|
should contain_neutron_l3_agent_config('DEFAULT/metadata_port').with_value(p[:metadata_port])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/send_arp_for_ha').with_value(p[:send_arp_for_ha])
|
should contain_neutron_l3_agent_config('DEFAULT/send_arp_for_ha').with_value(p[:send_arp_for_ha])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/periodic_interval').with_value(p[:periodic_interval])
|
should contain_neutron_l3_agent_config('DEFAULT/periodic_interval').with_value(p[:periodic_interval])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/periodic_fuzzy_delay').with_value(p[:periodic_fuzzy_delay])
|
should contain_neutron_l3_agent_config('DEFAULT/periodic_fuzzy_delay').with_value(p[:periodic_fuzzy_delay])
|
||||||
should contain_quantum_l3_agent_config('DEFAULT/enable_metadata_proxy').with_value(p[:enable_metadata_proxy])
|
should contain_neutron_l3_agent_config('DEFAULT/enable_metadata_proxy').with_value(p[:enable_metadata_proxy])
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'installs quantum l3 agent package' do
|
it 'installs neutron l3 agent package' do
|
||||||
if platform_params.has_key?(:l3_agent_package)
|
if platform_params.has_key?(:l3_agent_package)
|
||||||
should contain_package('quantum-l3').with(
|
should contain_package('neutron-l3').with(
|
||||||
:name => platform_params[:l3_agent_package],
|
:name => platform_params[:l3_agent_package],
|
||||||
:ensure => p[:package_ensure],
|
:ensure => p[:package_ensure],
|
||||||
:require => 'Package[quantum]'
|
:require => 'Package[neutron]'
|
||||||
)
|
)
|
||||||
should contain_package('quantum-l3').with_before(/Quantum_l3_agent_config\[.+\]/)
|
should contain_package('neutron-l3').with_before(/Neutron_l3_agent_config\[.+\]/)
|
||||||
else
|
else
|
||||||
should contain_package('quantum').with_before(/Quantum_l3_agent_config\[.+\]/)
|
should contain_package('neutron').with_before(/Neutron_l3_agent_config\[.+\]/)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures quantum l3 agent service' do
|
it 'configures neutron l3 agent service' do
|
||||||
should contain_service('quantum-l3').with(
|
should contain_service('neutron-l3').with(
|
||||||
:name => platform_params[:l3_agent_service],
|
:name => platform_params[:l3_agent_service],
|
||||||
:enable => true,
|
:enable => true,
|
||||||
:ensure => 'running',
|
:ensure => 'running',
|
||||||
:require => 'Class[Quantum]'
|
:require => 'Class[Neutron]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -79,11 +79,11 @@ describe 'quantum::agents::l3' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :l3_agent_package => 'quantum-l3-agent',
|
{ :l3_agent_package => 'neutron-l3-agent',
|
||||||
:l3_agent_service => 'quantum-l3-agent' }
|
:l3_agent_service => 'neutron-l3-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum l3 agent'
|
it_configures 'neutron l3 agent'
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
context 'on RedHat platforms' do
|
||||||
@ -92,9 +92,9 @@ describe 'quantum::agents::l3' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :l3_agent_service => 'quantum-l3-agent' }
|
{ :l3_agent_service => 'neutron-l3-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum l3 agent'
|
it_configures 'neutron l3 agent'
|
||||||
end
|
end
|
||||||
end
|
end
|
@ -1,9 +1,9 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::agents::lbaas' do
|
describe 'neutron::agents::lbaas' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }"
|
"class { 'neutron': rabbit_password => 'passw0rd' }"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
@ -14,51 +14,51 @@ describe 'quantum::agents::lbaas' do
|
|||||||
{ :package_ensure => 'present',
|
{ :package_ensure => 'present',
|
||||||
:enabled => true,
|
:enabled => true,
|
||||||
:debug => false,
|
:debug => false,
|
||||||
:interface_driver => 'quantum.agent.linux.interface.OVSInterfaceDriver',
|
:interface_driver => 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
:device_driver => 'quantum.plugins.services.agent_loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
:device_driver => 'neutron.plugins.services.agent_loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
||||||
:use_namespaces => true,
|
:use_namespaces => true,
|
||||||
:user_group => 'nogroup',
|
:user_group => 'nogroup',
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
shared_examples_for 'quantum lbaas agent' do
|
shared_examples_for 'neutron lbaas agent' do
|
||||||
let :p do
|
let :p do
|
||||||
default_params.merge(params)
|
default_params.merge(params)
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
it_configures 'haproxy lbaas_driver'
|
it_configures 'haproxy lbaas_driver'
|
||||||
|
|
||||||
it 'configures lbaas_agent.ini' do
|
it 'configures lbaas_agent.ini' do
|
||||||
should contain_quantum_lbaas_agent_config('DEFAULT/debug').with_value(p[:debug]);
|
should contain_neutron_lbaas_agent_config('DEFAULT/debug').with_value(p[:debug]);
|
||||||
should contain_quantum_lbaas_agent_config('DEFAULT/interface_driver').with_value(p[:interface_driver]);
|
should contain_neutron_lbaas_agent_config('DEFAULT/interface_driver').with_value(p[:interface_driver]);
|
||||||
should contain_quantum_lbaas_agent_config('DEFAULT/device_driver').with_value(p[:device_driver]);
|
should contain_neutron_lbaas_agent_config('DEFAULT/device_driver').with_value(p[:device_driver]);
|
||||||
should contain_quantum_lbaas_agent_config('DEFAULT/use_namespaces').with_value(p[:use_namespaces]);
|
should contain_neutron_lbaas_agent_config('DEFAULT/use_namespaces').with_value(p[:use_namespaces]);
|
||||||
should contain_quantum_lbaas_agent_config('DEFAULT/user_group').with_value(p[:user_group]);
|
should contain_neutron_lbaas_agent_config('DEFAULT/user_group').with_value(p[:user_group]);
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'installs quantum lbaas agent package' do
|
it 'installs neutron lbaas agent package' do
|
||||||
if platform_params.has_key?(:lbaas_agent_package)
|
if platform_params.has_key?(:lbaas_agent_package)
|
||||||
should contain_package('quantum-lbaas-agent').with(
|
should contain_package('neutron-lbaas-agent').with(
|
||||||
:name => platform_params[:lbaas_agent_package],
|
:name => platform_params[:lbaas_agent_package],
|
||||||
:ensure => p[:package_ensure]
|
:ensure => p[:package_ensure]
|
||||||
)
|
)
|
||||||
should contain_package('quantum').with_before(/Package\[quantum-lbaas-agent\]/)
|
should contain_package('neutron').with_before(/Package\[neutron-lbaas-agent\]/)
|
||||||
should contain_package('quantum-lbaas-agent').with_before(/Quantum_lbaas_agent_config\[.+\]/)
|
should contain_package('neutron-lbaas-agent').with_before(/Neutron_lbaas_agent_config\[.+\]/)
|
||||||
should contain_package('quantum-lbaas-agent').with_before(/Quantum_config\[.+\]/)
|
should contain_package('neutron-lbaas-agent').with_before(/Neutron_config\[.+\]/)
|
||||||
else
|
else
|
||||||
should contain_package('quantum').with_before(/Quantum_lbaas_agent_config\[.+\]/)
|
should contain_package('neutron').with_before(/Neutron_lbaas_agent_config\[.+\]/)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures quantum lbaas agent service' do
|
it 'configures neutron lbaas agent service' do
|
||||||
should contain_service('quantum-lbaas-service').with(
|
should contain_service('neutron-lbaas-service').with(
|
||||||
:name => platform_params[:lbaas_agent_service],
|
:name => platform_params[:lbaas_agent_service],
|
||||||
:enable => true,
|
:enable => true,
|
||||||
:ensure => 'running',
|
:ensure => 'running',
|
||||||
:require => 'Class[Quantum]'
|
:require => 'Class[Neutron]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -66,7 +66,7 @@ describe 'quantum::agents::lbaas' do
|
|||||||
shared_examples_for 'haproxy lbaas_driver' do
|
shared_examples_for 'haproxy lbaas_driver' do
|
||||||
it 'installs haproxy packages' do
|
it 'installs haproxy packages' do
|
||||||
if platform_params.has_key?(:lbaas_agent_package)
|
if platform_params.has_key?(:lbaas_agent_package)
|
||||||
should contain_package('haproxy').with_before('Package[quantum-lbaas-agent]')
|
should contain_package('haproxy').with_before('Package[neutron-lbaas-agent]')
|
||||||
end
|
end
|
||||||
should contain_package('haproxy').with(
|
should contain_package('haproxy').with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
@ -83,11 +83,11 @@ describe 'quantum::agents::lbaas' do
|
|||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :haproxy_package => 'haproxy',
|
{ :haproxy_package => 'haproxy',
|
||||||
:lbaas_agent_package => 'quantum-lbaas-agent',
|
:lbaas_agent_package => 'neutron-lbaas-agent',
|
||||||
:lbaas_agent_service => 'quantum-lbaas-agent' }
|
:lbaas_agent_service => 'neutron-lbaas-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum lbaas agent'
|
it_configures 'neutron lbaas agent'
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
context 'on RedHat platforms' do
|
||||||
@ -97,9 +97,9 @@ describe 'quantum::agents::lbaas' do
|
|||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :haproxy_package => 'haproxy',
|
{ :haproxy_package => 'haproxy',
|
||||||
:lbaas_agent_service => 'quantum-lbaas-agent' }
|
:lbaas_agent_service => 'neutron-lbaas-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum lbaas agent'
|
it_configures 'neutron lbaas agent'
|
||||||
end
|
end
|
||||||
end
|
end
|
@ -1,26 +1,26 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::agents::linuxbridge' do
|
describe 'neutron::agents::linuxbridge' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }\n" +
|
"class { 'neutron': rabbit_password => 'passw0rd' }\n" +
|
||||||
"class { 'quantum::plugins::linuxbridge': }"
|
"class { 'neutron::plugins::linuxbridge': }"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{ :physical_interface_mappings => 'physnet:eth0',
|
{ :physical_interface_mappings => 'physnet:eth0',
|
||||||
:firewall_driver => 'quantum.agent.linux.iptables_firewall.IptablesFirewallDriver',
|
:firewall_driver => 'neutron.agent.linux.iptables_firewall.IptablesFirewallDriver',
|
||||||
:package_ensure => 'present',
|
:package_ensure => 'present',
|
||||||
:enable => true
|
:enable => true
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'quantum linuxbridge agent' do
|
shared_examples_for 'neutron linuxbridge agent' do
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
it 'configures quantum linuxbridge agent service' do
|
it 'configures neutron linuxbridge agent service' do
|
||||||
should contain_service('quantum-plugin-linuxbridge-service').with(
|
should contain_service('neutron-plugin-linuxbridge-service').with(
|
||||||
:ensure => 'running',
|
:ensure => 'running',
|
||||||
:name => platform_params[:linuxbridge_agent_service],
|
:name => platform_params[:linuxbridge_agent_service],
|
||||||
:enable => params[:enable]
|
:enable => params[:enable]
|
||||||
@ -28,10 +28,10 @@ describe 'quantum::agents::linuxbridge' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'configures linuxbridge_conf.ini' do
|
it 'configures linuxbridge_conf.ini' do
|
||||||
should contain_quantum_plugin_linuxbridge('LINUX_BRIDGE/physical_interface_mappings').with(
|
should contain_neutron_plugin_linuxbridge('LINUX_BRIDGE/physical_interface_mappings').with(
|
||||||
:value => params[:physical_interface_mappings]
|
:value => params[:physical_interface_mappings]
|
||||||
)
|
)
|
||||||
should contain_quantum_plugin_linuxbridge('SECURITYGROUP/firewall_driver').with(
|
should contain_neutron_plugin_linuxbridge('SECURITYGROUP/firewall_driver').with(
|
||||||
:value => params[:firewall_driver]
|
:value => params[:firewall_driver]
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
@ -44,14 +44,14 @@ describe 'quantum::agents::linuxbridge' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :linuxbridge_agent_package => 'quantum-plugin-linuxbridge-agent',
|
{ :linuxbridge_agent_package => 'neutron-plugin-linuxbridge-agent',
|
||||||
:linuxbridge_agent_service => 'quantum-plugin-linuxbridge-agent' }
|
:linuxbridge_agent_service => 'neutron-plugin-linuxbridge-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum linuxbridge agent'
|
it_configures 'neutron linuxbridge agent'
|
||||||
|
|
||||||
it 'installs quantum linuxbridge agent package' do
|
it 'installs neutron linuxbridge agent package' do
|
||||||
should contain_package('quantum-plugin-linuxbridge-agent').with(
|
should contain_package('neutron-plugin-linuxbridge-agent').with(
|
||||||
:ensure => params[:package_ensure],
|
:ensure => params[:package_ensure],
|
||||||
:name => platform_params[:linuxbridge_agent_package]
|
:name => platform_params[:linuxbridge_agent_package]
|
||||||
)
|
)
|
||||||
@ -64,10 +64,10 @@ describe 'quantum::agents::linuxbridge' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :linuxbridge_agent_package => 'openstack-quantum-linuxbridge',
|
{ :linuxbridge_agent_package => 'openstack-neutron-linuxbridge',
|
||||||
:linuxbridge_agent_service => 'quantum-linuxbridge-agent' }
|
:linuxbridge_agent_service => 'neutron-linuxbridge-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum linuxbridge agent'
|
it_configures 'neutron linuxbridge agent'
|
||||||
end
|
end
|
||||||
end
|
end
|
@ -1,9 +1,9 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::agents::metadata' do
|
describe 'neutron::agents::metadata' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }"
|
"class { 'neutron': rabbit_password => 'passw0rd' }"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
@ -13,7 +13,7 @@ describe 'quantum::agents::metadata' do
|
|||||||
:auth_url => 'http://localhost:35357/v2.0',
|
:auth_url => 'http://localhost:35357/v2.0',
|
||||||
:auth_region => 'RegionOne',
|
:auth_region => 'RegionOne',
|
||||||
:auth_tenant => 'services',
|
:auth_tenant => 'services',
|
||||||
:auth_user => 'quantum',
|
:auth_user => 'neutron',
|
||||||
:auth_password => 'password',
|
:auth_password => 'password',
|
||||||
:metadata_ip => '127.0.0.1',
|
:metadata_ip => '127.0.0.1',
|
||||||
:metadata_port => '8775',
|
:metadata_port => '8775',
|
||||||
@ -21,29 +21,29 @@ describe 'quantum::agents::metadata' do
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'quantum metadata agent' do
|
shared_examples_for 'neutron metadata agent' do
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
it 'configures quantum metadata agent service' do
|
it 'configures neutron metadata agent service' do
|
||||||
should contain_service('quantum-metadata').with(
|
should contain_service('neutron-metadata').with(
|
||||||
:name => platform_params[:metadata_agent_service],
|
:name => platform_params[:metadata_agent_service],
|
||||||
:enable => params[:enabled],
|
:enable => params[:enabled],
|
||||||
:ensure => 'running',
|
:ensure => 'running',
|
||||||
:require => 'Class[Quantum]'
|
:require => 'Class[Neutron]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures metadata_agent.ini' do
|
it 'configures metadata_agent.ini' do
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/debug').with(:value => params[:debug])
|
should contain_neutron_metadata_agent_config('DEFAULT/debug').with(:value => params[:debug])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/auth_url').with(:value => params[:auth_url])
|
should contain_neutron_metadata_agent_config('DEFAULT/auth_url').with(:value => params[:auth_url])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/auth_region').with(:value => params[:auth_region])
|
should contain_neutron_metadata_agent_config('DEFAULT/auth_region').with(:value => params[:auth_region])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/admin_tenant_name').with(:value => params[:auth_tenant])
|
should contain_neutron_metadata_agent_config('DEFAULT/admin_tenant_name').with(:value => params[:auth_tenant])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/admin_user').with(:value => params[:auth_user])
|
should contain_neutron_metadata_agent_config('DEFAULT/admin_user').with(:value => params[:auth_user])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/admin_password').with(:value => params[:auth_password])
|
should contain_neutron_metadata_agent_config('DEFAULT/admin_password').with(:value => params[:auth_password])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/nova_metadata_ip').with(:value => params[:metadata_ip])
|
should contain_neutron_metadata_agent_config('DEFAULT/nova_metadata_ip').with(:value => params[:metadata_ip])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/nova_metadata_port').with(:value => params[:metadata_port])
|
should contain_neutron_metadata_agent_config('DEFAULT/nova_metadata_port').with(:value => params[:metadata_port])
|
||||||
should contain_quantum_metadata_agent_config('DEFAULT/metadata_proxy_shared_secret').with(:value => params[:shared_secret])
|
should contain_neutron_metadata_agent_config('DEFAULT/metadata_proxy_shared_secret').with(:value => params[:shared_secret])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -53,18 +53,18 @@ describe 'quantum::agents::metadata' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :metadata_agent_package => 'quantum-metadata-agent',
|
{ :metadata_agent_package => 'neutron-metadata-agent',
|
||||||
:metadata_agent_service => 'quantum-metadata-agent' }
|
:metadata_agent_service => 'neutron-metadata-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'installs quantum metadata agent package' do
|
it 'installs neutron metadata agent package' do
|
||||||
should contain_package('quantum-metadata').with(
|
should contain_package('neutron-metadata').with(
|
||||||
:ensure => params[:package_ensure],
|
:ensure => params[:package_ensure],
|
||||||
:name => platform_params[:metadata_agent_package]
|
:name => platform_params[:metadata_agent_package]
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum metadata agent'
|
it_configures 'neutron metadata agent'
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -74,10 +74,10 @@ describe 'quantum::agents::metadata' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :metadata_agent_service => 'quantum-metadata-agent' }
|
{ :metadata_agent_service => 'neutron-metadata-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum metadata agent'
|
it_configures 'neutron metadata agent'
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
@ -1,10 +1,10 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::agents::ovs' do
|
describe 'neutron::agents::ovs' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }\n" +
|
"class { 'neutron': rabbit_password => 'passw0rd' }\n" +
|
||||||
"class { 'quantum::plugins::ovs': network_vlan_ranges => 'test' }"
|
"class { 'neutron::plugins::ovs': network_vlan_ranges => 'test' }"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :default_params do
|
let :default_params do
|
||||||
@ -17,56 +17,56 @@ describe 'quantum::agents::ovs' do
|
|||||||
:local_ip => false,
|
:local_ip => false,
|
||||||
:tunnel_bridge => 'br-tun',
|
:tunnel_bridge => 'br-tun',
|
||||||
:polling_interval => 2,
|
:polling_interval => 2,
|
||||||
:firewall_driver => 'quantum.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver' }
|
:firewall_driver => 'neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver' }
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{}
|
{}
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'quantum plugin ovs agent' do
|
shared_examples_for 'neutron plugin ovs agent' do
|
||||||
let :p do
|
let :p do
|
||||||
default_params.merge(params)
|
default_params.merge(params)
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
it 'configures ovs_quantum_plugin.ini' do
|
it 'configures ovs_neutron_plugin.ini' do
|
||||||
should contain_quantum_plugin_ovs('AGENT/polling_interval').with_value(p[:polling_interval])
|
should contain_neutron_plugin_ovs('AGENT/polling_interval').with_value(p[:polling_interval])
|
||||||
should contain_quantum_plugin_ovs('OVS/integration_bridge').with_value(p[:integration_bridge])
|
should contain_neutron_plugin_ovs('OVS/integration_bridge').with_value(p[:integration_bridge])
|
||||||
should contain_quantum_plugin_ovs('SECURITYGROUP/firewall_driver').\
|
should contain_neutron_plugin_ovs('SECURITYGROUP/firewall_driver').\
|
||||||
with_value(p[:firewall_driver])
|
with_value(p[:firewall_driver])
|
||||||
should contain_quantum_plugin_ovs('OVS/enable_tunneling').with_value(false)
|
should contain_neutron_plugin_ovs('OVS/enable_tunneling').with_value(false)
|
||||||
should contain_quantum_plugin_ovs('OVS/tunnel_bridge').with_ensure('absent')
|
should contain_neutron_plugin_ovs('OVS/tunnel_bridge').with_ensure('absent')
|
||||||
should contain_quantum_plugin_ovs('OVS/local_ip').with_ensure('absent')
|
should contain_neutron_plugin_ovs('OVS/local_ip').with_ensure('absent')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures vs_bridge' do
|
it 'configures vs_bridge' do
|
||||||
should contain_vs_bridge(p[:integration_bridge]).with(
|
should contain_vs_bridge(p[:integration_bridge]).with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
:before => 'Service[quantum-plugin-ovs-service]'
|
:before => 'Service[neutron-plugin-ovs-service]'
|
||||||
)
|
)
|
||||||
should_not contain_vs_brige(p[:integration_bridge])
|
should_not contain_vs_brige(p[:integration_bridge])
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'installs quantum ovs agent package' do
|
it 'installs neutron ovs agent package' do
|
||||||
if platform_params.has_key?(:ovs_agent_package)
|
if platform_params.has_key?(:ovs_agent_package)
|
||||||
should contain_package('quantum-plugin-ovs-agent').with(
|
should contain_package('neutron-plugin-ovs-agent').with(
|
||||||
:name => platform_params[:ovs_agent_package],
|
:name => platform_params[:ovs_agent_package],
|
||||||
:ensure => p[:package_ensure]
|
:ensure => p[:package_ensure]
|
||||||
)
|
)
|
||||||
should contain_package('quantum-plugin-ovs-agent').with_before(/Quantum_plugin_ovs\[.+\]/)
|
should contain_package('neutron-plugin-ovs-agent').with_before(/Neutron_plugin_ovs\[.+\]/)
|
||||||
else
|
else
|
||||||
should contain_package('quantum-plugin-ovs').with_before(/Quantum_plugin_ovs\[.+\]/)
|
should contain_package('neutron-plugin-ovs').with_before(/Neutron_plugin_ovs\[.+\]/)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures quantum ovs agent service' do
|
it 'configures neutron ovs agent service' do
|
||||||
should contain_service('quantum-plugin-ovs-service').with(
|
should contain_service('neutron-plugin-ovs-service').with(
|
||||||
:name => platform_params[:ovs_agent_service],
|
:name => platform_params[:ovs_agent_service],
|
||||||
:enable => true,
|
:enable => true,
|
||||||
:ensure => 'running',
|
:ensure => 'running',
|
||||||
:require => 'Class[Quantum]'
|
:require => 'Class[Neutron]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -75,7 +75,7 @@ describe 'quantum::agents::ovs' do
|
|||||||
params.merge!(:firewall_driver => false)
|
params.merge!(:firewall_driver => false)
|
||||||
end
|
end
|
||||||
it 'should configure firewall driver' do
|
it 'should configure firewall driver' do
|
||||||
should contain_quantum_plugin_ovs('SECURITYGROUP/firewall_driver').with_ensure('absent')
|
should contain_neutron_plugin_ovs('SECURITYGROUP/firewall_driver').with_ensure('absent')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -85,18 +85,18 @@ describe 'quantum::agents::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'configures bridge mappings' do
|
it 'configures bridge mappings' do
|
||||||
should contain_quantum_plugin_ovs('OVS/bridge_mappings')
|
should contain_neutron_plugin_ovs('OVS/bridge_mappings')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should configure bridge mappings' do
|
it 'should configure bridge mappings' do
|
||||||
should contain_quantum__plugins__ovs__bridge(params[:bridge_mappings].join(',')).with(
|
should contain_neutron__plugins__ovs__bridge(params[:bridge_mappings].join(',')).with(
|
||||||
:before => 'Service[quantum-plugin-ovs-service]'
|
:before => 'Service[neutron-plugin-ovs-service]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should configure bridge uplinks' do
|
it 'should configure bridge uplinks' do
|
||||||
should contain_quantum__plugins__ovs__port(params[:bridge_uplinks].join(',')).with(
|
should contain_neutron__plugins__ovs__port(params[:bridge_uplinks].join(',')).with(
|
||||||
:before => 'Service[quantum-plugin-ovs-service]'
|
:before => 'Service[neutron-plugin-ovs-service]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -117,12 +117,12 @@ describe 'quantum::agents::ovs' do
|
|||||||
params.merge!(:enable_tunneling => true, :local_ip => '127.0.0.1' )
|
params.merge!(:enable_tunneling => true, :local_ip => '127.0.0.1' )
|
||||||
end
|
end
|
||||||
it 'should configure ovs for tunneling' do
|
it 'should configure ovs for tunneling' do
|
||||||
should contain_quantum_plugin_ovs('OVS/enable_tunneling').with_value(true)
|
should contain_neutron_plugin_ovs('OVS/enable_tunneling').with_value(true)
|
||||||
should contain_quantum_plugin_ovs('OVS/tunnel_bridge').with_value(default_params[:tunnel_bridge])
|
should contain_neutron_plugin_ovs('OVS/tunnel_bridge').with_value(default_params[:tunnel_bridge])
|
||||||
should contain_quantum_plugin_ovs('OVS/local_ip').with_value('127.0.0.1')
|
should contain_neutron_plugin_ovs('OVS/local_ip').with_value('127.0.0.1')
|
||||||
should contain_vs_bridge(default_params[:tunnel_bridge]).with(
|
should contain_vs_bridge(default_params[:tunnel_bridge]).with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
:before => 'Service[quantum-plugin-ovs-service]'
|
:before => 'Service[neutron-plugin-ovs-service]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -135,11 +135,11 @@ describe 'quantum::agents::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :ovs_agent_package => 'quantum-plugin-openvswitch-agent',
|
{ :ovs_agent_package => 'neutron-plugin-openvswitch-agent',
|
||||||
:ovs_agent_service => 'quantum-plugin-openvswitch-agent' }
|
:ovs_agent_service => 'neutron-plugin-openvswitch-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum plugin ovs agent'
|
it_configures 'neutron plugin ovs agent'
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
context 'on RedHat platforms' do
|
||||||
@ -148,18 +148,18 @@ describe 'quantum::agents::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :ovs_cleanup_service => 'quantum-ovs-cleanup',
|
{ :ovs_cleanup_service => 'neutron-ovs-cleanup',
|
||||||
:ovs_agent_service => 'quantum-openvswitch-agent' }
|
:ovs_agent_service => 'neutron-openvswitch-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum plugin ovs agent'
|
it_configures 'neutron plugin ovs agent'
|
||||||
it 'configures quantum ovs cleanup service' do
|
it 'configures neutron ovs cleanup service' do
|
||||||
should contain_service('ovs-cleanup-service').with(
|
should contain_service('ovs-cleanup-service').with(
|
||||||
:name => platform_params[:ovs_cleanup_service],
|
:name => platform_params[:ovs_cleanup_service],
|
||||||
:enable => true,
|
:enable => true,
|
||||||
:ensure => 'running'
|
:ensure => 'running'
|
||||||
)
|
)
|
||||||
should contain_package('quantum-plugin-ovs').with_before(/Service\[ovs-cleanup-service\]/)
|
should contain_package('neutron-plugin-ovs').with_before(/Service\[ovs-cleanup-service\]/)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
@ -1,13 +1,13 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::client' do
|
describe 'neutron::client' do
|
||||||
|
|
||||||
context 'on Debian platforms' do
|
context 'on Debian platforms' do
|
||||||
let :facts do
|
let :facts do
|
||||||
{ :osfamily => 'Debian' }
|
{ :osfamily => 'Debian' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_class('quantum::client') }
|
it { should contain_class('neutron::client') }
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
context 'on RedHat platforms' do
|
||||||
@ -15,6 +15,6 @@ describe 'quantum::client' do
|
|||||||
{ :osfamily => 'RedHat' }
|
{ :osfamily => 'RedHat' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_class('quantum::client') }
|
it { should contain_class('neutron::client') }
|
||||||
end
|
end
|
||||||
end
|
end
|
@ -1,6 +1,6 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::db::mysql' do
|
describe 'neutron::db::mysql' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
'include mysql::server'
|
'include mysql::server'
|
||||||
@ -19,7 +19,7 @@ describe 'quantum::db::mysql' do
|
|||||||
{ :osfamily => 'Debian' }
|
{ :osfamily => 'Debian' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_class('quantum::db::mysql') }
|
it { should contain_class('neutron::db::mysql') }
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
context 'on RedHat platforms' do
|
||||||
@ -27,56 +27,56 @@ describe 'quantum::db::mysql' do
|
|||||||
{ :osfamily => 'RedHat' }
|
{ :osfamily => 'RedHat' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_class('quantum::db::mysql') }
|
it { should contain_class('neutron::db::mysql') }
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "overriding allowed_hosts param to array" do
|
describe "overriding allowed_hosts param to array" do
|
||||||
let :params do
|
let :params do
|
||||||
{
|
{
|
||||||
:password => 'quantumpass',
|
:password => 'neutronpass',
|
||||||
:allowed_hosts => ['127.0.0.1','%']
|
:allowed_hosts => ['127.0.0.1','%']
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it {should_not contain_quantum__db__mysql__host_access("127.0.0.1").with(
|
it {should_not contain_neutron__db__mysql__host_access("127.0.0.1").with(
|
||||||
:user => 'quantum',
|
:user => 'neutron',
|
||||||
:password => 'quantumpass',
|
:password => 'neutronpass',
|
||||||
:database => 'quantum'
|
:database => 'neutron'
|
||||||
)}
|
)}
|
||||||
it {should contain_quantum__db__mysql__host_access("%").with(
|
it {should contain_neutron__db__mysql__host_access("%").with(
|
||||||
:user => 'quantum',
|
:user => 'neutron',
|
||||||
:password => 'quantumpass',
|
:password => 'neutronpass',
|
||||||
:database => 'quantum'
|
:database => 'neutron'
|
||||||
)}
|
)}
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "overriding allowed_hosts param to string" do
|
describe "overriding allowed_hosts param to string" do
|
||||||
let :params do
|
let :params do
|
||||||
{
|
{
|
||||||
:password => 'quantumpass2',
|
:password => 'neutronpass2',
|
||||||
:allowed_hosts => '192.168.1.1'
|
:allowed_hosts => '192.168.1.1'
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it {should contain_quantum__db__mysql__host_access("192.168.1.1").with(
|
it {should contain_neutron__db__mysql__host_access("192.168.1.1").with(
|
||||||
:user => 'quantum',
|
:user => 'neutron',
|
||||||
:password => 'quantumpass2',
|
:password => 'neutronpass2',
|
||||||
:database => 'quantum'
|
:database => 'neutron'
|
||||||
)}
|
)}
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "overriding allowed_hosts param equals to host param " do
|
describe "overriding allowed_hosts param equals to host param " do
|
||||||
let :params do
|
let :params do
|
||||||
{
|
{
|
||||||
:password => 'quantumpass2',
|
:password => 'neutronpass2',
|
||||||
:allowed_hosts => '127.0.0.1'
|
:allowed_hosts => '127.0.0.1'
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it {should_not contain_quantum__db__mysql__host_access("127.0.0.1").with(
|
it {should_not contain_neutron__db__mysql__host_access("127.0.0.1").with(
|
||||||
:user => 'quantum',
|
:user => 'neutron',
|
||||||
:password => 'quantumpass2',
|
:password => 'neutronpass2',
|
||||||
:database => 'quantum'
|
:database => 'neutron'
|
||||||
)}
|
)}
|
||||||
end
|
end
|
||||||
end
|
end
|
139
spec/classes/neutron_init_spec.rb
Normal file
139
spec/classes/neutron_init_spec.rb
Normal file
@ -0,0 +1,139 @@
|
|||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe 'neutron' do
|
||||||
|
|
||||||
|
let :params do
|
||||||
|
{ :package_ensure => 'present',
|
||||||
|
:verbose => false,
|
||||||
|
:debug => false,
|
||||||
|
:core_plugin => 'neutron.plugins.linuxbridge.lb_neutron_plugin.LinuxBridgePluginV2',
|
||||||
|
:rabbit_host => '127.0.0.1',
|
||||||
|
:rabbit_port => 5672,
|
||||||
|
:rabbit_hosts => false,
|
||||||
|
:rabbit_user => 'guest',
|
||||||
|
:rabbit_password => 'guest',
|
||||||
|
:rabbit_virtual_host => '/'
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'neutron' do
|
||||||
|
|
||||||
|
context 'and if rabbit_host parameter is provided' do
|
||||||
|
it_configures 'a neutron base installation'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'and if rabbit_hosts parameter is provided' do
|
||||||
|
before do
|
||||||
|
params.delete(:rabbit_host)
|
||||||
|
params.delete(:rabbit_port)
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with one server' do
|
||||||
|
before { params.merge!( :rabbit_hosts => ['127.0.0.1:5672'] ) }
|
||||||
|
it_configures 'a neutron base installation'
|
||||||
|
it_configures 'rabbit HA with a single virtual host'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with multiple servers' do
|
||||||
|
before { params.merge!( :rabbit_hosts => ['rabbit1:5672', 'rabbit2:5672'] ) }
|
||||||
|
it_configures 'a neutron base installation'
|
||||||
|
it_configures 'rabbit HA with multiple hosts'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'a neutron base installation' do
|
||||||
|
|
||||||
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
|
it 'configures neutron configuration folder' do
|
||||||
|
should contain_file('/etc/neutron/').with(
|
||||||
|
:ensure => 'directory',
|
||||||
|
:owner => 'root',
|
||||||
|
:group => 'neutron',
|
||||||
|
:mode => '0750',
|
||||||
|
:require => 'Package[neutron]'
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'configures neutron configuration file' do
|
||||||
|
should contain_file('/etc/neutron/neutron.conf').with(
|
||||||
|
:owner => 'root',
|
||||||
|
:group => 'neutron',
|
||||||
|
:mode => '0640',
|
||||||
|
:require => 'Package[neutron]'
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'installs neutron package' do
|
||||||
|
should contain_package('neutron').with(
|
||||||
|
:ensure => 'present',
|
||||||
|
:name => platform_params[:common_package_name]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'configures credentials for rabbit' do
|
||||||
|
should contain_neutron_config('DEFAULT/rabbit_userid').with_value( params[:rabbit_user] )
|
||||||
|
should contain_neutron_config('DEFAULT/rabbit_password').with_value( params[:rabbit_password] )
|
||||||
|
should contain_neutron_config('DEFAULT/rabbit_virtual_host').with_value( params[:rabbit_virtual_host] )
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'configures neutron.conf' do
|
||||||
|
should contain_neutron_config('DEFAULT/verbose').with_value( params[:verbose] )
|
||||||
|
should contain_neutron_config('DEFAULT/bind_host').with_value('0.0.0.0')
|
||||||
|
should contain_neutron_config('DEFAULT/bind_port').with_value('9696')
|
||||||
|
should contain_neutron_config('DEFAULT/auth_strategy').with_value('keystone')
|
||||||
|
should contain_neutron_config('DEFAULT/core_plugin').with_value( params[:core_plugin] )
|
||||||
|
should contain_neutron_config('DEFAULT/base_mac').with_value('fa:16:3e:00:00:00')
|
||||||
|
should contain_neutron_config('DEFAULT/mac_generation_retries').with_value(16)
|
||||||
|
should contain_neutron_config('DEFAULT/dhcp_lease_duration').with_value(120)
|
||||||
|
should contain_neutron_config('DEFAULT/allow_bulk').with_value(true)
|
||||||
|
should contain_neutron_config('DEFAULT/allow_overlapping_ips').with_value(false)
|
||||||
|
should contain_neutron_config('DEFAULT/control_exchange').with_value('neutron')
|
||||||
|
should contain_neutron_config('AGENT/root_helper').with_value('sudo neutron-rootwrap /etc/neutron/rootwrap.conf')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'rabbit HA with a single virtual host' do
|
||||||
|
it 'in neutron.conf' do
|
||||||
|
should_not contain_neutron_config('DEFAULT/rabbit_host')
|
||||||
|
should_not contain_neutron_config('DEFAULT/rabbit_port')
|
||||||
|
should contain_neutron_config('DEFAULT/rabbit_hosts').with_value( params[:rabbit_hosts] )
|
||||||
|
should contain_neutron_config('DEFAULT/rabbit_ha_queues').with_value(true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'rabbit HA with multiple hosts' do
|
||||||
|
it 'in neutron.conf' do
|
||||||
|
should_not contain_neutron_config('DEFAULT/rabbit_host')
|
||||||
|
should_not contain_neutron_config('DEFAULT/rabbit_port')
|
||||||
|
should contain_neutron_config('DEFAULT/rabbit_hosts').with_value( params[:rabbit_hosts].join(',') )
|
||||||
|
should contain_neutron_config('DEFAULT/rabbit_ha_queues').with_value(true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
context 'on Debian platforms' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => 'Debian' }
|
||||||
|
end
|
||||||
|
|
||||||
|
let :platform_params do
|
||||||
|
{ :common_package_name => 'neutron-common' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it_configures 'neutron'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on RedHat platforms' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => 'RedHat' }
|
||||||
|
end
|
||||||
|
|
||||||
|
let :platform_params do
|
||||||
|
{ :common_package_name => 'openstack-neutron' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it_configures 'neutron'
|
||||||
|
end
|
||||||
|
end
|
@ -1,33 +1,33 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::keystone::auth' do
|
describe 'neutron::keystone::auth' do
|
||||||
|
|
||||||
describe 'with default class parameters' do
|
describe 'with default class parameters' do
|
||||||
let :params do
|
let :params do
|
||||||
{
|
{
|
||||||
:password => 'quantum_password',
|
:password => 'neutron_password',
|
||||||
:tenant => 'foobar'
|
:tenant => 'foobar'
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_keystone_user('quantum').with(
|
it { should contain_keystone_user('neutron').with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
:password => 'quantum_password',
|
:password => 'neutron_password',
|
||||||
:tenant => 'foobar'
|
:tenant => 'foobar'
|
||||||
) }
|
) }
|
||||||
|
|
||||||
it { should contain_keystone_user_role('quantum@foobar').with(
|
it { should contain_keystone_user_role('neutron@foobar').with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
:roles => 'admin'
|
:roles => 'admin'
|
||||||
)}
|
)}
|
||||||
|
|
||||||
it { should contain_keystone_service('quantum').with(
|
it { should contain_keystone_service('neutron').with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
:type => 'network',
|
:type => 'network',
|
||||||
:description => 'Quantum Networking Service'
|
:description => 'Neutron Networking Service'
|
||||||
) }
|
) }
|
||||||
|
|
||||||
it { should contain_keystone_endpoint('RegionOne/quantum').with(
|
it { should contain_keystone_endpoint('RegionOne/neutron').with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
:public_url => "http://127.0.0.1:9696/",
|
:public_url => "http://127.0.0.1:9696/",
|
||||||
:admin_url => "http://127.0.0.1:9696/",
|
:admin_url => "http://127.0.0.1:9696/",
|
||||||
@ -40,7 +40,7 @@ describe 'quantum::keystone::auth' do
|
|||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{
|
{
|
||||||
:password => 'quantum_password',
|
:password => 'neutron_password',
|
||||||
:public_protocol => 'https',
|
:public_protocol => 'https',
|
||||||
:public_port => '80',
|
:public_port => '80',
|
||||||
:public_address => '10.10.10.10',
|
:public_address => '10.10.10.10',
|
||||||
@ -50,7 +50,7 @@ describe 'quantum::keystone::auth' do
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_keystone_endpoint('RegionOne/quantum').with(
|
it { should contain_keystone_endpoint('RegionOne/neutron').with(
|
||||||
:ensure => 'present',
|
:ensure => 'present',
|
||||||
:public_url => "https://10.10.10.10:80/",
|
:public_url => "https://10.10.10.10:80/",
|
||||||
:internal_url => "http://10.10.10.11:81/",
|
:internal_url => "http://10.10.10.11:81/",
|
||||||
@ -64,17 +64,17 @@ describe 'quantum::keystone::auth' do
|
|||||||
let :params do
|
let :params do
|
||||||
{
|
{
|
||||||
:password => 'foo',
|
:password => 'foo',
|
||||||
:auth_name => 'quantumy'
|
:auth_name => 'neutrony'
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_keystone_user('quantumy') }
|
it { should contain_keystone_user('neutrony') }
|
||||||
|
|
||||||
it { should contain_keystone_user_role('quantumy@services') }
|
it { should contain_keystone_user_role('neutrony@services') }
|
||||||
|
|
||||||
it { should contain_keystone_service('quantumy') }
|
it { should contain_keystone_service('neutrony') }
|
||||||
|
|
||||||
it { should contain_keystone_endpoint('RegionOne/quantumy') }
|
it { should contain_keystone_endpoint('RegionOne/neutrony') }
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
@ -1,34 +1,34 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::plugins::cisco' do
|
describe 'neutron::plugins::cisco' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum::server': auth_password => 'password'}"
|
"class { 'neutron::server': auth_password => 'password'}"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{ :keystone_username => 'quantum',
|
{ :keystone_username => 'neutron',
|
||||||
:keystone_password => 'quantum_pass',
|
:keystone_password => 'neutron_pass',
|
||||||
:keystone_auth_url => 'http://127.0.0.1:35357/v2.0/',
|
:keystone_auth_url => 'http://127.0.0.1:35357/v2.0/',
|
||||||
:keystone_tenant => 'tenant',
|
:keystone_tenant => 'tenant',
|
||||||
|
|
||||||
:database_name => 'quantum',
|
:database_name => 'neutron',
|
||||||
:database_pass => 'dbpass',
|
:database_pass => 'dbpass',
|
||||||
:database_host => 'localhost',
|
:database_host => 'localhost',
|
||||||
:database_user => 'quantum'}
|
:database_user => 'neutron'}
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params_default do
|
let :params_default do
|
||||||
{
|
{
|
||||||
:vswitch_plugin => 'quantum.plugins.openvswitch.ovs_quantum_plugin.OVSQuantumPluginV2',
|
:vswitch_plugin => 'neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2',
|
||||||
:vlan_start => '100',
|
:vlan_start => '100',
|
||||||
:vlan_end => '3000',
|
:vlan_end => '3000',
|
||||||
:vlan_name_prefix => 'q-',
|
:vlan_name_prefix => 'q-',
|
||||||
:model_class => 'quantum.plugins.cisco.models.virt_phy_sw_v2.VirtualPhysicalSwitchModelV2',
|
:model_class => 'neutron.plugins.cisco.models.virt_phy_sw_v2.VirtualPhysicalSwitchModelV2',
|
||||||
:max_ports => '100',
|
:max_ports => '100',
|
||||||
:max_port_profiles => '65568',
|
:max_port_profiles => '65568',
|
||||||
:max_networks => '65568',
|
:max_networks => '65568',
|
||||||
:manager_class => 'quantum.plugins.cisco.segmentation.l2network_vlan_mgr_v2.L2NetworkVLANMgr'
|
:manager_class => 'neutron.plugins.cisco.segmentation.l2network_vlan_mgr_v2.L2NetworkVLANMgr'
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -39,82 +39,82 @@ describe 'quantum::plugins::cisco' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should have a plugin config folder' do
|
it 'should have a plugin config folder' do
|
||||||
should contain_file('/etc/quantum/plugins').with(
|
should contain_file('/etc/neutron/plugins').with(
|
||||||
:ensure => 'directory',
|
:ensure => 'directory',
|
||||||
:owner => 'root',
|
:owner => 'root',
|
||||||
:group => 'quantum',
|
:group => 'neutron',
|
||||||
:mode => '0640'
|
:mode => '0640'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should have a cisco plugin config folder' do
|
it 'should have a cisco plugin config folder' do
|
||||||
should contain_file('/etc/quantum/plugins/cisco').with(
|
should contain_file('/etc/neutron/plugins/cisco').with(
|
||||||
:ensure => 'directory',
|
:ensure => 'directory',
|
||||||
:owner => 'root',
|
:owner => 'root',
|
||||||
:group => 'quantum',
|
:group => 'neutron',
|
||||||
:mode => '0640'
|
:mode => '0640'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform default l2 configuration' do
|
it 'should perform default l2 configuration' do
|
||||||
should contain_quantum_plugin_cisco_l2network('VLANS/vlan_start').\
|
should contain_neutron_plugin_cisco_l2network('VLANS/vlan_start').\
|
||||||
with_value(params[:vlan_start])
|
with_value(params[:vlan_start])
|
||||||
should contain_quantum_plugin_cisco_l2network('VLANS/vlan_end').\
|
should contain_neutron_plugin_cisco_l2network('VLANS/vlan_end').\
|
||||||
with_value(params[:vlan_end])
|
with_value(params[:vlan_end])
|
||||||
should contain_quantum_plugin_cisco_l2network('VLANS/vlan_name_prefix').\
|
should contain_neutron_plugin_cisco_l2network('VLANS/vlan_name_prefix').\
|
||||||
with_value(params[:vlan_name_prefix])
|
with_value(params[:vlan_name_prefix])
|
||||||
should contain_quantum_plugin_cisco_l2network('MODEL/model_class').\
|
should contain_neutron_plugin_cisco_l2network('MODEL/model_class').\
|
||||||
with_value(params[:model_class])
|
with_value(params[:model_class])
|
||||||
should contain_quantum_plugin_cisco_l2network('PORTS/max_ports').\
|
should contain_neutron_plugin_cisco_l2network('PORTS/max_ports').\
|
||||||
with_value(params[:max_ports])
|
with_value(params[:max_ports])
|
||||||
should contain_quantum_plugin_cisco_l2network('PORTPROFILES/max_port_profiles').\
|
should contain_neutron_plugin_cisco_l2network('PORTPROFILES/max_port_profiles').\
|
||||||
with_value(params[:max_port_profiles])
|
with_value(params[:max_port_profiles])
|
||||||
should contain_quantum_plugin_cisco_l2network('NETWORKS/max_networks').\
|
should contain_neutron_plugin_cisco_l2network('NETWORKS/max_networks').\
|
||||||
with_value(params[:max_networks])
|
with_value(params[:max_networks])
|
||||||
should contain_quantum_plugin_cisco_l2network('SEGMENTATION/manager_class').\
|
should contain_neutron_plugin_cisco_l2network('SEGMENTATION/manager_class').\
|
||||||
with_value(params[:manager_class])
|
with_value(params[:manager_class])
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should create a dummy inventory item' do
|
it 'should create a dummy inventory item' do
|
||||||
should contain_quantum_plugin_cisco('INVENTORY/dummy').\
|
should contain_neutron_plugin_cisco('INVENTORY/dummy').\
|
||||||
with_value('dummy')
|
with_value('dummy')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should configure the db connection' do
|
it 'should configure the db connection' do
|
||||||
should contain_quantum_plugin_cisco_db_conn('DATABASE/name').\
|
should contain_neutron_plugin_cisco_db_conn('DATABASE/name').\
|
||||||
with_value(params[:database_name])
|
with_value(params[:database_name])
|
||||||
should contain_quantum_plugin_cisco_db_conn('DATABASE/user').\
|
should contain_neutron_plugin_cisco_db_conn('DATABASE/user').\
|
||||||
with_value(params[:database_user])
|
with_value(params[:database_user])
|
||||||
should contain_quantum_plugin_cisco_db_conn('DATABASE/pass').\
|
should contain_neutron_plugin_cisco_db_conn('DATABASE/pass').\
|
||||||
with_value(params[:database_pass])
|
with_value(params[:database_pass])
|
||||||
should contain_quantum_plugin_cisco_db_conn('DATABASE/host').\
|
should contain_neutron_plugin_cisco_db_conn('DATABASE/host').\
|
||||||
with_value(params[:database_host])
|
with_value(params[:database_host])
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should configure the admin credentials' do
|
it 'should configure the admin credentials' do
|
||||||
should contain_quantum_plugin_cisco_credentials('keystone/username').\
|
should contain_neutron_plugin_cisco_credentials('keystone/username').\
|
||||||
with_value(params[:keystone_username])
|
with_value(params[:keystone_username])
|
||||||
should contain_quantum_plugin_cisco_credentials('keystone/password').\
|
should contain_neutron_plugin_cisco_credentials('keystone/password').\
|
||||||
with_value(params[:keystone_password])
|
with_value(params[:keystone_password])
|
||||||
should contain_quantum_plugin_cisco_credentials('keystone/auth_url').\
|
should contain_neutron_plugin_cisco_credentials('keystone/auth_url').\
|
||||||
with_value(params[:keystone_auth_url])
|
with_value(params[:keystone_auth_url])
|
||||||
should contain_quantum_plugin_cisco_credentials('keystone/tenant').\
|
should contain_neutron_plugin_cisco_credentials('keystone/tenant').\
|
||||||
with_value(params[:keystone_tenant])
|
with_value(params[:keystone_tenant])
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform vswitch plugin configuration' do
|
it 'should perform vswitch plugin configuration' do
|
||||||
should contain_quantum_plugin_cisco('PLUGINS/vswitch_plugin').\
|
should contain_neutron_plugin_cisco('PLUGINS/vswitch_plugin').\
|
||||||
with_value('quantum.plugins.openvswitch.ovs_quantum_plugin.OVSQuantumPluginV2')
|
with_value('neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2')
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'with nexus plugin' do
|
describe 'with nexus plugin' do
|
||||||
before do
|
before do
|
||||||
params.merge!(:nexus_plugin => 'quantum.plugins.cisco.nexus.cisco_nexus_plugin_v2.NexusPlugin')
|
params.merge!(:nexus_plugin => 'neutron.plugins.cisco.nexus.cisco_nexus_plugin_v2.NexusPlugin')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform nexus plugin configuration' do
|
it 'should perform nexus plugin configuration' do
|
||||||
should contain_quantum_plugin_cisco('PLUGINS/nexus_plugin').\
|
should contain_neutron_plugin_cisco('PLUGINS/nexus_plugin').\
|
||||||
with_value('quantum.plugins.cisco.nexus.cisco_nexus_plugin_v2.NexusPlugin')
|
with_value('neutron.plugins.cisco.nexus.cisco_nexus_plugin_v2.NexusPlugin')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
@ -1,9 +1,9 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::plugins::linuxbridge' do
|
describe 'neutron::plugins::linuxbridge' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }"
|
"class { 'neutron': rabbit_password => 'passw0rd' }"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
@ -14,25 +14,25 @@ describe 'quantum::plugins::linuxbridge' do
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'quantum linuxbridge plugin' do
|
shared_examples_for 'neutron linuxbridge plugin' do
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
it { should include_class('neutron::params') }
|
||||||
|
|
||||||
it 'installs quantum linuxbridge plugin package' do
|
it 'installs neutron linuxbridge plugin package' do
|
||||||
should contain_package('quantum-plugin-linuxbridge').with(
|
should contain_package('neutron-plugin-linuxbridge').with(
|
||||||
:ensure => params[:package_ensure],
|
:ensure => params[:package_ensure],
|
||||||
:name => platform_params[:linuxbridge_plugin_package]
|
:name => platform_params[:linuxbridge_plugin_package]
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures linuxbridge_conf.ini' do
|
it 'configures linuxbridge_conf.ini' do
|
||||||
should contain_quantum_plugin_linuxbridge('DATABASE/sql_connection').with(
|
should contain_neutron_plugin_linuxbridge('DATABASE/sql_connection').with(
|
||||||
:value => params[:sql_connection]
|
:value => params[:sql_connection]
|
||||||
)
|
)
|
||||||
should contain_quantum_plugin_linuxbridge('VLANS/tenant_network_type').with(
|
should contain_neutron_plugin_linuxbridge('VLANS/tenant_network_type').with(
|
||||||
:value => params[:tenant_network_type]
|
:value => params[:tenant_network_type]
|
||||||
)
|
)
|
||||||
should contain_quantum_plugin_linuxbridge('VLANS/network_vlan_ranges').with(
|
should contain_neutron_plugin_linuxbridge('VLANS/network_vlan_ranges').with(
|
||||||
:value => params[:network_vlan_ranges]
|
:value => params[:network_vlan_ranges]
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
@ -45,13 +45,13 @@ describe 'quantum::plugins::linuxbridge' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :linuxbridge_plugin_package => 'quantum-plugin-linuxbridge' }
|
{ :linuxbridge_plugin_package => 'neutron-plugin-linuxbridge' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum linuxbridge plugin'
|
it_configures 'neutron linuxbridge plugin'
|
||||||
it 'configures /etc/default/quantum-server' do
|
it 'configures /etc/default/neutron-server' do
|
||||||
should contain_file_line('/etc/default/quantum-server:QUANTUM_PLUGIN_CONFIG').with(
|
should contain_file_line('/etc/default/neutron-server:NEUTRON_PLUGIN_CONFIG').with(
|
||||||
:line => 'QUANTUM_PLUGIN_CONFIG=/etc/quantum/plugins/linuxbridge/linuxbridge_conf.ini'
|
:line => 'NEUTRON_PLUGIN_CONFIG=/etc/neutron/plugins/linuxbridge/linuxbridge_conf.ini'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -62,9 +62,9 @@ describe 'quantum::plugins::linuxbridge' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :linuxbridge_plugin_package => 'openstack-quantum-linuxbridge' }
|
{ :linuxbridge_plugin_package => 'openstack-neutron-linuxbridge' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum linuxbridge plugin'
|
it_configures 'neutron linuxbridge plugin'
|
||||||
end
|
end
|
||||||
end
|
end
|
@ -1,15 +1,15 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::plugins::ovs' do
|
describe 'neutron::plugins::ovs' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }"
|
"class { 'neutron': rabbit_password => 'passw0rd' }"
|
||||||
end
|
end
|
||||||
|
|
||||||
let :default_params do
|
let :default_params do
|
||||||
{
|
{
|
||||||
:package_ensure => 'present',
|
:package_ensure => 'present',
|
||||||
:sql_connection => 'sqlite:////var/lib/quantum/ovs.sqlite',
|
:sql_connection => 'sqlite:////var/lib/neutron/ovs.sqlite',
|
||||||
:sql_max_retries => 10,
|
:sql_max_retries => 10,
|
||||||
:sql_idle_timeout => '3600',
|
:sql_idle_timeout => '3600',
|
||||||
:reconnect_interval => 2,
|
:reconnect_interval => 2,
|
||||||
@ -22,7 +22,7 @@ describe 'quantum::plugins::ovs' do
|
|||||||
{ }
|
{ }
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'quantum ovs plugin' do
|
shared_examples_for 'neutron ovs plugin' do
|
||||||
before do
|
before do
|
||||||
params.merge!(default_params)
|
params.merge!(default_params)
|
||||||
end
|
end
|
||||||
@ -32,12 +32,12 @@ describe 'quantum::plugins::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform default configuration of' do
|
it 'should perform default configuration of' do
|
||||||
should contain_quantum_plugin_ovs('DATABASE/sql_connection').with_value(params[:sql_connection])
|
should contain_neutron_plugin_ovs('DATABASE/sql_connection').with_value(params[:sql_connection])
|
||||||
should contain_quantum_plugin_ovs('DATABASE/sql_max_retries').with_value(params[:sql_max_retries])
|
should contain_neutron_plugin_ovs('DATABASE/sql_max_retries').with_value(params[:sql_max_retries])
|
||||||
should contain_quantum_plugin_ovs('DATABASE/sql_idle_timeout').with_value(params[:sql_idle_timeout])
|
should contain_neutron_plugin_ovs('DATABASE/sql_idle_timeout').with_value(params[:sql_idle_timeout])
|
||||||
should contain_quantum_plugin_ovs('DATABASE/reconnect_interval').with_value(params[:reconnect_interval])
|
should contain_neutron_plugin_ovs('DATABASE/reconnect_interval').with_value(params[:reconnect_interval])
|
||||||
should contain_quantum_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
should contain_neutron_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
||||||
should contain_package('quantum-plugin-ovs').with(
|
should contain_package('neutron-plugin-ovs').with(
|
||||||
:name => platform_params[:ovs_server_package],
|
:name => platform_params[:ovs_server_package],
|
||||||
:ensure => params[:package_ensure]
|
:ensure => params[:package_ensure]
|
||||||
)
|
)
|
||||||
@ -49,8 +49,8 @@ describe 'quantum::plugins::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform vlan network configuration' do
|
it 'should perform vlan network configuration' do
|
||||||
should contain_quantum_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
should contain_neutron_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
||||||
should contain_quantum_plugin_ovs('OVS/network_vlan_ranges').with_value(params[:network_vlan_ranges])
|
should contain_neutron_plugin_ovs('OVS/network_vlan_ranges').with_value(params[:network_vlan_ranges])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -64,8 +64,8 @@ describe 'quantum::plugins::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform gre network configuration' do
|
it 'should perform gre network configuration' do
|
||||||
should contain_quantum_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
should contain_neutron_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
||||||
should contain_quantum_plugin_ovs('OVS/tunnel_id_ranges').with_value(params[:tunnel_id_ranges])
|
should contain_neutron_plugin_ovs('OVS/tunnel_id_ranges').with_value(params[:tunnel_id_ranges])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -77,9 +77,9 @@ describe 'quantum::plugins::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform gre network configuration' do
|
it 'should perform gre network configuration' do
|
||||||
should contain_quantum_plugin_ovs('OVS/network_vlan_ranges').with_value(params[:network_vlan_ranges])
|
should contain_neutron_plugin_ovs('OVS/network_vlan_ranges').with_value(params[:network_vlan_ranges])
|
||||||
should contain_quantum_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
should contain_neutron_plugin_ovs('OVS/tenant_network_type').with_value(params[:tenant_network_type])
|
||||||
should contain_quantum_plugin_ovs('OVS/tunnel_id_ranges').with_value(params[:tunnel_id_ranges])
|
should contain_neutron_plugin_ovs('OVS/tunnel_id_ranges').with_value(params[:tunnel_id_ranges])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -87,7 +87,7 @@ describe 'quantum::plugins::ovs' do
|
|||||||
let :params do
|
let :params do
|
||||||
{ :tenant_network_type => 'flat'}
|
{ :tenant_network_type => 'flat'}
|
||||||
end
|
end
|
||||||
it { should contain_quantum_plugin_ovs('OVS/network_vlan_ranges').with_value(params[:network_vlan_ranges]) }
|
it { should contain_neutron_plugin_ovs('OVS/network_vlan_ranges').with_value(params[:network_vlan_ranges]) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -97,10 +97,10 @@ describe 'quantum::plugins::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :ovs_server_package => 'quantum-plugin-openvswitch' }
|
{ :ovs_server_package => 'neutron-plugin-openvswitch' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum ovs plugin'
|
it_configures 'neutron ovs plugin'
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
context 'on RedHat platforms' do
|
||||||
@ -113,17 +113,17 @@ describe 'quantum::plugins::ovs' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :ovs_server_package => 'openstack-quantum-openvswitch' }
|
{ :ovs_server_package => 'openstack-neutron-openvswitch' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should perform redhat specific configuration' do
|
it 'should perform redhat specific configuration' do
|
||||||
should contain_file('/etc/quantum/plugin.ini').with(
|
should contain_file('/etc/neutron/plugin.ini').with(
|
||||||
:ensure => 'link',
|
:ensure => 'link',
|
||||||
:target => '/etc/quantum/plugins/openvswitch/ovs_quantum_plugin.ini',
|
:target => '/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini',
|
||||||
:require => 'Package[quantum-plugin-ovs]'
|
:require => 'Package[neutron-plugin-ovs]'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum ovs plugin'
|
it_configures 'neutron ovs plugin'
|
||||||
end
|
end
|
||||||
end
|
end
|
@ -1,6 +1,6 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::quota' do
|
describe 'neutron::quota' do
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{}
|
{}
|
||||||
@ -15,26 +15,26 @@ describe 'quantum::quota' do
|
|||||||
:quota_floatingip => 50,
|
:quota_floatingip => 50,
|
||||||
:quota_security_group => 10,
|
:quota_security_group => 10,
|
||||||
:quota_security_group_rule => 100,
|
:quota_security_group_rule => 100,
|
||||||
:quota_driver => 'quantum.quota.ConfDriver',
|
:quota_driver => 'neutron.quota.ConfDriver',
|
||||||
:quota_firewall => 1,
|
:quota_firewall => 1,
|
||||||
:quota_firewall_policy => 1,
|
:quota_firewall_policy => 1,
|
||||||
:quota_firewall_rule => -1 }
|
:quota_firewall_rule => -1 }
|
||||||
end
|
end
|
||||||
|
|
||||||
shared_examples_for 'quantum quota' do
|
shared_examples_for 'neutron quota' do
|
||||||
let :params_hash do
|
let :params_hash do
|
||||||
default_params.merge(params)
|
default_params.merge(params)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures quota in quantum.conf' do
|
it 'configures quota in neutron.conf' do
|
||||||
params_hash.each_pair do |config,value|
|
params_hash.each_pair do |config,value|
|
||||||
should contain_quantum_config("QUOTAS/#{config}").with_value( value )
|
should contain_neutron_config("QUOTAS/#{config}").with_value( value )
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'with default parameters' do
|
context 'with default parameters' do
|
||||||
it_configures 'quantum quota'
|
it_configures 'neutron quota'
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'with provided parameters' do
|
context 'with provided parameters' do
|
||||||
@ -53,6 +53,6 @@ describe 'quantum::quota' do
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'quantum quota'
|
it_configures 'neutron quota'
|
||||||
end
|
end
|
||||||
end
|
end
|
158
spec/classes/neutron_server_spec.rb
Normal file
158
spec/classes/neutron_server_spec.rb
Normal file
@ -0,0 +1,158 @@
|
|||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe 'neutron::server' do
|
||||||
|
|
||||||
|
let :pre_condition do
|
||||||
|
"class { 'neutron': rabbit_password => 'passw0rd' }"
|
||||||
|
end
|
||||||
|
|
||||||
|
let :params do
|
||||||
|
{ :auth_password => 'passw0rd',
|
||||||
|
:auth_user => 'neutron' }
|
||||||
|
end
|
||||||
|
|
||||||
|
let :default_params do
|
||||||
|
{ :package_ensure => 'present',
|
||||||
|
:enabled => true,
|
||||||
|
:log_dir => '/var/log/neutron',
|
||||||
|
:auth_type => 'keystone',
|
||||||
|
:auth_host => 'localhost',
|
||||||
|
:auth_port => '35357',
|
||||||
|
:auth_tenant => 'services',
|
||||||
|
:auth_user => 'neutron' }
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'a neutron server' do
|
||||||
|
let :p do
|
||||||
|
default_params.merge(params)
|
||||||
|
end
|
||||||
|
|
||||||
|
it { should include_class('neutron::params') }
|
||||||
|
it 'configures logging' do
|
||||||
|
should contain_neutron_config('DEFAULT/log_file').with_ensure('absent')
|
||||||
|
should contain_neutron_config('DEFAULT/log_dir').with_value(p[:log_dir])
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'configures authentication middleware' do
|
||||||
|
should contain_neutron_api_config('filter:authtoken/auth_host').with_value(p[:auth_host]);
|
||||||
|
should contain_neutron_api_config('filter:authtoken/auth_port').with_value(p[:auth_port]);
|
||||||
|
should contain_neutron_api_config('filter:authtoken/admin_tenant_name').with_value(p[:auth_tenant]);
|
||||||
|
should contain_neutron_api_config('filter:authtoken/admin_user').with_value(p[:auth_user]);
|
||||||
|
should contain_neutron_api_config('filter:authtoken/admin_password').with_value(p[:auth_password]);
|
||||||
|
should contain_neutron_api_config('filter:authtoken/auth_admin_prefix').with(:ensure => 'absent')
|
||||||
|
end
|
||||||
|
|
||||||
|
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]
|
||||||
|
)
|
||||||
|
should contain_package('neutron-server').with_before(/Neutron_api_config\[.+\]/)
|
||||||
|
should contain_package('neutron-server').with_before(/Neutron_config\[.+\]/)
|
||||||
|
should contain_package('neutron-server').with_before(/Service\[neutron-server\]/)
|
||||||
|
else
|
||||||
|
should contain_package('neutron').with_before(/Neutron_api_config\[.+\]/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'configures neutron server service' do
|
||||||
|
should contain_service('neutron-server').with(
|
||||||
|
:name => platform_params[:server_service],
|
||||||
|
:enable => true,
|
||||||
|
:ensure => 'running',
|
||||||
|
:require => 'Class[Neutron]'
|
||||||
|
)
|
||||||
|
should contain_neutron_api_config('filter:authtoken/auth_admin_prefix').with(
|
||||||
|
:ensure => 'absent'
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'a neutron server with auth_admin_prefix set' do
|
||||||
|
[ '/keystone', '/keystone/admin', '' ].each do |auth_admin_prefix|
|
||||||
|
describe "with keystone_auth_admin_prefix containing incorrect value #{auth_admin_prefix}" do
|
||||||
|
before do
|
||||||
|
params.merge!({
|
||||||
|
:auth_admin_prefix => auth_admin_prefix,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
it do
|
||||||
|
should contain_neutron_api_config('filter:authtoken/auth_admin_prefix').with(
|
||||||
|
:value => params[:auth_admin_prefix]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
shared_examples_for 'a neutron server with some incorrect auth_admin_prefix set' do
|
||||||
|
[ '/keystone/', 'keystone/', 'keystone' ].each do |auth_admin_prefix|
|
||||||
|
describe "with keystone_auth_admin_prefix containing incorrect value #{auth_admin_prefix}" do
|
||||||
|
before do
|
||||||
|
params.merge!({
|
||||||
|
:auth_admin_prefix => auth_admin_prefix,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
it do
|
||||||
|
expect {
|
||||||
|
should contain_neutron_api_config('filter:authtoken/auth_admin_prefix')
|
||||||
|
}.to raise_error(Puppet::Error, /validate_re\(\): "#{auth_admin_prefix}" does not match/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'a neutron server with broken authentication' do
|
||||||
|
before do
|
||||||
|
params.delete(:auth_password)
|
||||||
|
end
|
||||||
|
it_raises 'a Puppet::Error', /auth_password must be set/
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples_for 'a neutron server with log_file specified' do
|
||||||
|
before do
|
||||||
|
params.merge!(
|
||||||
|
:log_file => '/var/log/neutron/server.log'
|
||||||
|
)
|
||||||
|
end
|
||||||
|
it 'configures logging' do
|
||||||
|
should contain_neutron_config('DEFAULT/log_file').with_value(params[:log_file])
|
||||||
|
should contain_neutron_config('DEFAULT/log_dir').with_ensure('absent')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on Debian platforms' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => 'Debian' }
|
||||||
|
end
|
||||||
|
|
||||||
|
let :platform_params do
|
||||||
|
{ :server_package => 'neutron-server',
|
||||||
|
:server_service => 'neutron-server' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it_configures 'a neutron server'
|
||||||
|
it_configures 'a neutron server with broken authentication'
|
||||||
|
it_configures 'a neutron server with log_file specified'
|
||||||
|
it_configures 'a neutron server with auth_admin_prefix set'
|
||||||
|
it_configures 'a neutron server with some incorrect auth_admin_prefix set'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on RedHat platforms' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => 'RedHat' }
|
||||||
|
end
|
||||||
|
|
||||||
|
let :platform_params do
|
||||||
|
{ :server_service => 'neutron-server' }
|
||||||
|
end
|
||||||
|
|
||||||
|
it_configures 'a neutron server'
|
||||||
|
it_configures 'a neutron server with broken authentication'
|
||||||
|
it_configures 'a neutron server with log_file specified'
|
||||||
|
it_configures 'a neutron server with auth_admin_prefix set'
|
||||||
|
it_configures 'a neutron server with some incorrect auth_admin_prefix set'
|
||||||
|
end
|
||||||
|
end
|
@ -1,108 +0,0 @@
|
|||||||
require 'spec_helper'
|
|
||||||
|
|
||||||
describe 'quantum::agents::dhcp' do
|
|
||||||
|
|
||||||
let :pre_condition do
|
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }"
|
|
||||||
end
|
|
||||||
|
|
||||||
let :params do
|
|
||||||
{}
|
|
||||||
end
|
|
||||||
|
|
||||||
let :default_params do
|
|
||||||
{ :package_ensure => 'present',
|
|
||||||
:enabled => true,
|
|
||||||
:debug => false,
|
|
||||||
:state_path => '/var/lib/quantum',
|
|
||||||
:resync_interval => 30,
|
|
||||||
:interface_driver => 'quantum.agent.linux.interface.OVSInterfaceDriver',
|
|
||||||
:dhcp_driver => 'quantum.agent.linux.dhcp.Dnsmasq',
|
|
||||||
:root_helper => 'sudo quantum-rootwrap /etc/quantum/rootwrap.conf',
|
|
||||||
:use_namespaces => true }
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
shared_examples_for 'quantum dhcp agent' do
|
|
||||||
let :p do
|
|
||||||
default_params.merge(params)
|
|
||||||
end
|
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
|
||||||
|
|
||||||
it_configures 'dnsmasq dhcp_driver'
|
|
||||||
|
|
||||||
it 'configures dhcp_agent.ini' do
|
|
||||||
should contain_quantum_dhcp_agent_config('DEFAULT/debug').with_value(p[:debug]);
|
|
||||||
should contain_quantum_dhcp_agent_config('DEFAULT/state_path').with_value(p[:state_path]);
|
|
||||||
should contain_quantum_dhcp_agent_config('DEFAULT/resync_interval').with_value(p[:resync_interval]);
|
|
||||||
should contain_quantum_dhcp_agent_config('DEFAULT/interface_driver').with_value(p[:interface_driver]);
|
|
||||||
should contain_quantum_dhcp_agent_config('DEFAULT/dhcp_driver').with_value(p[:dhcp_driver]);
|
|
||||||
should contain_quantum_dhcp_agent_config('DEFAULT/root_helper').with_value(p[:root_helper]);
|
|
||||||
should contain_quantum_dhcp_agent_config('DEFAULT/use_namespaces').with_value(p[:use_namespaces]);
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'installs quantum dhcp agent package' do
|
|
||||||
if platform_params.has_key?(:dhcp_agent_package)
|
|
||||||
should contain_package('quantum-dhcp-agent').with(
|
|
||||||
:name => platform_params[:dhcp_agent_package],
|
|
||||||
:ensure => p[:package_ensure]
|
|
||||||
)
|
|
||||||
should contain_package('quantum').with_before(/Package\[quantum-dhcp-agent\]/)
|
|
||||||
should contain_package('quantum-dhcp-agent').with_before(/Quantum_dhcp_agent_config\[.+\]/)
|
|
||||||
should contain_package('quantum-dhcp-agent').with_before(/Quantum_config\[.+\]/)
|
|
||||||
else
|
|
||||||
should contain_package('quantum').with_before(/Quantum_dhcp_agent_config\[.+\]/)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'configures quantum dhcp agent service' do
|
|
||||||
should contain_service('quantum-dhcp-service').with(
|
|
||||||
:name => platform_params[:dhcp_agent_service],
|
|
||||||
:enable => true,
|
|
||||||
:ensure => 'running',
|
|
||||||
:require => 'Class[Quantum]'
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'dnsmasq dhcp_driver' do
|
|
||||||
it 'installs dnsmasq packages' do
|
|
||||||
if platform_params.has_key?(:dhcp_agent_package)
|
|
||||||
should contain_package('dnsmasq').with_before('Package[quantum-dhcp-agent]')
|
|
||||||
end
|
|
||||||
should contain_package('dnsmasq').with(
|
|
||||||
:ensure => 'present',
|
|
||||||
:name => platform_params[:dnsmasq_packages]
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
context 'on Debian platforms' do
|
|
||||||
let :facts do
|
|
||||||
{ :osfamily => 'Debian' }
|
|
||||||
end
|
|
||||||
|
|
||||||
let :platform_params do
|
|
||||||
{ :dnsmasq_packages => ['dnsmasq-base', 'dnsmasq-utils'],
|
|
||||||
:dhcp_agent_package => 'quantum-dhcp-agent',
|
|
||||||
:dhcp_agent_service => 'quantum-dhcp-agent' }
|
|
||||||
end
|
|
||||||
|
|
||||||
it_configures 'quantum dhcp agent'
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
|
||||||
let :facts do
|
|
||||||
{ :osfamily => 'RedHat' }
|
|
||||||
end
|
|
||||||
|
|
||||||
let :platform_params do
|
|
||||||
{ :dnsmasq_packages => ['dnsmasq', 'dnsmasq-utils'],
|
|
||||||
:dhcp_agent_service => 'quantum-dhcp-agent' }
|
|
||||||
end
|
|
||||||
|
|
||||||
it_configures 'quantum dhcp agent'
|
|
||||||
end
|
|
||||||
end
|
|
@ -1,139 +0,0 @@
|
|||||||
require 'spec_helper'
|
|
||||||
|
|
||||||
describe 'quantum' do
|
|
||||||
|
|
||||||
let :params do
|
|
||||||
{ :package_ensure => 'present',
|
|
||||||
:verbose => false,
|
|
||||||
:debug => false,
|
|
||||||
:core_plugin => 'quantum.plugins.linuxbridge.lb_quantum_plugin.LinuxBridgePluginV2',
|
|
||||||
:rabbit_host => '127.0.0.1',
|
|
||||||
:rabbit_port => 5672,
|
|
||||||
:rabbit_hosts => false,
|
|
||||||
:rabbit_user => 'guest',
|
|
||||||
:rabbit_password => 'guest',
|
|
||||||
:rabbit_virtual_host => '/'
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'quantum' do
|
|
||||||
|
|
||||||
context 'and if rabbit_host parameter is provided' do
|
|
||||||
it_configures 'a quantum base installation'
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'and if rabbit_hosts parameter is provided' do
|
|
||||||
before do
|
|
||||||
params.delete(:rabbit_host)
|
|
||||||
params.delete(:rabbit_port)
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'with one server' do
|
|
||||||
before { params.merge!( :rabbit_hosts => ['127.0.0.1:5672'] ) }
|
|
||||||
it_configures 'a quantum base installation'
|
|
||||||
it_configures 'rabbit HA with a single virtual host'
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'with multiple servers' do
|
|
||||||
before { params.merge!( :rabbit_hosts => ['rabbit1:5672', 'rabbit2:5672'] ) }
|
|
||||||
it_configures 'a quantum base installation'
|
|
||||||
it_configures 'rabbit HA with multiple hosts'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'a quantum base installation' do
|
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
|
||||||
|
|
||||||
it 'configures quantum configuration folder' do
|
|
||||||
should contain_file('/etc/quantum/').with(
|
|
||||||
:ensure => 'directory',
|
|
||||||
:owner => 'root',
|
|
||||||
:group => 'quantum',
|
|
||||||
:mode => '0750',
|
|
||||||
:require => 'Package[quantum]'
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'configures quantum configuration file' do
|
|
||||||
should contain_file('/etc/quantum/quantum.conf').with(
|
|
||||||
:owner => 'root',
|
|
||||||
:group => 'quantum',
|
|
||||||
:mode => '0640',
|
|
||||||
:require => 'Package[quantum]'
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'installs quantum package' do
|
|
||||||
should contain_package('quantum').with(
|
|
||||||
:ensure => 'present',
|
|
||||||
:name => platform_params[:common_package_name]
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'configures credentials for rabbit' do
|
|
||||||
should contain_quantum_config('DEFAULT/rabbit_userid').with_value( params[:rabbit_user] )
|
|
||||||
should contain_quantum_config('DEFAULT/rabbit_password').with_value( params[:rabbit_password] )
|
|
||||||
should contain_quantum_config('DEFAULT/rabbit_virtual_host').with_value( params[:rabbit_virtual_host] )
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'configures quantum.conf' do
|
|
||||||
should contain_quantum_config('DEFAULT/verbose').with_value( params[:verbose] )
|
|
||||||
should contain_quantum_config('DEFAULT/bind_host').with_value('0.0.0.0')
|
|
||||||
should contain_quantum_config('DEFAULT/bind_port').with_value('9696')
|
|
||||||
should contain_quantum_config('DEFAULT/auth_strategy').with_value('keystone')
|
|
||||||
should contain_quantum_config('DEFAULT/core_plugin').with_value( params[:core_plugin] )
|
|
||||||
should contain_quantum_config('DEFAULT/base_mac').with_value('fa:16:3e:00:00:00')
|
|
||||||
should contain_quantum_config('DEFAULT/mac_generation_retries').with_value(16)
|
|
||||||
should contain_quantum_config('DEFAULT/dhcp_lease_duration').with_value(120)
|
|
||||||
should contain_quantum_config('DEFAULT/allow_bulk').with_value(true)
|
|
||||||
should contain_quantum_config('DEFAULT/allow_overlapping_ips').with_value(false)
|
|
||||||
should contain_quantum_config('DEFAULT/control_exchange').with_value('quantum')
|
|
||||||
should contain_quantum_config('AGENT/root_helper').with_value('sudo quantum-rootwrap /etc/quantum/rootwrap.conf')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'rabbit HA with a single virtual host' do
|
|
||||||
it 'in quantum.conf' do
|
|
||||||
should_not contain_quantum_config('DEFAULT/rabbit_host')
|
|
||||||
should_not contain_quantum_config('DEFAULT/rabbit_port')
|
|
||||||
should contain_quantum_config('DEFAULT/rabbit_hosts').with_value( params[:rabbit_hosts] )
|
|
||||||
should contain_quantum_config('DEFAULT/rabbit_ha_queues').with_value(true)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'rabbit HA with multiple hosts' do
|
|
||||||
it 'in quantum.conf' do
|
|
||||||
should_not contain_quantum_config('DEFAULT/rabbit_host')
|
|
||||||
should_not contain_quantum_config('DEFAULT/rabbit_port')
|
|
||||||
should contain_quantum_config('DEFAULT/rabbit_hosts').with_value( params[:rabbit_hosts].join(',') )
|
|
||||||
should contain_quantum_config('DEFAULT/rabbit_ha_queues').with_value(true)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
context 'on Debian platforms' do
|
|
||||||
let :facts do
|
|
||||||
{ :osfamily => 'Debian' }
|
|
||||||
end
|
|
||||||
|
|
||||||
let :platform_params do
|
|
||||||
{ :common_package_name => 'quantum-common' }
|
|
||||||
end
|
|
||||||
|
|
||||||
it_configures 'quantum'
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
|
||||||
let :facts do
|
|
||||||
{ :osfamily => 'RedHat' }
|
|
||||||
end
|
|
||||||
|
|
||||||
let :platform_params do
|
|
||||||
{ :common_package_name => 'openstack-quantum' }
|
|
||||||
end
|
|
||||||
|
|
||||||
it_configures 'quantum'
|
|
||||||
end
|
|
||||||
end
|
|
@ -1,158 +0,0 @@
|
|||||||
require 'spec_helper'
|
|
||||||
|
|
||||||
describe 'quantum::server' do
|
|
||||||
|
|
||||||
let :pre_condition do
|
|
||||||
"class { 'quantum': rabbit_password => 'passw0rd' }"
|
|
||||||
end
|
|
||||||
|
|
||||||
let :params do
|
|
||||||
{ :auth_password => 'passw0rd',
|
|
||||||
:auth_user => 'quantum' }
|
|
||||||
end
|
|
||||||
|
|
||||||
let :default_params do
|
|
||||||
{ :package_ensure => 'present',
|
|
||||||
:enabled => true,
|
|
||||||
:log_dir => '/var/log/quantum',
|
|
||||||
:auth_type => 'keystone',
|
|
||||||
:auth_host => 'localhost',
|
|
||||||
:auth_port => '35357',
|
|
||||||
:auth_tenant => 'services',
|
|
||||||
:auth_user => 'quantum' }
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'a quantum server' do
|
|
||||||
let :p do
|
|
||||||
default_params.merge(params)
|
|
||||||
end
|
|
||||||
|
|
||||||
it { should include_class('quantum::params') }
|
|
||||||
it 'configures logging' do
|
|
||||||
should contain_quantum_config('DEFAULT/log_file').with_ensure('absent')
|
|
||||||
should contain_quantum_config('DEFAULT/log_dir').with_value(p[:log_dir])
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'configures authentication middleware' do
|
|
||||||
should contain_quantum_api_config('filter:authtoken/auth_host').with_value(p[:auth_host]);
|
|
||||||
should contain_quantum_api_config('filter:authtoken/auth_port').with_value(p[:auth_port]);
|
|
||||||
should contain_quantum_api_config('filter:authtoken/admin_tenant_name').with_value(p[:auth_tenant]);
|
|
||||||
should contain_quantum_api_config('filter:authtoken/admin_user').with_value(p[:auth_user]);
|
|
||||||
should contain_quantum_api_config('filter:authtoken/admin_password').with_value(p[:auth_password]);
|
|
||||||
should contain_quantum_api_config('filter:authtoken/auth_admin_prefix').with(:ensure => 'absent')
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'installs quantum server package' do
|
|
||||||
if platform_params.has_key?(:server_package)
|
|
||||||
should contain_package('quantum-server').with(
|
|
||||||
:name => platform_params[:server_package],
|
|
||||||
:ensure => p[:package_ensure]
|
|
||||||
)
|
|
||||||
should contain_package('quantum-server').with_before(/Quantum_api_config\[.+\]/)
|
|
||||||
should contain_package('quantum-server').with_before(/Quantum_config\[.+\]/)
|
|
||||||
should contain_package('quantum-server').with_before(/Service\[quantum-server\]/)
|
|
||||||
else
|
|
||||||
should contain_package('quantum').with_before(/Quantum_api_config\[.+\]/)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'configures quantum server service' do
|
|
||||||
should contain_service('quantum-server').with(
|
|
||||||
:name => platform_params[:server_service],
|
|
||||||
:enable => true,
|
|
||||||
:ensure => 'running',
|
|
||||||
:require => 'Class[Quantum]'
|
|
||||||
)
|
|
||||||
should contain_quantum_api_config('filter:authtoken/auth_admin_prefix').with(
|
|
||||||
:ensure => 'absent'
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'a quantum server with auth_admin_prefix set' do
|
|
||||||
[ '/keystone', '/keystone/admin', '' ].each do |auth_admin_prefix|
|
|
||||||
describe "with keystone_auth_admin_prefix containing incorrect value #{auth_admin_prefix}" do
|
|
||||||
before do
|
|
||||||
params.merge!({
|
|
||||||
:auth_admin_prefix => auth_admin_prefix,
|
|
||||||
})
|
|
||||||
end
|
|
||||||
it do
|
|
||||||
should contain_quantum_api_config('filter:authtoken/auth_admin_prefix').with(
|
|
||||||
:value => params[:auth_admin_prefix]
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
shared_examples_for 'a quantum server with some incorrect auth_admin_prefix set' do
|
|
||||||
[ '/keystone/', 'keystone/', 'keystone' ].each do |auth_admin_prefix|
|
|
||||||
describe "with keystone_auth_admin_prefix containing incorrect value #{auth_admin_prefix}" do
|
|
||||||
before do
|
|
||||||
params.merge!({
|
|
||||||
:auth_admin_prefix => auth_admin_prefix,
|
|
||||||
})
|
|
||||||
end
|
|
||||||
it do
|
|
||||||
expect {
|
|
||||||
should contain_quantum_api_config('filter:authtoken/auth_admin_prefix')
|
|
||||||
}.to raise_error(Puppet::Error, /validate_re\(\): "#{auth_admin_prefix}" does not match/)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'a quantum server with broken authentication' do
|
|
||||||
before do
|
|
||||||
params.delete(:auth_password)
|
|
||||||
end
|
|
||||||
it_raises 'a Puppet::Error', /auth_password must be set/
|
|
||||||
end
|
|
||||||
|
|
||||||
shared_examples_for 'a quantum server with log_file specified' do
|
|
||||||
before do
|
|
||||||
params.merge!(
|
|
||||||
:log_file => '/var/log/quantum/server.log'
|
|
||||||
)
|
|
||||||
end
|
|
||||||
it 'configures logging' do
|
|
||||||
should contain_quantum_config('DEFAULT/log_file').with_value(params[:log_file])
|
|
||||||
should contain_quantum_config('DEFAULT/log_dir').with_ensure('absent')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'on Debian platforms' do
|
|
||||||
let :facts do
|
|
||||||
{ :osfamily => 'Debian' }
|
|
||||||
end
|
|
||||||
|
|
||||||
let :platform_params do
|
|
||||||
{ :server_package => 'quantum-server',
|
|
||||||
:server_service => 'quantum-server' }
|
|
||||||
end
|
|
||||||
|
|
||||||
it_configures 'a quantum server'
|
|
||||||
it_configures 'a quantum server with broken authentication'
|
|
||||||
it_configures 'a quantum server with log_file specified'
|
|
||||||
it_configures 'a quantum server with auth_admin_prefix set'
|
|
||||||
it_configures 'a quantum server with some incorrect auth_admin_prefix set'
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'on RedHat platforms' do
|
|
||||||
let :facts do
|
|
||||||
{ :osfamily => 'RedHat' }
|
|
||||||
end
|
|
||||||
|
|
||||||
let :platform_params do
|
|
||||||
{ :server_service => 'quantum-server' }
|
|
||||||
end
|
|
||||||
|
|
||||||
it_configures 'a quantum server'
|
|
||||||
it_configures 'a quantum server with broken authentication'
|
|
||||||
it_configures 'a quantum server with log_file specified'
|
|
||||||
it_configures 'a quantum server with auth_admin_prefix set'
|
|
||||||
it_configures 'a quantum server with some incorrect auth_admin_prefix set'
|
|
||||||
end
|
|
||||||
end
|
|
@ -1,6 +1,6 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe 'quantum::db::mysql::host_access' do
|
describe 'neutron::db::mysql::host_access' do
|
||||||
|
|
||||||
let :pre_condition do
|
let :pre_condition do
|
||||||
'include mysql'
|
'include mysql'
|
||||||
@ -11,15 +11,15 @@ describe 'quantum::db::mysql::host_access' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :params do
|
let :params do
|
||||||
{ :user => 'quantum',
|
{ :user => 'neutron',
|
||||||
:password => 'passw0rd',
|
:password => 'passw0rd',
|
||||||
:database => 'quantum' }
|
:database => 'neutron' }
|
||||||
end
|
end
|
||||||
|
|
||||||
let :facts do
|
let :facts do
|
||||||
{ :osfamily => 'Debian' }
|
{ :osfamily => 'Debian' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it { should contain_database_user('quantum@127.0.0.1') }
|
it { should contain_database_user('neutron@127.0.0.1') }
|
||||||
it { should contain_database_grant('quantum@127.0.0.1/quantum') }
|
it { should contain_database_grant('neutron@127.0.0.1/neutron') }
|
||||||
end
|
end
|
@ -1,13 +1,13 @@
|
|||||||
require 'puppet'
|
require 'puppet'
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
require 'puppet/provider/quantum_l3_ovs_bridge/quantum'
|
require 'puppet/provider/neutron_l3_ovs_bridge/neutron'
|
||||||
|
|
||||||
provider_class = Puppet::Type.type(:quantum_l3_ovs_bridge).provider(:quantum)
|
provider_class = Puppet::Type.type(:neutron_l3_ovs_bridge).provider(:neutron)
|
||||||
|
|
||||||
describe provider_class do
|
describe provider_class do
|
||||||
|
|
||||||
let :resource do
|
let :resource do
|
||||||
Puppet::Type::Quantum_l3_ovs_bridge.new(
|
Puppet::Type::Neutron_l3_ovs_bridge.new(
|
||||||
:name => 'br-ex',
|
:name => 'br-ex',
|
||||||
:subnet_name => 'subnet1'
|
:subnet_name => 'subnet1'
|
||||||
)
|
)
|
@ -1,8 +1,8 @@
|
|||||||
require 'puppet'
|
require 'puppet'
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
require 'puppet/provider/quantum_network/quantum'
|
require 'puppet/provider/neutron_network/neutron'
|
||||||
|
|
||||||
provider_class = Puppet::Type.type(:quantum_network).provider(:quantum)
|
provider_class = Puppet::Type.type(:neutron_network).provider(:neutron)
|
||||||
|
|
||||||
describe provider_class do
|
describe provider_class do
|
||||||
|
|
||||||
@ -23,7 +23,7 @@ describe provider_class do
|
|||||||
|
|
||||||
describe 'when updating a network' do
|
describe 'when updating a network' do
|
||||||
let :resource do
|
let :resource do
|
||||||
Puppet::Type::Quantum_network.new(net_attrs)
|
Puppet::Type::Neutron_network.new(net_attrs)
|
||||||
end
|
end
|
||||||
|
|
||||||
let :provider do
|
let :provider do
|
||||||
@ -31,21 +31,21 @@ describe provider_class do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should call net-update to change admin_state_up' do
|
it 'should call net-update to change admin_state_up' do
|
||||||
provider.expects(:auth_quantum).with('net-update',
|
provider.expects(:auth_neutron).with('net-update',
|
||||||
'--admin_state_up=False',
|
'--admin_state_up=False',
|
||||||
net_name)
|
net_name)
|
||||||
provider.admin_state_up=('False')
|
provider.admin_state_up=('False')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should call net-update to change shared' do
|
it 'should call net-update to change shared' do
|
||||||
provider.expects(:auth_quantum).with('net-update',
|
provider.expects(:auth_neutron).with('net-update',
|
||||||
'--shared=True',
|
'--shared=True',
|
||||||
net_name)
|
net_name)
|
||||||
provider.shared=('True')
|
provider.shared=('True')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should call net-update to change router_external' do
|
it 'should call net-update to change router_external' do
|
||||||
provider.expects(:auth_quantum).with('net-update',
|
provider.expects(:auth_neutron).with('net-update',
|
||||||
'--router:external=True',
|
'--router:external=True',
|
||||||
net_name)
|
net_name)
|
||||||
provider.router_external=('True')
|
provider.router_external=('True')
|
@ -1,8 +1,8 @@
|
|||||||
require 'puppet'
|
require 'puppet'
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
require 'puppet/provider/quantum_router/quantum'
|
require 'puppet/provider/neutron_router/neutron'
|
||||||
|
|
||||||
provider_class = Puppet::Type.type(:quantum_router).provider(:quantum)
|
provider_class = Puppet::Type.type(:neutron_router).provider(:neutron)
|
||||||
|
|
||||||
describe provider_class do
|
describe provider_class do
|
||||||
|
|
||||||
@ -21,7 +21,7 @@ describe provider_class do
|
|||||||
|
|
||||||
describe 'when updating a router' do
|
describe 'when updating a router' do
|
||||||
let :resource do
|
let :resource do
|
||||||
Puppet::Type::Quantum_router.new(router_attrs)
|
Puppet::Type::Neutron_router.new(router_attrs)
|
||||||
end
|
end
|
||||||
|
|
||||||
let :provider do
|
let :provider do
|
||||||
@ -29,20 +29,20 @@ describe provider_class do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should call router-update to change admin_state_up' do
|
it 'should call router-update to change admin_state_up' do
|
||||||
provider.expects(:auth_quantum).with('router-update',
|
provider.expects(:auth_neutron).with('router-update',
|
||||||
'--admin-state-up=False',
|
'--admin-state-up=False',
|
||||||
router_name)
|
router_name)
|
||||||
provider.admin_state_up=('False')
|
provider.admin_state_up=('False')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should call router-gateway-clear for an empty network name' do
|
it 'should call router-gateway-clear for an empty network name' do
|
||||||
provider.expects(:auth_quantum).with('router-gateway-clear',
|
provider.expects(:auth_neutron).with('router-gateway-clear',
|
||||||
router_name)
|
router_name)
|
||||||
provider.gateway_network_name=('')
|
provider.gateway_network_name=('')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should call router-gateway-set to configure an external network' do
|
it 'should call router-gateway-set to configure an external network' do
|
||||||
provider.expects(:auth_quantum).with('router-gateway-set',
|
provider.expects(:auth_neutron).with('router-gateway-set',
|
||||||
router_name,
|
router_name,
|
||||||
'net1')
|
'net1')
|
||||||
provider.gateway_network_name=('net1')
|
provider.gateway_network_name=('net1')
|
@ -1,9 +1,9 @@
|
|||||||
require 'puppet'
|
require 'puppet'
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
require 'puppet/provider/quantum_router_interface/quantum'
|
require 'puppet/provider/neutron_router_interface/neutron'
|
||||||
|
|
||||||
provider_class = Puppet::Type.type(:quantum_router_interface).
|
provider_class = Puppet::Type.type(:neutron_router_interface).
|
||||||
provider(:quantum)
|
provider(:neutron)
|
||||||
|
|
||||||
describe provider_class do
|
describe provider_class do
|
||||||
|
|
||||||
@ -16,7 +16,7 @@ describe provider_class do
|
|||||||
|
|
||||||
describe 'when accessing attributes of an interface' do
|
describe 'when accessing attributes of an interface' do
|
||||||
let :resource do
|
let :resource do
|
||||||
Puppet::Type::Quantum_router_interface.new(interface_attrs)
|
Puppet::Type::Neutron_router_interface.new(interface_attrs)
|
||||||
end
|
end
|
||||||
|
|
||||||
let :provider do
|
let :provider do
|
@ -1,9 +1,9 @@
|
|||||||
require 'puppet'
|
require 'puppet'
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
require 'puppet/provider/quantum'
|
require 'puppet/provider/neutron'
|
||||||
require 'tempfile'
|
require 'tempfile'
|
||||||
|
|
||||||
describe Puppet::Provider::Quantum do
|
describe Puppet::Provider::Neutron do
|
||||||
|
|
||||||
def klass
|
def klass
|
||||||
described_class
|
described_class
|
||||||
@ -25,7 +25,7 @@ describe Puppet::Provider::Quantum do
|
|||||||
end
|
end
|
||||||
|
|
||||||
let :credential_error do
|
let :credential_error do
|
||||||
/Quantum types will not work/
|
/Neutron types will not work/
|
||||||
end
|
end
|
||||||
|
|
||||||
after :each do
|
after :each do
|
||||||
@ -36,37 +36,37 @@ describe Puppet::Provider::Quantum do
|
|||||||
|
|
||||||
it 'should fail if config is empty' do
|
it 'should fail if config is empty' do
|
||||||
conf = {}
|
conf = {}
|
||||||
klass.expects(:quantum_conf).returns(conf)
|
klass.expects(:neutron_conf).returns(conf)
|
||||||
expect do
|
expect do
|
||||||
klass.quantum_credentials
|
klass.neutron_credentials
|
||||||
end.to raise_error(Puppet::Error, credential_error)
|
end.to raise_error(Puppet::Error, credential_error)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should fail if config does not have keystone_authtoken section.' do
|
it 'should fail if config does not have keystone_authtoken section.' do
|
||||||
conf = {'foo' => 'bar'}
|
conf = {'foo' => 'bar'}
|
||||||
klass.expects(:quantum_conf).returns(conf)
|
klass.expects(:neutron_conf).returns(conf)
|
||||||
expect do
|
expect do
|
||||||
klass.quantum_credentials
|
klass.neutron_credentials
|
||||||
end.to raise_error(Puppet::Error, credential_error)
|
end.to raise_error(Puppet::Error, credential_error)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should fail if config does not contain all auth params' do
|
it 'should fail if config does not contain all auth params' do
|
||||||
conf = {'keystone_authtoken' => {'invalid_value' => 'foo'}}
|
conf = {'keystone_authtoken' => {'invalid_value' => 'foo'}}
|
||||||
klass.expects(:quantum_conf).returns(conf)
|
klass.expects(:neutron_conf).returns(conf)
|
||||||
expect do
|
expect do
|
||||||
klass.quantum_credentials
|
klass.neutron_credentials
|
||||||
end.to raise_error(Puppet::Error, credential_error)
|
end.to raise_error(Puppet::Error, credential_error)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should use specified host/port/protocol in the auth endpoint' do
|
it 'should use specified host/port/protocol in the auth endpoint' do
|
||||||
conf = {'keystone_authtoken' => credential_hash}
|
conf = {'keystone_authtoken' => credential_hash}
|
||||||
klass.expects(:quantum_conf).returns(conf)
|
klass.expects(:neutron_conf).returns(conf)
|
||||||
klass.get_auth_endpoint.should == auth_endpoint
|
klass.get_auth_endpoint.should == auth_endpoint
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'when invoking the quantum cli' do
|
describe 'when invoking the neutron cli' do
|
||||||
|
|
||||||
it 'should set auth credentials in the environment' do
|
it 'should set auth credentials in the environment' do
|
||||||
authenv = {
|
authenv = {
|
||||||
@ -75,25 +75,25 @@ describe Puppet::Provider::Quantum do
|
|||||||
:OS_TENANT_NAME => credential_hash['admin_tenant_name'],
|
:OS_TENANT_NAME => credential_hash['admin_tenant_name'],
|
||||||
:OS_PASSWORD => credential_hash['admin_password'],
|
:OS_PASSWORD => credential_hash['admin_password'],
|
||||||
}
|
}
|
||||||
klass.expects(:get_quantum_credentials).with().returns(credential_hash)
|
klass.expects(:get_neutron_credentials).with().returns(credential_hash)
|
||||||
klass.expects(:withenv).with(authenv)
|
klass.expects(:withenv).with(authenv)
|
||||||
klass.auth_quantum('test_retries')
|
klass.auth_neutron('test_retries')
|
||||||
end
|
end
|
||||||
|
|
||||||
['[Errno 111] Connection refused',
|
['[Errno 111] Connection refused',
|
||||||
'(HTTP 400)'].reverse.each do |valid_message|
|
'(HTTP 400)'].reverse.each do |valid_message|
|
||||||
it "should retry when quantum cli returns with error #{valid_message}" do
|
it "should retry when neutron cli returns with error #{valid_message}" do
|
||||||
klass.expects(:get_quantum_credentials).with().returns({})
|
klass.expects(:get_neutron_credentials).with().returns({})
|
||||||
klass.expects(:sleep).with(10).returns(nil)
|
klass.expects(:sleep).with(10).returns(nil)
|
||||||
klass.expects(:quantum).twice.with(['test_retries']).raises(
|
klass.expects(:neutron).twice.with(['test_retries']).raises(
|
||||||
Exception, valid_message).then.returns('')
|
Exception, valid_message).then.returns('')
|
||||||
klass.auth_quantum('test_retries')
|
klass.auth_neutron('test_retries')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'when listing quantum resources' do
|
describe 'when listing neutron resources' do
|
||||||
|
|
||||||
it 'should exclude the column header' do
|
it 'should exclude the column header' do
|
||||||
output = <<-EOT
|
output = <<-EOT
|
||||||
@ -101,18 +101,18 @@ describe Puppet::Provider::Quantum do
|
|||||||
net1
|
net1
|
||||||
net2
|
net2
|
||||||
EOT
|
EOT
|
||||||
klass.expects(:auth_quantum).returns(output)
|
klass.expects(:auth_neutron).returns(output)
|
||||||
result = klass.list_quantum_resources('foo')
|
result = klass.list_neutron_resources('foo')
|
||||||
result.should eql(['net1', 'net2'])
|
result.should eql(['net1', 'net2'])
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'when retrieving attributes for quantum resources' do
|
describe 'when retrieving attributes for neutron resources' do
|
||||||
|
|
||||||
it 'should parse single-valued attributes into a key-value pair' do
|
it 'should parse single-valued attributes into a key-value pair' do
|
||||||
klass.expects(:auth_quantum).returns('admin_state_up="True"')
|
klass.expects(:auth_neutron).returns('admin_state_up="True"')
|
||||||
result = klass.get_quantum_resource_attrs('foo', 'id')
|
result = klass.get_neutron_resource_attrs('foo', 'id')
|
||||||
result.should eql({"admin_state_up" => 'True'})
|
result.should eql({"admin_state_up" => 'True'})
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -121,8 +121,8 @@ describe Puppet::Provider::Quantum do
|
|||||||
subnets="subnet1
|
subnets="subnet1
|
||||||
subnet2"
|
subnet2"
|
||||||
EOT
|
EOT
|
||||||
klass.expects(:auth_quantum).returns(output)
|
klass.expects(:auth_neutron).returns(output)
|
||||||
result = klass.get_quantum_resource_attrs('foo', 'id')
|
result = klass.get_neutron_resource_attrs('foo', 'id')
|
||||||
result.should eql({"subnets" => ['subnet1', 'subnet2']})
|
result.should eql({"subnets" => ['subnet1', 'subnet2']})
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -135,7 +135,7 @@ subnet2"
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should handle an empty port list' do
|
it 'should handle an empty port list' do
|
||||||
klass.expects(:auth_quantum).with('router-port-list',
|
klass.expects(:auth_neutron).with('router-port-list',
|
||||||
'--format=csv',
|
'--format=csv',
|
||||||
router)
|
router)
|
||||||
result = klass.list_router_ports(router)
|
result = klass.list_router_ports(router)
|
||||||
@ -163,7 +163,7 @@ subnet2"
|
|||||||
"subnet_id"=>"e4db0abd-276a-4f69-92ea-8b9e4eacfd43",
|
"subnet_id"=>"e4db0abd-276a-4f69-92ea-8b9e4eacfd43",
|
||||||
"id"=>"de0dc526-02b2-467c-9832-2c3dc69ac2b4",
|
"id"=>"de0dc526-02b2-467c-9832-2c3dc69ac2b4",
|
||||||
"mac_address"=>"fa:16:3e:f6:b5:72"}]
|
"mac_address"=>"fa:16:3e:f6:b5:72"}]
|
||||||
klass.expects(:auth_quantum).
|
klass.expects(:auth_neutron).
|
||||||
with('router-port-list', '--format=csv', router).
|
with('router-port-list', '--format=csv', router).
|
||||||
returns(output)
|
returns(output)
|
||||||
result = klass.list_router_ports(router)
|
result = klass.list_router_ports(router)
|
@ -1,8 +1,8 @@
|
|||||||
require 'puppet'
|
require 'puppet'
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
require 'puppet/provider/quantum_subnet/quantum'
|
require 'puppet/provider/neutron_subnet/neutron'
|
||||||
|
|
||||||
provider_class = Puppet::Type.type(:quantum_subnet).provider(:quantum)
|
provider_class = Puppet::Type.type(:neutron_subnet).provider(:neutron)
|
||||||
|
|
||||||
describe provider_class do
|
describe provider_class do
|
||||||
|
|
||||||
@ -25,7 +25,7 @@ describe provider_class do
|
|||||||
|
|
||||||
describe 'when updating a subnet' do
|
describe 'when updating a subnet' do
|
||||||
let :resource do
|
let :resource do
|
||||||
Puppet::Type::Quantum_subnet.new(subnet_attrs)
|
Puppet::Type::Neutron_subnet.new(subnet_attrs)
|
||||||
end
|
end
|
||||||
|
|
||||||
let :provider do
|
let :provider do
|
||||||
@ -33,14 +33,14 @@ describe provider_class do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'should call subnet-update to change gateway_ip' do
|
it 'should call subnet-update to change gateway_ip' do
|
||||||
provider.expects(:auth_quantum).with('subnet-update',
|
provider.expects(:auth_neutron).with('subnet-update',
|
||||||
'--gateway-ip=10.0.0.2',
|
'--gateway-ip=10.0.0.2',
|
||||||
subnet_name)
|
subnet_name)
|
||||||
provider.gateway_ip=('10.0.0.2')
|
provider.gateway_ip=('10.0.0.2')
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should call subnet-update to change enable_dhcp' do
|
it 'should call subnet-update to change enable_dhcp' do
|
||||||
provider.expects(:auth_quantum).with('subnet-update',
|
provider.expects(:auth_neutron).with('subnet-update',
|
||||||
'--enable-dhcp=True',
|
'--enable-dhcp=True',
|
||||||
subnet_name)
|
subnet_name)
|
||||||
provider.enable_dhcp=('True')
|
provider.enable_dhcp=('True')
|
Loading…
x
Reference in New Issue
Block a user