Merge pull request #147 from harlowja/master
Let the log iterable function take a logger thus allowing callers to pass in there logger
This commit is contained in:
commit
fa1cca8b17
@ -180,7 +180,8 @@ class PkgInstallComponent(ComponentBase, PackageBasedComponentMixin):
|
|||||||
def download(self):
|
def download(self):
|
||||||
download_locs = self._get_real_download_locations()
|
download_locs = self._get_real_download_locations()
|
||||||
uris = [loc['uri'] for loc in download_locs]
|
uris = [loc['uri'] for loc in download_locs]
|
||||||
utils.log_iterable(uris, header="Downloading from %s uris" % (len(uris)))
|
utils.log_iterable(uris, logger=LOG,
|
||||||
|
header="Downloading from %s uris" % (len(uris)))
|
||||||
for info in download_locs:
|
for info in download_locs:
|
||||||
# Extract da download!
|
# Extract da download!
|
||||||
uri = info['uri']
|
uri = info['uri']
|
||||||
@ -228,7 +229,8 @@ class PkgInstallComponent(ComponentBase, PackageBasedComponentMixin):
|
|||||||
pkgs = self._get_packages()
|
pkgs = self._get_packages()
|
||||||
if pkgs:
|
if pkgs:
|
||||||
pkg_names = set([p['name'] for p in pkgs])
|
pkg_names = set([p['name'] for p in pkgs])
|
||||||
utils.log_iterable(pkg_names, header="Setting up %s distribution packages" % (len(pkg_names)))
|
utils.log_iterable(pkg_names, logger=LOG,
|
||||||
|
header="Setting up %s distribution packages" % (len(pkg_names)))
|
||||||
with utils.progress_bar(INSTALL_TITLE, len(pkgs)) as p_bar:
|
with utils.progress_bar(INSTALL_TITLE, len(pkgs)) as p_bar:
|
||||||
for (i, p) in enumerate(pkgs):
|
for (i, p) in enumerate(pkgs):
|
||||||
self.tracewriter.package_installed(p)
|
self.tracewriter.package_installed(p)
|
||||||
@ -280,7 +282,8 @@ class PkgInstallComponent(ComponentBase, PackageBasedComponentMixin):
|
|||||||
def _configure_files(self):
|
def _configure_files(self):
|
||||||
config_fns = self._get_config_files()
|
config_fns = self._get_config_files()
|
||||||
if config_fns:
|
if config_fns:
|
||||||
utils.log_iterable(config_fns, header="Configuring %s files" % (len(config_fns)))
|
utils.log_iterable(config_fns, logger=LOG,
|
||||||
|
header="Configuring %s files" % (len(config_fns)))
|
||||||
for fn in config_fns:
|
for fn in config_fns:
|
||||||
parameters = self._get_param_map(fn)
|
parameters = self._get_param_map(fn)
|
||||||
tgt_fn = self._get_target_config_name(fn)
|
tgt_fn = self._get_target_config_name(fn)
|
||||||
@ -341,7 +344,8 @@ class PythonInstallComponent(PkgInstallComponent):
|
|||||||
pips = self._get_pips()
|
pips = self._get_pips()
|
||||||
if pips:
|
if pips:
|
||||||
pip_names = set([p['name'] for p in pips])
|
pip_names = set([p['name'] for p in pips])
|
||||||
utils.log_iterable(pip_names, header="Setting up %s python packages" % (len(pip_names)))
|
utils.log_iterable(pip_names, logger=LOG,
|
||||||
|
header="Setting up %s python packages" % (len(pip_names)))
|
||||||
with utils.progress_bar(INSTALL_TITLE, len(pips)) as p_bar:
|
with utils.progress_bar(INSTALL_TITLE, len(pips)) as p_bar:
|
||||||
for (i, p) in enumerate(pips):
|
for (i, p) in enumerate(pips):
|
||||||
self.tracewriter.pip_installed(p)
|
self.tracewriter.pip_installed(p)
|
||||||
@ -354,7 +358,8 @@ class PythonInstallComponent(PkgInstallComponent):
|
|||||||
real_dirs = dict()
|
real_dirs = dict()
|
||||||
for (name, wkdir) in py_dirs.items():
|
for (name, wkdir) in py_dirs.items():
|
||||||
real_dirs[name] = wkdir or self.app_dir
|
real_dirs[name] = wkdir or self.app_dir
|
||||||
utils.log_iterable(real_dirs.values(), header="Setting up %s python directories" % (len(real_dirs)))
|
utils.log_iterable(real_dirs.values(), logger=LOG,
|
||||||
|
header="Setting up %s python directories" % (len(real_dirs)))
|
||||||
for (name, working_dir) in real_dirs.items():
|
for (name, working_dir) in real_dirs.items():
|
||||||
self.tracewriter.dirs_made(*sh.mkdirslist(working_dir))
|
self.tracewriter.dirs_made(*sh.mkdirslist(working_dir))
|
||||||
self.tracewriter.py_installed(name, working_dir)
|
self.tracewriter.py_installed(name, working_dir)
|
||||||
@ -408,14 +413,16 @@ class PkgUninstallComponent(ComponentBase, PackageBasedComponentMixin):
|
|||||||
def _unconfigure_links(self):
|
def _unconfigure_links(self):
|
||||||
sym_files = self.tracereader.symlinks_made()
|
sym_files = self.tracereader.symlinks_made()
|
||||||
if sym_files:
|
if sym_files:
|
||||||
utils.log_iterable(sym_files, header="Removing %s symlink files" % (len(sym_files)))
|
utils.log_iterable(sym_files, logger=LOG,
|
||||||
|
header="Removing %s symlink files" % (len(sym_files)))
|
||||||
for fn in sym_files:
|
for fn in sym_files:
|
||||||
sh.unlink(fn, run_as_root=True)
|
sh.unlink(fn, run_as_root=True)
|
||||||
|
|
||||||
def _unconfigure_files(self):
|
def _unconfigure_files(self):
|
||||||
cfg_files = self.tracereader.files_configured()
|
cfg_files = self.tracereader.files_configured()
|
||||||
if cfg_files:
|
if cfg_files:
|
||||||
utils.log_iterable(cfg_files, header="Removing %s configuration files" % (len(cfg_files)))
|
utils.log_iterable(cfg_files, logger=LOG,
|
||||||
|
header="Removing %s configuration files" % (len(cfg_files)))
|
||||||
for fn in cfg_files:
|
for fn in cfg_files:
|
||||||
sh.unlink(fn, run_as_root=True)
|
sh.unlink(fn, run_as_root=True)
|
||||||
|
|
||||||
@ -445,12 +452,14 @@ class PkgUninstallComponent(ComponentBase, PackageBasedComponentMixin):
|
|||||||
if packager.remove(p):
|
if packager.remove(p):
|
||||||
which_removed.add(p['name'])
|
which_removed.add(p['name'])
|
||||||
p_bar.update(i + 1)
|
p_bar.update(i + 1)
|
||||||
utils.log_iterable(which_removed, header="Actually removed %s packages" % (len(which_removed)))
|
utils.log_iterable(which_removed, logger=LOG,
|
||||||
|
header="Actually removed %s packages" % (len(which_removed)))
|
||||||
|
|
||||||
def _uninstall_touched_files(self):
|
def _uninstall_touched_files(self):
|
||||||
files_touched = self.tracereader.files_touched()
|
files_touched = self.tracereader.files_touched()
|
||||||
if files_touched:
|
if files_touched:
|
||||||
utils.log_iterable(files_touched, header="Removing %s touched files" % (len(files_touched)))
|
utils.log_iterable(files_touched, logger=LOG,
|
||||||
|
header="Removing %s touched files" % (len(files_touched)))
|
||||||
for fn in files_touched:
|
for fn in files_touched:
|
||||||
sh.unlink(fn, run_as_root=True)
|
sh.unlink(fn, run_as_root=True)
|
||||||
|
|
||||||
@ -460,10 +469,12 @@ class PkgUninstallComponent(ComponentBase, PackageBasedComponentMixin):
|
|||||||
dirs_made = [sh.abspth(d) for d in dirs_made]
|
dirs_made = [sh.abspth(d) for d in dirs_made]
|
||||||
if self.keep_old:
|
if self.keep_old:
|
||||||
download_places = [path_location[0] for path_location in self.tracereader.download_locations()]
|
download_places = [path_location[0] for path_location in self.tracereader.download_locations()]
|
||||||
utils.log_iterable(download_places, header="Keeping %s download directories" % (len(download_places)))
|
utils.log_iterable(download_places, logger=LOG,
|
||||||
|
header="Keeping %s download directories" % (len(download_places)))
|
||||||
for download_place in download_places:
|
for download_place in download_places:
|
||||||
dirs_made = sh.remove_parents(download_place, dirs_made)
|
dirs_made = sh.remove_parents(download_place, dirs_made)
|
||||||
utils.log_iterable(dirs_made, header="Removing %s created directories" % (len(dirs_made)))
|
utils.log_iterable(dirs_made, logger=LOG,
|
||||||
|
header="Removing %s created directories" % (len(dirs_made)))
|
||||||
for dir_name in dirs_made:
|
for dir_name in dirs_made:
|
||||||
sh.deldir(dir_name, run_as_root=True)
|
sh.deldir(dir_name, run_as_root=True)
|
||||||
|
|
||||||
@ -481,7 +492,8 @@ class PythonUninstallComponent(PkgUninstallComponent):
|
|||||||
pips = self.tracereader.pips_installed()
|
pips = self.tracereader.pips_installed()
|
||||||
if pips:
|
if pips:
|
||||||
pip_names = set([p['name'] for p in pips])
|
pip_names = set([p['name'] for p in pips])
|
||||||
utils.log_iterable(pip_names, header="Uninstalling %s python packages" % (len(pip_names)))
|
utils.log_iterable(pip_names, logger=LOG,
|
||||||
|
header="Uninstalling %s python packages" % (len(pip_names)))
|
||||||
with utils.progress_bar(UNINSTALL_TITLE, len(pips), reverse=True) as p_bar:
|
with utils.progress_bar(UNINSTALL_TITLE, len(pips), reverse=True) as p_bar:
|
||||||
for (i, p) in enumerate(pips):
|
for (i, p) in enumerate(pips):
|
||||||
pip.uninstall(p, self.distro)
|
pip.uninstall(p, self.distro)
|
||||||
@ -493,7 +505,8 @@ class PythonUninstallComponent(PkgUninstallComponent):
|
|||||||
py_listing_dirs = set()
|
py_listing_dirs = set()
|
||||||
for (_, where) in py_listing:
|
for (_, where) in py_listing:
|
||||||
py_listing_dirs.add(where)
|
py_listing_dirs.add(where)
|
||||||
utils.log_iterable(py_listing_dirs, header="Uninstalling %s python setups" % (len(py_listing_dirs)))
|
utils.log_iterable(py_listing_dirs, logger=LOG,
|
||||||
|
header="Uninstalling %s python setups" % (len(py_listing_dirs)))
|
||||||
for where in py_listing_dirs:
|
for where in py_listing_dirs:
|
||||||
sh.execute(*PY_UNINSTALL, cwd=where, run_as_root=True)
|
sh.execute(*PY_UNINSTALL, cwd=where, run_as_root=True)
|
||||||
|
|
||||||
|
@ -145,7 +145,9 @@ class ActionRunner(object):
|
|||||||
self._handle_prereq(persona, instances, root_dir)
|
self._handle_prereq(persona, instances, root_dir)
|
||||||
component_order = self._order_components(persona.wanted_components)
|
component_order = self._order_components(persona.wanted_components)
|
||||||
LOG.info("Processing components for action %r", (self.NAME or "???"))
|
LOG.info("Processing components for action %r", (self.NAME or "???"))
|
||||||
utils.log_iterable(component_order, header="Activating in the following order:")
|
utils.log_iterable(component_order,
|
||||||
|
header="Activating in the following order:",
|
||||||
|
logger=LOG)
|
||||||
self._verify_components(component_order, instances)
|
self._verify_components(component_order, instances)
|
||||||
self._warm_components(component_order, instances)
|
self._warm_components(component_order, instances)
|
||||||
self._run(persona, root_dir, component_order, instances)
|
self._run(persona, root_dir, component_order, instances)
|
||||||
|
@ -152,11 +152,13 @@ def mark_unexecute_file(fn, kvs, comment_start='#'):
|
|||||||
sh.chmod(fn, 0644)
|
sh.chmod(fn, 0644)
|
||||||
|
|
||||||
|
|
||||||
def log_iterable(to_log, header=None):
|
def log_iterable(to_log, header=None, logger=None):
|
||||||
|
if not logger:
|
||||||
|
logger = LOG
|
||||||
if header:
|
if header:
|
||||||
LOG.info(header)
|
logger.info(header)
|
||||||
for c in to_log:
|
for c in to_log:
|
||||||
LOG.info("|-- %s", color_text(c, 'blue'))
|
logger.info("|-- %s", color_text(c, 'blue'))
|
||||||
|
|
||||||
|
|
||||||
@contextlib.contextmanager
|
@contextlib.contextmanager
|
||||||
|
Loading…
Reference in New Issue
Block a user