Commit 023f86d5 authored by Lisa Casino's avatar Lisa Casino

recipe/switch_softwaretype: add log

parent 9635c705
...@@ -25,9 +25,8 @@ ...@@ -25,9 +25,8 @@
# #
############################################################################## ##############################################################################
from zc.buildout.buildout import Buildout from zc.buildout.buildout import Buildout
from zc.buildout import UserError
class SubBuildout(Buildout): class SubBuildout(Buildout):
"""Run buildout in buildout, partially copied from infrae.buildout """Run buildout in buildout, partially copied from infrae.buildout
...@@ -52,6 +51,8 @@ class SubBuildout(Buildout): ...@@ -52,6 +51,8 @@ class SubBuildout(Buildout):
opt, opt,
main_buildout['buildout'][opt], main_buildout['buildout'][opt],
)) ))
if not ("slap-connection" in main_buildout):
raise UserError("You should use slap-connection in the section [slap-configuration].")
# Use same slap connection # Use same slap connection
for k, v in main_buildout["slap-connection"].items(): for k, v in main_buildout["slap-connection"].items():
options.append(('slap-connection', k, v)) options.append(('slap-connection', k, v))
...@@ -71,8 +72,26 @@ class Recipe: ...@@ -71,8 +72,26 @@ class Recipe:
self.buildout = buildout self.buildout = buildout
self.options = options self.options = options
self.name = name self.name = name
if not ("slap-configuration" in self.buildout) or not ("slap-software-type" in buildout["slap-configuration"]):
raise UserError("You should have a section [slap-configuration] with " \
"this recipe: slapos.cookbook:slapconfiguration.")
self.software_type = buildout["slap-configuration"]["slap-software-type"] self.software_type = buildout["slap-configuration"]["slap-software-type"]
if self.software_type not in self.options:
raise UserError("This software type (%s) isn't mapped. RootSoftwareInstance " \
"is the default software type." % self.software_type)
try:
section, key = self.options[self.software_type].split(":") section, key = self.options[self.software_type].split(":")
except:
raise UserError("The softwares types in the section [%s] must be separate " \
"by a colon such as: 'section:key', where key is usually 'rendered'. " \
"Don't use: ${section:key}" % self.name)
if not (section in self.buildout):
raise UserError("The section %s can't be found in the file." % section)
elif not (key in buildout[section]):
raise UserError("The key %s can't be found in the section %s." % (key, section))
self.base = self.buildout[section][key] self.base = self.buildout[section][key]
def install(self): def install(self):
......
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
[template-cfg] [template-cfg]
filename = instance.cfg.in filename = instance.cfg.in
md5sum = caf9bd63a7d92b2af18b200611e42221 md5sum = c9d39e620b6a8ff59e959a6c277b3def
[instance_html5as] [instance_html5as]
_update_hash_filename_ = instance_html5as.cfg.in _update_hash_filename_ = instance_html5as.cfg.in
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment