2022-08-30 17:25:40 +02:00

102 lines
2.7 KiB
Python

# Copyright 2021 Collate
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""
Module centralising logger configs
"""
import logging
from enum import Enum
from typing import Union
from metadata.generated.schema.api.lineage.addLineage import AddLineageRequest
BASE_LOGGING_FORMAT = (
"[%(asctime)s] %(levelname)-8s {%(name)s:%(module)s:%(lineno)d} - %(message)s"
)
logging.basicConfig(format=BASE_LOGGING_FORMAT, datefmt="%Y-%m-%d %H:%M:%S")
class Loggers(Enum):
OMETA = "OMetaAPI"
CLI = "Metadata"
PROFILER = "Profiler"
INGESTION = "Ingestion"
UTILS = "Utils"
GREAT_EXPECTATIONS = "GreatExpectations"
SQA_PROFILER_INTERFACE = "SQAInterface"
TEST_SUITE = "TestSuite"
def ometa_logger():
return logging.getLogger(Loggers.OMETA.value)
def cli_logger():
return logging.getLogger(Loggers.CLI.value)
def profiler_logger():
return logging.getLogger(Loggers.PROFILER.value)
def test_suite_logger():
return logging.getLogger(Loggers.TEST_SUITE.value)
def sqa_interface_registry_logger():
return logging.getLogger(Loggers.SQA_PROFILER_INTERFACE.value)
def ingestion_logger():
return logging.getLogger(Loggers.INGESTION.value)
def utils_logger():
return logging.getLogger(Loggers.UTILS.value)
def great_expectations_logger():
return logging.getLogger(Loggers.GREAT_EXPECTATIONS.value)
def set_loggers_level(level: Union[int, str] = logging.INFO):
"""
Set all loggers levels
:param level: logging level
"""
ometa_logger().setLevel(level)
cli_logger().setLevel(level)
profiler_logger().setLevel(level)
ingestion_logger().setLevel(level)
utils_logger().setLevel(level)
great_expectations_logger().setLevel(level)
test_suite_logger().setLevel(level)
def get_add_lineage_log_str(add_lineage: AddLineageRequest) -> str:
"""
Given a LineageRequest, parse its contents to return
a string that we can log
"""
# id and type will always be informed
id_ = add_lineage.edge.fromEntity.id.__root__
type_ = add_lineage.edge.fromEntity.type
# name can be informed or not
name_str = (
f"name: {add_lineage.edge.fromEntity.name}, "
if add_lineage.edge.fromEntity.name
else ""
)
return f"{type_} [{name_str}id: {id_}]"