add verbose/debug functions to msger
authorJF Ding <jian-feng.ding@intel.com>
Fri, 19 Aug 2011 13:56:49 +0000 (21:56 +0800)
committerJF Ding <jian-feng.ding@intel.com>
Fri, 19 Aug 2011 13:56:49 +0000 (21:56 +0800)
13 files changed:
mic/configmgr.py
mic/creator.py
mic/imager/baseimager.py
mic/imager/fs.py
mic/imager/livecd.py
mic/imager/liveusb.py
mic/imager/raw.py
mic/msger.py
mic/pluginmgr.py
mic/utils/misc.py
mic/utils/rpmmisc.py
plugins/backend/yumpkgmgr.py
tools/mic

index 1ba75e2cf6a4bfe4c0b403ea9c3d352df6f8a979..42adb72760edff9b75c6704d06d644edcf6223c5 100644 (file)
@@ -18,7 +18,6 @@
 #
 
 import os, sys
-import logging
 import ConfigParser
 import mic.utils as utils
 import mic.utils.errors as errors
index 8f9d3821046412559cbc1f165787482ee3a79135..dd8380601f49d79316dbff9474ef2d832ca856f4 100644 (file)
@@ -18,7 +18,6 @@
 #
 
 import os, sys
-import logging
 
 from mic import configmgr
 from mic import pluginmgr
index a4fab4aed62c3665bbb44fb88ec225043d103fba..3d191dfc4ba6bf8c3984a44688f2efe58aff4ccd 100644 (file)
@@ -20,7 +20,6 @@ import os, sys
 import stat
 import tempfile
 import shutil
-import logging
 import subprocess
 import re
 import tarfile
@@ -738,7 +737,7 @@ class BaseImageCreator(object):
                                        (pkg, e))
 
         for pkg in skipped_pkgs:
-            logging.warn("Skipping missing package '%s'" % (pkg,))
+            msger.warning("Skipping missing package '%s'" % (pkg,))
 
     def __select_groups(self, pkg_manager):
         skipped_groups = []
@@ -752,7 +751,7 @@ class BaseImageCreator(object):
                                        (group.name, e))
 
         for group in skipped_groups:
-            logging.warn("Skipping missing group '%s'" % (group.name,))
+            msger.warning("Skipping missing group '%s'" % (group.name,))
 
     def __deselect_packages(self, pkg_manager):
         for pkg in self._excluded_pkgs:
@@ -942,7 +941,7 @@ class BaseImageCreator(object):
                                  stdout=subprocess.PIPE)
             (md5sum, errorstr) = p.communicate()
             if p.returncode != 0:
-                logging.warning("Can't generate md5sum for image %s" % image_name)
+                msger.warning("Can't generate md5sum for image %s" % image_name)
             else:
                 pattern = re.compile("\*.*$")
                 md5sum = pattern.sub("*" + os.path.basename(image_name), md5sum)
@@ -990,7 +989,7 @@ class BaseImageCreator(object):
         """ For image formats with two or multiple image files, it will be better to put them under a directory """
         if self.image_format in ("raw", "vmdk", "vdi", "nand", "mrstnand"):
             destdir = os.path.join(destdir, "%s-%s" % (self.name, self.image_format))
-            logging.debug("creating destination dir: %s" % destdir)
+            msger.debug("creating destination dir: %s" % destdir)
             makedirs(destdir)
 
         # Ensure all data is flushed to _outdir
index 3b253848ae64073afa968bc566f7955320cfa9c6..79b2cd2991f568372dfea6bc45d2bac4384436e2 100644 (file)
@@ -22,7 +22,6 @@ import stat
 import sys
 import tempfile
 import shutil
-import logging
 import subprocess
 import re
 import tarfile
@@ -57,7 +56,7 @@ class FsImageCreator(BaseImageCreator):
         if self._recording_pkgs:
             self._save_recording_pkgs(destdir)
 
-        logging.info("Copying %s to %s, please be patient to wait" % (self._instroot, destdir + "/" + self.name))
+        msger.info("Copying %s to %s, please be patient to wait" % (self._instroot, destdir + "/" + self.name))
 
         copycmd = find_binary_path("cp")
         args = [ copycmd, "-af", self._instroot, destdir + "/" + self.name ]
index 072ae60f227d674ada22bdf2510d31e8b9431bb4..bb0f4467d323ea6c16c74ff4b4068cb1c9f0086a 100644 (file)
@@ -21,7 +21,6 @@ import sys
 import glob
 import shutil
 import subprocess
