File: testsetup.py

package info (click to toggle)
python-hiyapyco 0.7.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 436 kB
  • sloc: python: 2,012; makefile: 237
file content (39 lines) | stat: -rw-r--r-- 1,192 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# vim: tabstop=4 expandtab shiftwidth=4 softtabstop=4 smartindent nu

import logging
import argparse

class LoggingAction(argparse.Action):
    def __call__(self, parser, namespace, values, option_string=None):
        # print '%r %r %r' % (namespace, values, option_string)
        logger = logging.getLogger()
        logger.setLevel(values)
        setattr(namespace, self.dest, values)

def setup_parser(args):
    try:
        # python 3.4 up ...
        loggingchoices = logging._nameToLevel.keys()
    except AttributeError:
        loggingchoices = [k for k in logging._levelNames.keys() if isinstance(k, str)]
    parser = argparse.ArgumentParser()
    parser.add_argument(
            '-l', '--loglevel',
            help='set loglevel',
            type=str,
            choices=loggingchoices,
            action=LoggingAction
            )
    return parser.parse_args(args)

def setup(args):
    logger = logging.getLogger()
    logging.basicConfig(
        level=logging.WARN,
        format='%(levelname)s\t[%(name)s] %(funcName)s: %(message)s'
        )
    args = setup_parser(args)
    if args.loglevel is None:
        logging.disable(logging.CRITICAL)
    return logger