puppet-openstack-integration/fixtures/scenario003.pp
Lee Yarwood 39de59e91a placement: Use puppet-placement to deploy an extracted service
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
2019-02-27 13:31:26 +00:00

122 lines
3.6 KiB
Puppet

#
# Copyright 2015 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
}
case $::osfamily {
'Debian': {
$ipv6 = false
# mistral is not packaged on Ubuntu Trusty
$mistral_enabled = false
# murano package should be fixed on Ubuntu Xenial
$murano_enabled = false
# trove package contains broken Tempest tests
$trove = false
}
'RedHat': {
$ipv6 = true
$mistral_enabled = true
# NOTE(mnaser): We need to figure out why Murano won't accept credentials
# and how to get it to work with Keystone V3.
$murano_enabled = false
$trove_enabled = true
}
default: {
fail("Unsupported osfamily (${::osfamily})")
}
}
if ($::operatingsystem == 'Ubuntu') and (versioncmp($::operatingsystemmajrelease, '16') >= 0) {
# Disable Designate MDS on Ubuntu until we find why Puppet run is not
# idempotent sometimes.
$designate_enabled = false
} else {
$designate_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
include ::openstack_integration::glance
class { '::openstack_integration::neutron':
driver => 'linuxbridge',
}
include ::openstack_integration::placement
include ::openstack_integration::nova
if $trove_enabled {
include ::openstack_integration::trove
}
include ::openstack_integration::horizon
include ::openstack_integration::heat
include ::openstack_integration::sahara
if $designate_enabled {
include ::openstack_integration::designate
}
if $murano_enabled {
include ::openstack_integration::murano
}
if $mistral_enabled {
include ::openstack_integration::mistral
}
include ::openstack_integration::provision
class { '::openstack_integration::tempest':
designate => $designate_enabled,
trove => $trove_enabled,
mistral => $mistral_enabled,
sahara => true,
horizon => true,
murano => $murano_enabled,
heat => true,
}