From 068e065893c55e4c7b41570b10969eda43f889d4 Mon Sep 17 00:00:00 2001 From: salim_moulouel Date: Mon, 26 Feb 2024 13:30:55 +0100 Subject: [PATCH] support dbt-core between 1.7.0 to 1.7.8 --- projects/adapter/src/dbt/adapters/fal/__version__.py | 2 +- .../src/dbt/adapters/fal_experimental/__version__.py | 2 +- projects/adapter/src/fal/dbt/cli/fal_runner.py | 4 ++++ projects/adapter/src/fal/dbt/integration/parse.py | 4 ++-- projects/adapter/src/fal/dbt/integration/project.py | 8 +++++++- 5 files changed, 15 insertions(+), 5 deletions(-) diff --git a/projects/adapter/src/dbt/adapters/fal/__version__.py b/projects/adapter/src/dbt/adapters/fal/__version__.py index 1340d2b535..6477de0c57 100644 --- a/projects/adapter/src/dbt/adapters/fal/__version__.py +++ b/projects/adapter/src/dbt/adapters/fal/__version__.py @@ -1 +1 @@ -version = '1.5.10a0' +version = '1.7.10a0' diff --git a/projects/adapter/src/dbt/adapters/fal_experimental/__version__.py b/projects/adapter/src/dbt/adapters/fal_experimental/__version__.py index 1340d2b535..6477de0c57 100644 --- a/projects/adapter/src/dbt/adapters/fal_experimental/__version__.py +++ b/projects/adapter/src/dbt/adapters/fal_experimental/__version__.py @@ -1 +1 @@ -version = '1.5.10a0' +version = '1.7.10a0' diff --git a/projects/adapter/src/fal/dbt/cli/fal_runner.py b/projects/adapter/src/fal/dbt/cli/fal_runner.py index 63365249a9..f8bce7cd68 100644 --- a/projects/adapter/src/fal/dbt/cli/fal_runner.py +++ b/projects/adapter/src/fal/dbt/cli/fal_runner.py @@ -14,8 +14,11 @@ def create_fal_dbt( args: argparse.Namespace, generated_models: Dict[str, Path] = {} ) -> FalDbt: real_state = None + real_defer_state = None if hasattr(args, "state") and args.state is not None: real_state = args.state + if hasattr(args, "real_defer_state") and args.defer_state is not None: + real_defer_state = args.state return FalDbt( args.project_dir, @@ -25,6 +28,7 @@ def create_fal_dbt( args.selector, args.threads, real_state, + real_defer_state, args.target, args.vars, generated_models, diff --git a/projects/adapter/src/fal/dbt/integration/parse.py b/projects/adapter/src/fal/dbt/integration/parse.py index ba211bb041..1c999ac2bf 100644 --- a/projects/adapter/src/fal/dbt/integration/parse.py +++ b/projects/adapter/src/fal/dbt/integration/parse.py @@ -5,7 +5,7 @@ from typing import Any, List, Dict, Optional, Union, TYPE_CHECKING from dbt.contracts.project import Project as ProjectContract -from dbt.config import RuntimeConfig, Project +from dbt.config import RuntimeConfig, Project, PartialProject from dbt.config.utils import parse_cli_vars as dbt_parse_cli_vars from dbt.contracts.graph.manifest import Manifest from dbt.contracts.results import RunResultsArtifact, FreshnessExecutionResultArtifact @@ -47,7 +47,7 @@ class RuntimeArgs: def load_dbt_project_contract(project_dir: str) -> ProjectContract: - partial_project = Project.partial_load(project_dir) + partial_project = PartialProject.from_project_root(project_dir) contract = ProjectContract.from_dict(partial_project.project_dict) if not hasattr(contract, "model_paths") or contract.model_paths is None: setattr(contract, "model_paths", contract.source_paths) diff --git a/projects/adapter/src/fal/dbt/integration/project.py b/projects/adapter/src/fal/dbt/integration/project.py index 71d4228c34..38725ed6be 100644 --- a/projects/adapter/src/fal/dbt/integration/project.py +++ b/projects/adapter/src/fal/dbt/integration/project.py @@ -436,6 +436,7 @@ class CompileArgs: models: List[str] exclude: Tuple[str] state: Optional[Path] + defer_state: Optional[Path] single_threaded: Optional[bool] @@ -453,6 +454,7 @@ def __init__( selector: Optional[str] = None, threads: Optional[int] = None, state: Optional[str] = None, + defer_state: Optional[str] = None, profile_target: Optional[str] = None, args_vars: str = "{}", generated_models: Dict[str, Path] = {}, @@ -485,9 +487,13 @@ def __init__( self.profiles_dir = flags.PROFILES_DIR self._state = None + self._defer_state = None if state is not None: self._state = Path(os.path.realpath(os.path.expanduser(state))) + if defer_state is not None: + self._defer_state = Path(os.path.realpath(os.path.expanduser(defer_state))) + self.scripts_dir = parse.get_scripts_dir(self.project_dir, args_vars) @@ -525,7 +531,7 @@ def __init__( # Necessary for manifest loading to not fail # dbt.tracking.initialize_tracking(self.profiles_dir) - args = CompileArgs(selector, select, select, exclude, self._state, None) + args = CompileArgs(selector, select, select, exclude, self._state, self._defer_state, None) self._compile_task = CompileTask(args, self._config, native_manifest) self._compile_task._runtime_initialize()