-import logging
 import re
 import time
 
@@ -31,6 +30,7 @@ import mic.utils.rpmmisc as rpmmisc
 import mic.utils.misc as misc
 from mic.utils.errors import *
 from loop import LoopImageCreator
+from mic import msger
 
 class LiveImageCreatorBase(LoopImageCreator):
     """A base class for LiveCD image creators.
@@ -250,7 +250,7 @@ class LiveImageCreatorBase(LoopImageCreator):
         elif os.path.exists("/usr/lib/anaconda-runtime/implantisomd5"):
             implantisomd5 = "/usr/lib/anaconda-runtime/implantisomd5"
         else:
-            logging.warn("isomd5sum not installed; not setting up mediacheck")
+            msger.warn("isomd5sum not installed; not setting up mediacheck")
             implantisomd5 = ""
             return
 
index aee1fb3ad5cd731e89378274881548b7f3ed02ad..a90b958bf7968d27bf7beb7db8ffa614d7b22fd3 100644 (file)
@@ -20,7 +20,6 @@ import os.path
 import glob
 import shutil
 import subprocess
-import logging
 import re
 import time
 
index 5aa0d9fbc073bff9ba99c5f72b48a97fcccc958a..26f18318a1d6d61c3b9e17ac58b2b21575758dd6 100644 (file)
@@ -24,7 +24,6 @@ import shutil
 import zipfile
 import tarfile
 import subprocess
-import logging
 
 import mic.kickstart as kickstart
 import mic.utils.fs_related as fs_related
@@ -32,6 +31,7 @@ import urlgrabber.progress as progress
 from baseimager import BaseImageCreator
 from mic.utils.partitionedfs import PartitionedMount
 from mic.utils.errors import *
+from mic import msger
 
 
 class RawImageCreator(BaseImageCreator):
@@ -114,7 +114,7 @@ class RawImageCreator(BaseImageCreator):
         mkinitrd += "rootfs=\"ext3\"\n"
         mkinitrd += "rootopts=\"defaults\"\n"
 
-        logging.debug("Writing mkinitrd config %s/etc/sysconfig/mkinitrd" % self._instroot)
+        msger.debug("Writing mkinitrd config %s/etc/sysconfig/mkinitrd" % self._instroot)
         os.makedirs(self._instroot + "/etc/sysconfig/",mode=644)
         cfg = open(self._instroot + "/etc/sysconfig/mkinitrd", "w")
         cfg.write(mkinitrd)
@@ -164,7 +164,7 @@ class RawImageCreator(BaseImageCreator):
 
         #create disk
         for item in disks:
-            logging.debug("Adding disk %s as %s/%s-%s.raw" % (item['name'], self.__imgdir,self.name, item['name']))
+            msger.debug("Adding disk %s as %s/%s-%s.raw" % (item['name'], self.__imgdir,self.name, item['name']))
             disk = fs_related.SparseLoopbackDisk("%s/%s-%s.raw" % (self.__imgdir,self.name, item['name']),item['size'])
             self.__disks[item['name']] = disk
 
@@ -261,7 +261,7 @@ class RawImageCreator(BaseImageCreator):
                syslinux_conf += "\tmenu default\n"
             footlabel += 1;
 
-        logging.debug("Writing syslinux config %s/boot/extlinux/extlinux.conf" % self._instroot)
+        msger.debug("Writing syslinux config %s/boot/extlinux/extlinux.conf" % self._instroot)
         cfg = open(self._instroot + "/boot/extlinux/extlinux.conf", "w")
         cfg.write(syslinux_conf)
         cfg.close()
@@ -272,7 +272,7 @@ class RawImageCreator(BaseImageCreator):
             loopdev = self.__disks[name].device
             i =i+1
 
-        logging.debug("Installing syslinux bootloader to %s" % loopdev)
+        msger.debug("Installing syslinux bootloader to %s" % loopdev)
 
         (bootdevnum, rootdevnum, rootdev, prefix) = self._get_syslinux_boot_config()
 
@@ -325,12 +325,12 @@ class RawImageCreator(BaseImageCreator):
         """
         self._resparse()
 
