39de59e91a
This change introduces an extracted placement class capable of deploying the service using puppet-placement ahead of the official extraction of the service from Nova in Train. scenario001 continues to deploy Placement using the now deprecated puppet-nova classes ahead of their removal in Train. Change-Id: I5260b4d3478008a76fbe53fdbb716004d11b22df
110 lines
3.4 KiB
Puppet
110 lines
3.4 KiB
Puppet
#
|
|
# Copyright 2016 Red Hat, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
|
|
if ($::os['family'] == 'Debian') {
|
|
$wsgi_mod_package = 'libapache2-mod-wsgi-py3'
|
|
$wsgi_mod_lib = 'mod_wsgi.so'
|
|
}
|
|
elsif ($::os['name'] == 'Fedora') or
|
|
($::os['family'] == 'RedHat' and Integer.new($::os['release']['major']) > 7) {
|
|
$wsgi_mod_package = 'python3-mod_wsgi'
|
|
$wsgi_mod_lib = 'mod_wsgi_python3.so'
|
|
}
|
|
if ($::os['family'] == 'Debian') or ($::os['name'] == 'Fedora') or
|
|
($::os['family'] == 'RedHat' and Integer.new($::os['release']['major']) > 7) {
|
|
include ::apache::params
|
|
class { '::apache':
|
|
mod_packages => merge($::apache::params::mod_packages, {
|
|
'wsgi' => $wsgi_mod_package,
|
|
}),
|
|
mod_libs => merge($::apache::params::mod_libs, {
|
|
'wsgi' => $wsgi_mod_lib,
|
|
})
|
|
}
|
|
}
|
|
|
|
if ($::os['name'] == 'Ubuntu') or ($::os['name'] == 'Fedora') or
|
|
($::os['family'] == 'RedHat' and Integer.new($::os['release']['major']) > 7) {
|
|
# FIXME(ykarel) Disable SSL until services are ready to work with SSL + Python3
|
|
$ssl = false
|
|
} else {
|
|
$ssl = true
|
|
}
|
|
|
|
if $::operatingsystem == 'Ubuntu' {
|
|
$ipv6 = false
|
|
# Watcher packages are not available in Ubuntu repository.
|
|
$watcher_enabled = false
|
|
# TODO(tobasco): No service plugin 'BGPVPN'
|
|
$bgpvpn_enabled = false
|
|
# TODO(tobasco): Plugin 'networking_l2gw.services.l2gateway.plugin.L2GatewayPlugin' not found.
|
|
$l2gw_enabled = false
|
|
# FIXME(ykarel) Disable bgp_dragent until Ubuntu python3 stein(with stein packages) jobs are ready
|
|
$bgp_dragent_enabled = false
|
|
} else {
|
|
$ipv6 = true
|
|
$watcher_enabled = true
|
|
$bgpvpn_enabled = true
|
|
$l2gw_enabled = true
|
|
$bgp_dragent_enabled = true
|
|
}
|
|
|
|
include ::openstack_integration
|
|
class { '::openstack_integration::config':
|
|
ssl => $ssl,
|
|
ipv6 => $ipv6,
|
|
}
|
|
|
|
if $ssl {
|
|
include ::openstack_integration::cacert
|
|
}
|
|
include ::openstack_integration::memcached
|
|
include ::openstack_integration::rabbitmq
|
|
include ::openstack_integration::mysql
|
|
include ::openstack_integration::keystone
|
|
class { '::openstack_integration::glance':
|
|
backend => 'swift',
|
|
}
|
|
class { '::openstack_integration::neutron':
|
|
bgpvpn_enabled => $bgpvpn_enabled,
|
|
l2gw_enabled => $l2gw_enabled,
|
|
bgp_dragent_enabled => $bgp_dragent_enabled,
|
|
}
|
|
include ::openstack_integration::placement
|
|
class { '::openstack_integration::nova':
|
|
libvirt_rbd => true,
|
|
}
|
|
|
|
class { '::openstack_integration::ceph':
|
|
deploy_rgw => true,
|
|
swift_dropin => true,
|
|
}
|
|
if $watcher_enabled {
|
|
include ::openstack_integration::watcher
|
|
}
|
|
|
|
include ::openstack_integration::provision
|
|
|
|
# Don't test swift, radosgw won't pass the current tests
|
|
# Glance, nova, neutron are true by default.
|
|
class { '::openstack_integration::tempest':
|
|
watcher => $watcher_enabled,
|
|
bgpvpn => $bgpvpn_enabled,
|
|
l2gw => $l2gw_enabled,
|
|
l2gw_switch => 'cell08-5930-01::FortyGigE1/0/1|100',
|
|
dr => $bgp_dragent_enabled,
|
|
}
|