Merge lp:~moon127/charms/precise/mongodb/add-execd-for-basenode into lp:charms/mongodb

Proposed by Gareth Woolridge
Status: Merged
Merged at revision: 51
Proposed branch: lp:~moon127/charms/precise/mongodb/add-execd-for-basenode
Merge into: lp:charms/mongodb
Diff against target: 109 lines (+58/-1)
5 files modified
.bzrignore (+1/-0)
charm-helpers-sync.yaml (+1/-0)
hooks/charmhelpers/payload/__init__.py (+1/-0)
hooks/charmhelpers/payload/execd.py (+50/-0)
hooks/hooks.py (+5/-1)
To merge this branch: bzr merge lp:~moon127/charms/precise/mongodb/add-execd-for-basenode
Reviewer Review Type Date Requested Status
Tom Haddon Approve
Review via email: mp+231757@code.launchpad.net

Description of the change

Add exec.d charm preinstall support from charmhelpers for basenode.

To post a comment you must log in.
Revision history for this message
Tom Haddon (mthaddon) wrote :

Looks good and works in my test environment. Will merge.

review: Approve

Preview Diff

[H/L] Next/Prev Comment, [J/K] Next/Prev File, [N/P] Next/Prev Hunk
1=== modified file '.bzrignore'
2--- .bzrignore 2014-07-10 18:38:27 +0000
3+++ .bzrignore 2014-08-21 15:23:35 +0000
4@@ -1,3 +1,4 @@
5 .git
6 bin/*
7 scripts/charm-helpers-sync.py
8+exec.d/*
9
10=== modified file 'charm-helpers-sync.yaml'
11--- charm-helpers-sync.yaml 2014-04-11 20:55:42 +0000
12+++ charm-helpers-sync.yaml 2014-08-21 15:23:35 +0000
13@@ -3,3 +3,4 @@
14 include:
15 - core
16 - fetch
17+ - payload.execd
18
19=== added directory 'exec.d'
20=== added directory 'hooks/charmhelpers/payload'
21=== added file 'hooks/charmhelpers/payload/__init__.py'
22--- hooks/charmhelpers/payload/__init__.py 1970-01-01 00:00:00 +0000
23+++ hooks/charmhelpers/payload/__init__.py 2014-08-21 15:23:35 +0000
24@@ -0,0 +1,1 @@
25+"Tools for working with files injected into a charm just before deployment."
26
27=== added file 'hooks/charmhelpers/payload/execd.py'
28--- hooks/charmhelpers/payload/execd.py 1970-01-01 00:00:00 +0000
29+++ hooks/charmhelpers/payload/execd.py 2014-08-21 15:23:35 +0000
30@@ -0,0 +1,50 @@
31+#!/usr/bin/env python
32+
33+import os
34+import sys
35+import subprocess
36+from charmhelpers.core import hookenv
37+
38+
39+def default_execd_dir():
40+ return os.path.join(os.environ['CHARM_DIR'], 'exec.d')
41+
42+
43+def execd_module_paths(execd_dir=None):
44+ """Generate a list of full paths to modules within execd_dir."""
45+ if not execd_dir:
46+ execd_dir = default_execd_dir()
47+
48+ if not os.path.exists(execd_dir):
49+ return
50+
51+ for subpath in os.listdir(execd_dir):
52+ module = os.path.join(execd_dir, subpath)
53+ if os.path.isdir(module):
54+ yield module
55+
56+
57+def execd_submodule_paths(command, execd_dir=None):
58+ """Generate a list of full paths to the specified command within exec_dir.
59+ """
60+ for module_path in execd_module_paths(execd_dir):
61+ path = os.path.join(module_path, command)
62+ if os.access(path, os.X_OK) and os.path.isfile(path):
63+ yield path
64+
65+
66+def execd_run(command, execd_dir=None, die_on_error=False, stderr=None):
67+ """Run command for each module within execd_dir which defines it."""
68+ for submodule_path in execd_submodule_paths(command, execd_dir):
69+ try:
70+ subprocess.check_call(submodule_path, shell=True, stderr=stderr)
71+ except subprocess.CalledProcessError as e:
72+ hookenv.log("Error ({}) running {}. Output: {}".format(
73+ e.returncode, e.cmd, e.output))
74+ if die_on_error:
75+ sys.exit(e.returncode)
76+
77+
78+def execd_preinstall(execd_dir=None):
79+ """Run charm-pre-install for each module within execd_dir."""
80+ execd_run('charm-pre-install', execd_dir=execd_dir)
81
82=== modified file 'hooks/hooks.py'
83--- hooks/hooks.py 2014-07-30 15:39:55 +0000
84+++ hooks/hooks.py 2014-08-21 15:23:35 +0000
85@@ -43,6 +43,8 @@
86
87 from charmhelpers.core.hookenv import log as juju_log
88
89+from charmhelpers.payload.execd import execd_preinstall
90+
91 from charmhelpers.core.host import (
92 service,
93 )
94@@ -724,6 +726,8 @@
95 ###############################################################################
96 @hooks.hook('install')
97 def install_hook():
98+ juju_log('Begin install hook.')
99+ execd_preinstall()
100 juju_log("Installing mongodb")
101 add_source(config('source'), config('key'))
102 apt_update(fatal=True)
103@@ -1369,4 +1373,4 @@
104 ###############################################################################
105 if __name__ == "__main__":
106 # execute a hook based on the name the program is called by
107- hooks.execute(sys.argv)
108\ No newline at end of file
109+ hooks.execute(sys.argv)

Subscribers

People subscribed via source and target branches