-
Notifications
You must be signed in to change notification settings - Fork 3.3k
/
kernel_function_log_messages.py
63 lines (49 loc) · 2.48 KB
/
kernel_function_log_messages.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# Copyright (c) Microsoft. All rights reserved.
import logging
from logging import Logger
from semantic_kernel.functions.function_result import FunctionResult
from semantic_kernel.functions.kernel_arguments import KernelArguments
class KernelFunctionLogMessages:
"""Kernel function log messages.
This class contains static methods to log messages related to kernel functions.
"""
@staticmethod
def log_function_invoking(logger: Logger, kernel_function_name: str):
"""Log message when a kernel function is invoked."""
logger.info("Function %s invoking.", kernel_function_name)
@staticmethod
def log_function_arguments(logger: Logger, arguments: KernelArguments):
"""Log message when a kernel function is invoked."""
logger.debug("Function arguments: %s", arguments)
@staticmethod
def log_function_invoked_success(logger: Logger, kernel_function_name: str):
"""Log message when a kernel function is invoked successfully."""
logger.info("Function %s succeeded.", kernel_function_name)
@staticmethod
def log_function_result_value(logger: Logger, function_result: FunctionResult | None):
"""Log message when a kernel function result is returned."""
if not logger.isEnabledFor(logging.DEBUG):
return
if function_result is not None:
try:
logger.debug("Function result: %s", function_result)
except Exception:
logger.error("Function result: Failed to convert result value to string")
else:
logger.debug("Function result: None")
@staticmethod
def log_function_error(logger: Logger, error: Exception):
"""Log message when a kernel function fails."""
logger.error("Function failed. Error: %s", error)
@staticmethod
def log_function_completed(logger: Logger, duration: float):
"""Log message when a kernel function is completed."""
logger.info("Function completed. Duration: %fs", duration)
@staticmethod
def log_function_streaming_invoking(logger: Logger, kernel_function_name: str):
"""Log message when a kernel function is invoked via streaming."""
logger.info("Function %s streaming.", kernel_function_name)
@staticmethod
def log_function_streaming_completed(logger: Logger, duration: float):
"""Log message when a kernel function is completed via streaming."""
logger.info("Function streaming completed. Duration: %fs", duration)