-        logging.debug("moving disks to stage location")
+        msger.debug("moving disks to stage location")
         for name in self.__disks.keys():
             src = "%s/%s-%s.raw" % (self.__imgdir, self.name,name)
             self._img_name = "%s-%s.%s" % (self.name, name, self.__disk_format)
             dst = "%s/%s" % (self._outdir, self._img_name)
-            logging.debug("moving %s to %s" % (src,dst))
+            msger.debug("moving %s to %s" % (src,dst))
             shutil.move(src,dst)
         self._write_image_xml()
 
@@ -415,7 +415,7 @@ class RawImageCreator(BaseImageCreator):
         xml += "  </storage>\n"
         xml += "</image>\n"
 
-        logging.debug("writing image XML to %s/%s.xml" %  (self._outdir, self.name))
+        msger.debug("writing image XML to %s/%s.xml" %  (self._outdir, self.name))
         cfg = open("%s/%s.xml" % (self._outdir, self.name), "w")
         cfg.write(xml)
         cfg.close()
index e1bee0b72dc64ac144623f90b9072a5714133f94..53d19085fe5793e59986902b841994e5183b4af6 100644 (file)
@@ -19,7 +19,7 @@
 import os,sys
 import re
 
-__ALL__ = ['set_mode', 'info', 'warning', 'error', 'ask']
+__ALL__ = ['set_mode', 'set_loglevel', 'raw' 'debug', 'verbose', 'info', 'warning', 'error', 'ask']
 
 # COLORs in ANSI
 INFO_COLOR = 32 # green
@@ -32,7 +32,19 @@ PREFIX_RE = re.compile('^<(.*?)>\s*(.*)')
 
 INTERACTIVE = True
 
-def _color_print(head, color, msg = None, stream = sys.stdout):
+LOG_LEVELS = {
+                'quiet': 0,
+                'normal': 1,
+                'verbose': 2,
+                'debug': 3,
+             }
+LOG_LEVEL = 1
+
+def _color_print(head, color, msg = None, stream = sys.stdout, level = 'normal'):
+
+    if LOG_LEVELS[level] > LOG_LEVEL:
+        # skip
+        return
 
     colored = True
     if color == NO_COLOR or \
@@ -64,8 +76,8 @@ def _color_print(head, color, msg = None, stream = sys.stdout):
 
     stream.flush()
 
-def _color_perror(head, color, msg):
-    _color_print(head, color, msg, sys.stderr)
+def _color_perror(head, color, msg, level = 'normal'):
+    _color_print(head, color, msg, sys.stderr, level)
 
 def _split_msg(head, msg):
     if msg.startswith('\n'):
@@ -85,6 +97,14 @@ def _split_msg(head, msg):
 
     return head, msg
 
+def set_loglevel(level):
+    global LOG_LEVEL
+    if level not in LOG_LEVELS:
+        # no effect
+        return
+
+    LOG_LEVEL = LOG_LEVELS[level]
+
 def set_mode(interactive):
     global INTERACTIVE
     if interactive:
@@ -100,10 +120,18 @@ def info(msg):
     head, msg = _split_msg('Info', msg)
     _color_print(head, INFO_COLOR, msg)
 
+def verbose(msg):
+    head, msg = _split_msg('Verbose', msg)
+    _color_print(head, INFO_COLOR, msg, level = 'verbose')
+
 def warning(msg):
     head, msg = _split_msg('Warning', msg)
     _color_perror(head, WARN_COLOR, msg)
 
+def debug(msg):
+    head, msg = _split_msg('Debug', msg)
+    _color_perror(head, ERR_COLOR, msg, level = 'debug')
+
 def error(msg):
     head, msg = _split_msg('Error', msg)
     _color_perror(head, ERR_COLOR, msg)
index 607172f66f8d9ae1db73840e82e95e3fbbc0a77f..fc39e6227df63f8be9986ca2311a7e624c09f3d8 100644 (file)
@@ -18,7 +18,7 @@
 #
 
 import os, sys
-import logging
+from mic import msger
 
 DEFAULT_PLUGIN_LOCATION = "/usr/lib/mic/plugins"
 
@@ -44,7 +44,7 @@ class PluginMgr(object):
 
     def addPluginDir(self, plugin_dir):
         if not os.path.isdir(plugin_dir):
-            logging.debug("Plugin dir is not a directory or does not exist: %s" % plugin_dir)
+            msger.debug("Plugin dir is not a directory or does not exist: %s" % plugin_dir)
             return
 
         if plugin_dir not in self.plugin_locations:
