From 51ff85bb2d4c50cb0f2877c4fd876fb770ea6350 Mon Sep 17 00:00:00 2001 From: Emily Rockman Date: Thu, 20 Jun 2024 14:02:28 -0500 Subject: [PATCH] Support DIFF as a recording mode (#10263) * add diffing * WIP * change file name * Update core/dbt/cli/requires.py --- core/dbt/cli/requires.py | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/core/dbt/cli/requires.py b/core/dbt/cli/requires.py index 01425d8db9b..892705d9b0c 100644 --- a/core/dbt/cli/requires.py +++ b/core/dbt/cli/requires.py @@ -45,6 +45,7 @@ Recorder, RecorderMode, get_record_mode_from_env, + get_record_types_from_dict, get_record_types_from_env, ) from dbt_common.utils import cast_dict_to_dict_of_strings @@ -110,8 +111,17 @@ def setup_record_replay(): recorder: Optional[Recorder] = None if rec_mode == RecorderMode.REPLAY: - recording_path = os.environ.get("DBT_RECORDER_FILE_PATH") - recorder = Recorder(RecorderMode.REPLAY, types=rec_types, recording_path=recording_path) + previous_recording_path = os.environ.get("DBT_RECORDER_FILE_PATH") + recorder = Recorder( + RecorderMode.REPLAY, types=rec_types, previous_recording_path=previous_recording_path + ) + elif rec_mode == RecorderMode.DIFF: + previous_recording_path = os.environ.get("DBT_RECORDER_FILE_PATH") + # ensure types match the previous recording + types = get_record_types_from_dict(previous_recording_path) + recorder = Recorder( + RecorderMode.DIFF, types=types, previous_recording_path=previous_recording_path + ) elif rec_mode == RecorderMode.RECORD: recorder = Recorder(RecorderMode.RECORD, types=rec_types) @@ -122,7 +132,10 @@ def tear_down_record_replay(): recorder = get_invocation_context().recorder if recorder is not None: if recorder.mode == RecorderMode.RECORD: - recorder.write("recording.json") + recorder.write() + if recorder.mode == RecorderMode.DIFF: + recorder.write() + recorder.write_diffs(diff_file_name="recording_diffs.json") elif recorder.mode == RecorderMode.REPLAY: recorder.write_diffs("replay_diffs.json")