2012-03-16 13:11:15 -07:00
|
|
|
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
|
|
|
|
# Copyright (C) 2012 Yahoo! Inc. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
|
|
|
import yaml
|
|
|
|
|
2012-03-16 15:00:43 -07:00
|
|
|
from devstack import decorators
|
2012-03-16 13:11:15 -07:00
|
|
|
from devstack import exceptions as excp
|
|
|
|
from devstack import log as logging
|
|
|
|
from devstack import shell as sh
|
|
|
|
|
|
|
|
LOG = logging.getLogger("devstack.persona")
|
|
|
|
|
|
|
|
|
|
|
|
class Persona(object):
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def load_file(cls, fn):
|
|
|
|
persona_fn = sh.abspth(fn)
|
|
|
|
LOG.audit("Loading persona from file [%s]", persona_fn)
|
2012-03-16 13:38:15 -07:00
|
|
|
cls_kvs = None
|
2012-03-16 13:11:15 -07:00
|
|
|
try:
|
|
|
|
with open(persona_fn, "r") as fh:
|
|
|
|
cls_kvs = yaml.load(fh.read())
|
|
|
|
except (IOError, yaml.YAMLError) as err:
|
|
|
|
LOG.warning('Could not load persona definition from %s: %s',
|
|
|
|
persona_fn, err)
|
|
|
|
instance = None
|
2012-03-16 13:38:15 -07:00
|
|
|
if cls_kvs is not None:
|
|
|
|
try:
|
|
|
|
cls_kvs['source'] = persona_fn
|
|
|
|
instance = cls(**cls_kvs)
|
|
|
|
except Exception as err:
|
|
|
|
LOG.warning('Could not initialize instance %s using parameter map %s: %s',
|
|
|
|
cls, cls_kvs, err)
|
2012-03-16 13:11:15 -07:00
|
|
|
return instance
|
|
|
|
|
2012-03-16 15:00:43 -07:00
|
|
|
@decorators.log_debug
|
2012-03-16 13:11:15 -07:00
|
|
|
def __init__(self, description,
|
|
|
|
supports,
|
|
|
|
components,
|
|
|
|
subsystems,
|
|
|
|
options,
|
|
|
|
**kargs):
|
|
|
|
self.distro_support = supports
|
|
|
|
self.wanted_components = components
|
|
|
|
self.source = kargs.get('source') # May not always be there (ie if from a stream...)
|
|
|
|
self.wanted_subsystems = subsystems
|
|
|
|
self.description = description
|
|
|
|
self.component_options = options
|
|
|
|
|
2012-03-16 13:38:15 -07:00
|
|
|
def __str__(self):
|
2012-03-16 13:11:15 -07:00
|
|
|
info = "%s" % (self.description)
|
|
|
|
if self.source:
|
|
|
|
info += " from source %s:" % (self.source)
|
|
|
|
if self.wanted_subsystems:
|
|
|
|
info += " with desired subsystems (%s)" % (self.wanted_subsystems)
|
|
|
|
if self.wanted_components:
|
|
|
|
info += " with desired components (%s)" % (", ".join(self.wanted_components))
|
|
|
|
if self.component_options:
|
|
|
|
info += " with desired component options (%s)" % (", ".join(self.component_options))
|
|
|
|
if self.distro_support:
|
|
|
|
info += " which 'should' work on distros (%s)" % (", ".join(self.distro_support))
|
|
|
|
return info
|
|
|
|
|
|
|
|
def verify(self, distro):
|
|
|
|
# Some sanity checks against the given distro
|
|
|
|
d_name = distro.name
|
|
|
|
if d_name not in self.distro_support:
|
2012-03-16 16:51:10 -07:00
|
|
|
msg = "Distro %r not supported" % (d_name)
|
2012-03-16 13:11:15 -07:00
|
|
|
raise excp.ConfigException(msg)
|
|
|
|
for c in self.wanted_components:
|
|
|
|
if not distro.known_component(c):
|
2012-03-16 16:51:10 -07:00
|
|
|
raise RuntimeError("Distro %r does not support component %r" %
|
2012-03-16 13:11:15 -07:00
|
|
|
(d_name, c))
|