@@ -52,19 +52,19 @@ class PluginMgr(object):
 
     def pluginCheck(self, pymod):
         if not hasattr(pymod, STRING_PLUGIN_MARK):
-            logging.debug("Not a valid plugin: %s" % pymod.__file__)
-            logging.debug("Please check whether %s given" % STRING_PLUGIN_MARK)
+            msger.debug("Not a valid plugin: %s" % pymod.__file__)
+            msger.debug("Please check whether %s given" % STRING_PLUGIN_MARK)
             return False
 
         plclass = getattr(pymod, STRING_PLUGIN_MARK)[1]
         if not hasattr(plclass, STRING_PTYPE_MARK):
-            logging.debug("Not a valid plugin: %s" % pymod.__file__)
-            logging.debug("Please check whether %s given" % STRING_PTYPE_MARK)
+            msger.debug("Not a valid plugin: %s" % pymod.__file__)
+            msger.debug("Please check whether %s given" % STRING_PTYPE_MARK)
             return False
 
         pltype = getattr(plclass, STRING_PTYPE_MARK)
         if not (pltype in self.plugin_types):
-            logging.debug("Unsupported plugin type in %s: %s" % (pymod.__file__, plugintype))
+            msger.debug("Unsupported plugin type in %s: %s" % (pymod.__file__, plugintype))
             return False
 
         return True
@@ -74,26 +74,26 @@ class PluginMgr(object):
             return
 
         if not plugin_filename.endswith(".py"):
-            logging.debug("Not a python file: %s" % os.path.join(dir_path, plugin_filename))
+            msger.debug("Not a python file: %s" % os.path.join(dir_path, plugin_filename))
             return
 
         if plugin_filename == ".py":
-            logging.debug("Empty module name: %s" % os.path.join(dir_path, plugin_filename))
+            msger.debug("Empty module name: %s" % os.path.join(dir_path, plugin_filename))
             return
 
         if plugin_filename == "__init__.py":
-            logging.debug("Unsupported python file: %s" % os.path.join(dir_path, plugin_filename))
+            msger.debug("Unsupported python file: %s" % os.path.join(dir_path, plugin_filename))
             return
 
         modname = os.path.splitext(plugin_filename)[0]
         if sys.modules.has_key(modname):
             pymod = sys.modules[modname]
-            logging.debug("Module %s already exists: %s" % (modname, pymod.__file__))
+            msger.debug("Module %s already exists: %s" % (modname, pymod.__file__))
         else:
             pymod = __import__(modname)
             pymod.__file__ = os.path.join(dir_path, plugin_filename)
         if not self.pluginCheck(pymod):
-            logging.warn("Failed to check plugin: %s" % os.path.join(dir_path, plugin_filename))
+            msger.warning("Failed to check plugin: %s" % os.path.join(dir_path, plugin_filename))
             return
 
         (pname, pcls) = pymod.__dict__[STRING_PLUGIN_MARK]
@@ -110,7 +110,7 @@ class PluginMgr(object):
 
     def getPluginByCateg(self, categ = None):
         if not (categ in self.plugin_types):
-            logging.warn("Failed to get plugin category: %s" % categ)
+            msger.warning("Failed to get plugin category: %s" % categ)
             return None
         else:
             return self.plugin_sets[categ]
@@ -135,7 +135,7 @@ class PluginMgr(object):
         pass
 
 if __name__ == "__main__":
-    logging.getLogger().setLevel(logging.DEBUG)
+    msger.set_loglevel('debug')
 
     pluginmgr = PluginMgr()
     pluginmgr.loadPlugins()
index b71c1b2f53db88edc866d094b0a856add3301834..a99f43e6a1b0b2d55358ef2e72157b2ad3bad410 100644 (file)
@@ -20,7 +20,6 @@
 import os
 import sys
 import subprocess
-import logging
 import tempfile
 import re
 import shutil
@@ -136,7 +135,7 @@ def convert_image(srcimg, srcfmt, dstimg, dstfmt):
     #convert disk format
     if dstfmt != "raw":
         raise CreatorError("Invalid destination image format: %s" % dstfmt)
-    logging.debug("converting %s image to %s" % (srcimg, dstimg))
+    msger.debug("converting %s image to %s" % (srcimg, dstimg))
     if srcfmt == "vmdk":
         path = find_binary_path("qemu-img")
         argv = [path, "convert", "-f", "vmdk", srcimg, "-O", dstfmt,  dstimg]
