puppet-openstack-integration/fixtures/scenario004.pp

106 lines
3.2 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 $facts['os']['name'] == 'Ubuntu' {
$ssl = false
} else {
$ssl = true
}
if $facts['os']['name'] == 'Ubuntu' {
$ipv6 = false
# TODO(tobias-urdin): No service plugin 'BGPVPN'
$bgpvpn_enabled = false
# TODO(tobias-urdin): 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
# TODO(tkajinam): Enable these along with the other plugins
$vpnaas_enabled = false
$taas_enabled = false
} else {
$ipv6 = true
$bgpvpn_enabled = true
$l2gw_enabled = true
$bgp_dragent_enabled = true
$vpnaas_enabled = true
$taas_enabled = true
}
include openstack_integration
class { 'openstack_integration::config':
ssl => $ssl,
ipv6 => $ipv6,
}
if $ssl {
include openstack_integration::cacert
}
include openstack_integration::apache
include openstack_integration::memcached
include openstack_integration::rabbitmq
include openstack_integration::mysql
include openstack_integration::redis
include openstack_integration::keystone
class { 'openstack_integration::glance':
backend => 'swift',
}
class { 'openstack_integration::neutron':
vpnaas_enabled => $vpnaas_enabled,
taas_enabled => $taas_enabled,
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,
create_cephfs => true,
ceph_pools => ['glance', 'nova'],
}
class { 'openstack_integration::horizon':
octavia_enabled => true
}
include openstack_integration::watcher
class { 'openstack_integration::manila':
backend => 'cephfsnative'
}
include openstack_integration::octavia
include openstack_integration::provision
# Glance, nova, neutron are true by default.
class { 'openstack_integration::tempest':
horizon => true,
watcher => true,
vpnaas => $vpnaas_enabled,
taas => $taas_enabled,
bgpvpn => $bgpvpn_enabled,
l2gw => $l2gw_enabled,
l2gw_switch => 'cell08-5930-01::FortyGigE1/0/1|100',
dr => $bgp_dragent_enabled,
manila => true,
share_protocol => 'CEPHFS',
octavia => true,
# RADOS Gateway does not support ResellerAdmin role by default
reseller_admin_role => 'admin',
swift => true,
}