Add preinstall hook and create charm-helpers.yaml to pull in additional charmhelpers module to support it

This commit is contained in:
Juju Management User 2013-11-12 16:28:10 +00:00
parent 8f7a04e4c4
commit b0113d7b6e
6 changed files with 60 additions and 1 deletions

5
charm-helpers.yaml Normal file
View File

@ -0,0 +1,5 @@
branch: lp:charm-helpers
destination: hooks/charmhelpers
include:
- core
- payload.execd

View File

View File

@ -0,0 +1 @@
"Tools for working with files injected into a charm just before deployment."

View File

@ -0,0 +1,50 @@
#!/usr/bin/env python
import os
import sys
import subprocess
from charmhelpers.core import hookenv
def default_execd_dir():
return os.path.join(os.environ['CHARM_DIR'], 'exec.d')
def execd_module_paths(execd_dir=None):
"""Generate a list of full paths to modules within execd_dir."""
if not execd_dir:
execd_dir = default_execd_dir()
if not os.path.exists(execd_dir):
return
for subpath in os.listdir(execd_dir):
module = os.path.join(execd_dir, subpath)
if os.path.isdir(module):
yield module
def execd_submodule_paths(command, execd_dir=None):
"""Generate a list of full paths to the specified command within exec_dir.
"""
for module_path in execd_module_paths(execd_dir):
path = os.path.join(module_path, command)
if os.access(path, os.X_OK) and os.path.isfile(path):
yield path
def execd_run(command, execd_dir=None, die_on_error=False, stderr=None):
"""Run command for each module within execd_dir which defines it."""
for submodule_path in execd_submodule_paths(command, execd_dir):
try:
subprocess.check_call(submodule_path, shell=True, stderr=stderr)
except subprocess.CalledProcessError as e:
hookenv.log("Error ({}) running {}. Output: {}".format(
e.returncode, e.cmd, e.output))
if die_on_error:
sys.exit(e.returncode)
def execd_preinstall(execd_dir=None):
"""Run charm-pre-install for each module within execd_dir."""
execd_run('charm-pre-install', execd_dir=execd_dir)

View File

@ -41,6 +41,8 @@ import lib.utils as utils
import lib.cluster_utils as cluster
import lib.haproxy_utils as haproxy
from charmhelpers.payload.execd import execd_preinstall
config = config_get()
packages = [
@ -98,6 +100,7 @@ valid_services = {
def install_hook():
execd_preinstall()
utils.configure_source()
utils.install(*packages)
update_config_block('DEFAULT',

View File

@ -1 +1 @@
225
226