From 5b27e57556f0e1e70e096d754ef145ff150788f1 Mon Sep 17 00:00:00 2001 From: Quigley Malcolm Date: Fri, 6 Dec 2024 18:31:00 -0600 Subject: [PATCH] Add two new event types `LogStartBatch` and `LogBatchResult` --- core/dbt/events/core_types.proto | 29 ++++++++++++++++++++++ core/dbt/events/types.py | 41 ++++++++++++++++++++++++++++++++ 2 files changed, 70 insertions(+) diff --git a/core/dbt/events/core_types.proto b/core/dbt/events/core_types.proto index 2938ebb554f..8f3b41f747d 100644 --- a/core/dbt/events/core_types.proto +++ b/core/dbt/events/core_types.proto @@ -1690,6 +1690,35 @@ message MicrobatchExecutionDebugMsg { MicrobatchExecutionDebug data = 2; } +// Q045 +message LogStartBatchLine { + NodeInfo node_info = 1; + string description = 2; + int32 batch_index = 3; + int32 total_batches = 4; +} + +message LogStartLineMsg { + CoreEventInfo info = 1; + LogStartLine data = 2; +} + +// Q046 +message LogBatchResult { + NodeInfo node_info = 1; + string description = 2; + string status = 3; + int32 batch_index = 4; + int32 total_batches = 5; + float execution_time = 6; + Group group = 7; +} + +message LogBatchResultMsg { + CoreEventInfo info = 1; + LogBatchResult data = 2; +} + // W - Node testing // Skipped W001 diff --git a/core/dbt/events/types.py b/core/dbt/events/types.py index 85d2df355ae..9e24f67389d 100644 --- a/core/dbt/events/types.py +++ b/core/dbt/events/types.py @@ -1710,6 +1710,47 @@ def message(self) -> str: return self.msg +class LogStartBatch(InfoLevel): + def code(self) -> str: + return "Q045" + + def message(self) -> str: + msg = f"START {self.description}" + return format_fancy_output_line( + msg=msg, + status="RUN", + index=self.batch_index, + total=self.total_batches, + progress_prefix="Batch", + ) + + +class LogBatchResult(DynamicLevel): + def code(self) -> str: + return "Q046" + + def message(self) -> str: + if self.status == "error": + info = "ERROR creating" + status = red(self.status.upper()) + elif "SKIP" in self.status: + info = "SKIPPED" + status = yellow(self.status.upper()) + else: + info = "OK created" + status = green(self.status) + + msg = f"{info} {self.description}" + return format_fancy_output_line( + msg=msg, + status=status, + index=self.batch_index, + total=self.total_batches, + execution_time=self.execution_time, + progress_prefix="Batch", + ) + + # ======================================================= # W - Node testing # =======================================================