summaryrefslogtreecommitdiffstats
path: root/src/ansiblelint/logger.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/ansiblelint/logger.py')
-rw-r--r--src/ansiblelint/logger.py18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/ansiblelint/logger.py b/src/ansiblelint/logger.py
new file mode 100644
index 0000000..18b36f4
--- /dev/null
+++ b/src/ansiblelint/logger.py
@@ -0,0 +1,18 @@
+"""Utils related to logging."""
+import logging
+import time
+from contextlib import contextmanager
+from typing import Any, Iterator
+
+_logger = logging.getLogger(__name__)
+
+
+@contextmanager
+def timed_info(msg: Any, *args: Any) -> Iterator[None]:
+ """Context manager for logging slow operations, mentions duration."""
+ start = time.time()
+ try:
+ yield
+ finally:
+ elapsed = time.time() - start
+ _logger.info(msg + " (%.2fs)", *(*args, elapsed))