[tor-commits] [arm/master] Combining _setup_debug_logging() and _armrc_dump()
atagar at torproject.org
atagar at torproject.org
Sun Dec 22 02:29:08 UTC 2013
commit 9a455805476927d467ed93424dc5bab4599d2324
Author: Damian Johnson <atagar at torproject.org>
Date: Sat Dec 21 18:22:43 2013 -0800
Combining _setup_debug_logging() and _armrc_dump()
The _armrc_dump() is solely used to help provide general debug information.
Might as well include it in the debug setup.
---
arm/starter.py | 62 ++++++++++++++++++++++++--------------------------------
1 file changed, 27 insertions(+), 35 deletions(-)
diff --git a/arm/starter.py b/arm/starter.py
index 6913275..ca2179f 100644
--- a/arm/starter.py
+++ b/arm/starter.py
@@ -122,19 +122,22 @@ def _authenticate(controller, password):
raise ValueError("Unable to authenticate: %s" % exc)
-def _setup_debug_logging(debug_path):
+def _setup_debug_logging(args):
"""
- Configures us to log at stem's trace level to debug log path.
+ Configures us to log at stem's trace level to debug log path, and notes some
+ general diagnostic information.
+
+ :param namedtuple args: startup arguments
:raises: **IOError** if we can't log to this location
"""
- debug_dir = os.path.dirname(debug_path)
+ debug_dir = os.path.dirname(args.debug_path)
if not os.path.exists(debug_dir):
os.makedirs(debug_dir)
- debug_handler = logging.FileHandler(debug_path, mode = 'w')
+ debug_handler = logging.FileHandler(args.debug_path, mode = 'w')
debug_handler.setLevel(stem.util.log.logging_level(stem.util.log.TRACE))
debug_handler.setFormatter(logging.Formatter(
fmt = '%(asctime)s [%(levelname)s] %(message)s',
@@ -143,24 +146,24 @@ def _setup_debug_logging(debug_path):
stem.util.log.get_logger().addHandler(debug_handler)
-
-def _armrc_dump(armrc_path):
- """
- Provides a dump of our armrc or a description of why it can't be read.
-
- :param str armrc_path: path of the armrc
-
- :returns: **str** with either a dump or description of our armrc
- """
-
- if not os.path.exists(armrc_path):
- return "[file doesn't exist]"
-
- try:
- with open(armrc_path) as armrc_file:
- return armrc_file.read()
- except IOError as exc:
- return "[unable to read file: %s]" % exc.strerror
+ if not os.path.exists(args.config):
+ armrc_content = "[file doesn't exist]"
+ else:
+ try:
+ with open(args.config) as armrc_file:
+ armrc_content = armrc_file.read()
+ except IOError as exc:
+ armrc_content = "[unable to read file: %s]" % exc.strerror
+
+ stem.util.log.trace(CONFIG['msg.debug_header'].format(
+ arm_version = arm.__version__,
+ stem_version = stem.__version__,
+ python_version = '.'.join(map(str, sys.version_info[:3])),
+ system = platform.system(),
+ platform = " ".join(platform.dist()),
+ armrc_path = args.config,
+ armrc_content = armrc_content,
+ ))
def _shutdown_daemons():
@@ -210,23 +213,12 @@ def main():
if args.debug_path is not None:
try:
- _setup_debug_logging()
+ _setup_debug_logging(args)
+ print "Saving a debug log to %s, please check it for sensitive information before sharing" % args.debug_path
except IOError as exc:
print "Unable to write to our debug log file (%s): %s" % (args.debug_path, exc.strerror)
sys.exit(1)
- stem.util.log.trace(CONFIG['msg.debug_header'].format(
- arm_version = arm.__version__,
- stem_version = stem.__version__,
- python_version = '.'.join(map(str, sys.version_info[:3])),
- system = platform.system(),
- platform = " ".join(platform.dist()),
- armrc_path = args.config,
- armrc_content = _armrc_dump(args.config),
- ))
-
- print "Saving a debug log to %s, please check it for sensitive information before sharing" % args.debug_path
-
# loads user's personal armrc if available
if os.path.exists(args.config):
More information about the tor-commits
mailing list