@@ -148,7 +147,7 @@ def convert_image(srcimg, srcfmt, dstimg, dstfmt):
 
     rc = subprocess.call(argv)
     if rc == 0:
-        logging.debug("convert successful")
+        msger.debug("convert successful")
     if rc != 0:
         raise CreatorError("Unable to convert disk to %s" % dstfmt)
 
@@ -1042,7 +1041,7 @@ def create_release(config, destdir, name, outimages, release):
                              stdout=subprocess.PIPE)
             (md5sum, errorstr) = p.communicate()
             if p.returncode != 0:
-                logging.warning("Can't generate md5sum for image %s/%s" %(destdir, f ))
+                msger.warning("Can't generate md5sum for image %s/%s" %(destdir, f ))
             else:
                 md5sum = md5sum.split(" ")[0]
                 fd.write(md5sum+" "+f+"\n")
index 1860af84d91c6d3da6d6861c4cacb1d4f9063f0d..e34a47b8c75259c68d95797e2dd3d5f62819d2a4 100644 (file)
@@ -20,7 +20,7 @@
 import os, sys, re
 import rpm
 import subprocess
-import logging
+from mic import msger
 
 class RPMInstallCallback:
     """ Command line callback class for callbacks from the RPM library.
@@ -134,8 +134,7 @@ class RPMInstallCallback:
                         sys.stdout.flush()
                         self.lastmsg = msg
                         if self.total_installed == self.total_actions:
-                             sys.stdout.write("\n")
-                             logging.info('\n'.join(self.logString))
+                             msger.info('\n'.join(self.logString))
 
         elif what == rpm.RPMCALLBACK_UNINST_START:
             pass
index 916781be1841c54aa4497fb10e4d719429d3ea59..2c4656f350f47dd0f1d8e62f9a79fac2b4f16d3c 100644 (file)
@@ -19,7 +19,6 @@
 import glob
 import os
 import sys
-import logging
 
 import yum
 import rpmUtils
@@ -35,6 +34,7 @@ from mic.utils.errors import *
 from mic.utils.fs_related import *
 from mic.pluginbase.backend_plugin import BackendPlugin
 from mic.imager.baseimager import BaseImageCreator as ImageCreator
+from mic import msger
 
 def getRPMCallback():
     sys.path.append('/usr/share/yum-cli')
@@ -248,7 +248,7 @@ class Yum(BackendPlugin, yum.YumBase):
                         pkgs.remove(x)
                         self.tsInfo.conditionals[req] = pkgs
         else:
-            logging.warn("No such package %s to remove" %(pkg,))
+            msger.warning("No such package %s to remove" %(pkg,))
 
     def selectGroup(self, grp, include = ksparser.GROUP_DEFAULT):
         try:
@@ -514,7 +514,7 @@ class Yum(BackendPlugin, yum.YumBase):
             if len(deps) != 0:
                 """ This isn't fatal, Ubuntu has this issue but it is ok. """
                 print deps
-                logging.warn("Dependency check failed!")
+                msger.warning("Dependency check failed!")
             rc = self.ts.order()
             if rc != 0:
                 raise CreatorError("ordering packages for installation failed!")
index 4198f3d0a3425dd6cc688bd2d1278322d71ba226..caa93661582dce75086f93ef83fce6e5b19827b6 100755 (executable)
--- a/tools/mic
+++ b/tools/mic
@@ -18,7 +18,6 @@
 #
 
 import os, sys
-import logging
 
 import mic.utils.misc as misc
 import mic.utils.errors as errors
@@ -54,11 +53,10 @@ class Mic(cmdln.Cmdln):
         return optparser
 
     def postoptparse(self):
-        if self.options.verbose is True:
-           logging.getLogger().setLevel(logging.INFO)
-        if self.options.debug is True:
-           logging.getLogger().setLevel(logging.DEBUG)
-        pass
+        if self.options.verbose:
+           msger.set_loglevel('verbose')
+        if self.options.debug:
+           msger.set_loglevel('debug')
 
     @cmdln.alias("cr")
     def do_create(self, argv):
@@ -172,8 +170,7 @@ class Mic(cmdln.Cmdln):
 if __name__ == "__main__":
     try:
         mic = Mic()
-        ret = mic.main()
-        sys.exit(ret)
+        sys.exit(mic.main())
 
     except errors.Usage, msg:
         msger.error("Usage error: %s\n" % msg)