summaryrefslogtreecommitdiffstats
path: root/src/ansiblelint/logger.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 12:06:49 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 12:06:49 +0000
commit2fe34b6444502079dc0b84365ce82dbc92de308e (patch)
tree8fedcab52bbbc3db6c5aa909a88a7a7b81685018 /src/ansiblelint/logger.py
parentInitial commit. (diff)
downloadansible-lint-2fe34b6444502079dc0b84365ce82dbc92de308e.tar.xz
ansible-lint-2fe34b6444502079dc0b84365ce82dbc92de308e.zip
Adding upstream version 6.17.2.upstream/6.17.2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/ansiblelint/logger.py31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/ansiblelint/logger.py b/src/ansiblelint/logger.py
new file mode 100644
index 0000000..f0477cd
--- /dev/null
+++ b/src/ansiblelint/logger.py
@@ -0,0 +1,31 @@
+"""Utils related to logging."""
+import logging
+import time
+from collections.abc import Iterator
+from contextlib import contextmanager
+from typing import Any
+
+_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)) # noqa: G003
+
+
+def warn_or_fail(message: str) -> None:
+ """Warn or fail depending on the strictness level."""
+ # pylint: disable=import-outside-toplevel
+ from ansiblelint.config import options
+ from ansiblelint.errors import StrictModeError
+
+ if options.strict:
+ raise StrictModeError(message)
+
+ _logger.warning(message)