Skip to content

Commit

Permalink
Add cosmos/propagate_logs Airflow config support for disabling log pr…
Browse files Browse the repository at this point in the history
…opagation if desired
  • Loading branch information
Andrew Greenburg committed Nov 3, 2023
1 parent 358f4b0 commit f57d03d
Show file tree
Hide file tree
Showing 6 changed files with 61 additions and 0 deletions.
25 changes: 25 additions & 0 deletions cosmos/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -116,3 +116,28 @@
"LoadMode",
"TestBehavior",
]

"""
Required provider info for using Airflow config for configuration
"""
def get_provider_info():
return {
"package-name": "astronomer-cosmos", # Required
"name": "Astronomer Cosmos", # Required
"description": "Astronomer Cosmos is a library for rendering dbt workflows in Airflow. Contains dags, task groups, and operators.", # Required
"versions": [__version__], # Required
"config": {
"cosmos": {
"description": None,
"options": {
"propagate_logs": {
"description": "Enable log propagation from Cosmos custom logger\n",
"version_added": "1.3.0a1",
"type": "boolean",
"example": None,
"default": "True",
},
},
},
},
}
5 changes: 5 additions & 0 deletions cosmos/log.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
from __future__ import annotations
import logging

from airflow.configuration import conf
from airflow.utils.log.colored_log import CustomTTYColoredFormatter


Expand All @@ -23,9 +24,13 @@ def get_logger(name: str | None = None) -> logging.Logger:
By using this logger, we introduce a (yellow) astronomer-cosmos string into the project's log messages:
[2023-08-09T14:20:55.532+0100] {subprocess.py:94} INFO - (astronomer-cosmos) - 13:20:55 Completed successfully
"""
propagateLogs: bool = True
if conf.has_option("cosmos", "propagate_logs"):
propagateLogs = conf.getboolean("cosmos", "propagate_logs")
logger = logging.getLogger(name)
formatter: logging.Formatter = CustomTTYColoredFormatter(fmt=LOG_FORMAT) # type: ignore
handler = logging.StreamHandler()
handler.setFormatter(formatter)
logger.addHandler(handler)
logger.propagate = propagateLogs
return logger
1 change: 1 addition & 0 deletions docs/configuration/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -21,3 +21,4 @@ Cosmos offers a number of configuration options to customize its behavior. For m
Selecting & Excluding <selecting-excluding>
Operator Args <operator-args>
Compiled SQL <compiled-sql>
Logging <logging>
19 changes: 19 additions & 0 deletions docs/configuration/logging.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
.. _logging:

Logging
====================

Cosmos uses a custom logger implementation so that all log messages are clearly tagged with ``(astronomer-cosmos)``. By default this logger has propagation enabled.

In some environments (for example when running Celery workers) this can cause duplicated log messages to appear in the logs. In this case log propagation can be disabled via airflow configuration using the boolean option ``propagate_logs`` under a ``cosmos`` section.

.. code-block:: cfg
[cosmos]
propagate_logs = False
or

.. code-block:: python
AIRFLOW__COSMOS__PROPAGATE_LOGS = "False"
3 changes: 3 additions & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,9 @@ kubernetes = [
]


[project.entry-points.cosmos]
provider_info = "cosmos:get_provider_info"

[project.urls]
Homepage = "https://github.com/astronomer/astronomer-cosmos"
Documentation = "https://astronomer.github.io/astronomer-cosmos"
Expand Down
8 changes: 8 additions & 0 deletions tests/test_log.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import logging

from cosmos.log import get_logger
from airflow.configuration import conf


def test_get_logger():
Expand All @@ -12,3 +13,10 @@ def test_get_logger():
assert custom_logger.propagate is True
assert custom_logger.handlers[0].formatter.__class__.__name__ == "CustomTTYColoredFormatter"
assert custom_string in custom_logger.handlers[0].formatter._fmt

def test_propagate_logs_conf():
if not conf.has_section("cosmos"):
conf.add_section("cosmos")
conf.set("cosmos","propagate_logs","False")
custom_logger = get_logger("cosmos-log")
assert custom_logger.propagate is False

0 comments on commit f57d03d

Please sign in to comment.