Source code for mlflow.entities.trace_state

from enum import Enum

from opentelemetry import trace as trace_api

from mlflow.protos import service_pb2 as pb


[docs]class TraceState(str, Enum): """Enum representing the state of a trace. - ``STATE_UNSPECIFIED``: Unspecified trace state. - ``OK``: Trace successfully completed. - ``ERROR``: Trace encountered an error. - ``IN_PROGRESS``: Trace is currently in progress. """ STATE_UNSPECIFIED = "STATE_UNSPECIFIED" OK = "OK" ERROR = "ERROR" IN_PROGRESS = "IN_PROGRESS"
[docs] def to_proto(self): return pb.TraceInfoV3.State.Value(self)
[docs] @classmethod def from_proto(cls, proto: int) -> "TraceState": return TraceState(pb.TraceInfoV3.State.Name(proto))
[docs] @staticmethod def from_otel_status(otel_status: trace_api.Status): """Convert OpenTelemetry status code to MLflow TraceState.""" return _OTEL_STATUS_CODE_TO_MLFLOW[otel_status.status_code]
_OTEL_STATUS_CODE_TO_MLFLOW = { trace_api.StatusCode.OK: TraceState.OK, trace_api.StatusCode.ERROR: TraceState.ERROR, trace_api.StatusCode.UNSET: TraceState.STATE_UNSPECIFIED, }