Split common logging functions into rbackup.logging module

This commit is contained in:
Eric Torres 2019-04-27 10:13:10 -07:00
parent 09228b0aa1
commit 7d7aae9298
2 changed files with 43 additions and 21 deletions

View File

@ -13,7 +13,6 @@ Command-Line Arguments
-r, --remote-host address/alias of remote machine to use -r, --remote-host address/alias of remote machine to use
-s, --run-post-sync run sync syscall after backup -s, --run-post-sync run sync syscall after backup
-u, --umask umask value to use while running backup process -u, --umask umask value to use while running backup process
-v, --verbose show info messages
Run a backup, creating a snapshot in the process. Run a backup, creating a snapshot in the process.
@ -30,14 +29,13 @@ and
import argparse import argparse
import logging import logging
import os import os
import sys
import rbackup.config.config_files as config import rbackup.config.config_files as config
import rbackup.logging
import rbackup.script as script import rbackup.script as script
from rbackup.struct.repository import Repository from rbackup.struct.repository import Repository
# ========== Constants ========== # ========== Constants ==========
LOGFORMAT = "==> %(levelname)s %(message)s"
EXTRA_RSYNC_OPTS = { EXTRA_RSYNC_OPTS = {
"dry_run": "--dry-run", "dry_run": "--dry-run",
"delete": "--delete-after", "delete": "--delete-after",
@ -50,22 +48,9 @@ E_PERMISSION = 13
# ========== Logging Setup ========== # ========== Logging Setup ==========
console_formatter = logging.Formatter(LOGFORMAT)
syslog = logging.getLogger("rbackup") syslog = logging.getLogger("rbackup")
syslog.setLevel(logging.DEBUG) syslog.setLevel(logging.DEBUG)
stdout_handler = logging.StreamHandler(sys.stdout)
stdout_handler.setLevel(logging.INFO)
stdout_handler.setFormatter(console_formatter)
stdout_handler.addFilter(lambda record: record.levelno <= logging.INFO)
stderr_handler = logging.StreamHandler(sys.stderr)
stderr_handler.setLevel(logging.WARNING)
stderr_handler.setFormatter(console_formatter)
syslog.addHandler(stdout_handler)
syslog.addHandler(stderr_handler)
# ========== Functions ========== # ========== Functions ==========
def parse_cmdline_arguments(**kwargs): def parse_cmdline_arguments(**kwargs):
@ -132,11 +117,11 @@ def parse_cmdline_arguments(**kwargs):
if __name__ == "__main__": if __name__ == "__main__":
args = parse_cmdline_arguments() args = parse_cmdline_arguments()
if args.verbose: stdout_handler, stderr_handler = rbackup.logging.retrieve_console_handlers(
stdout_handler.setLevel(logging.INFO) debug=args.debug
)
if args.debug: syslog.addHandler(stdout_handler)
stdout_handler.setLevel(logging.DEBUG) syslog.addHandler(stderr_handler)
dest = ( dest = (
args.repository args.repository

37
rbackup/logging.py Normal file
View File

@ -0,0 +1,37 @@
"""
.. moduleauthor:: Eric Torres
.. module:: rbackup.logging
:synopsis: library for common logging constants
"""
import logging
import sys
# ========== Constants ==========
# ----- Console Formatters -----
_CONSOLE_FORMAT = "==> %(levelname)s %(message)s"
CONSOLE_FORMATTER = logging.Formatter(_CONSOLE_FORMAT)
# ========== Functions ==========
def retrieve_console_handlers(*, debug=False):
"""Retrieve a pair of logging handlers configured for console output.
:param debug: should logging.DEBUG level messages be recorded?
:type debug: bool
:return: tuple of ``logging.StreamHandler``s for stdout and stderr
"""
stdout_handler = logging.StreamHandler(sys.stdout)
stdout_handler.setFormatter(_CONSOLE_FORMAT)
stdout_handler.addFilter(lambda record: record.levelno <= logging.INFO)
if debug:
stdout_handler.setLevel(logging.DEBUG)
else:
stdout_handler.setLevel(logging.INFO)
stderr_handler = logging.StreamHandler(sys.stderr)
stderr_handler.setLevel(logging.WARNING)
stderr_handler.setFormatter(_CONSOLE_FORMAT)
return stdout_handler, stderr_handler