Project Config#
The cosmos.config.ProjectConfig
allows you to specify information about where your dbt project is located and project
variables that should be used for rendering and execution. It takes the following arguments:
dbt_project_path
: The full path to your dbt project. This directory should have adbt_project.yml
filemodels_relative_path
: The path to your models directory, relative to thedbt_project_path
. This defaults tomodels/
seeds_relative_path
: The path to your seeds directory, relative to thedbt_project_path
. This defaults todata/
snapshots_relative_path
: The path to your snapshots directory, relative to thedbt_project_path
. This defaults tosnapshots/
manifest_path
: The absolute path to your manifests directory. This is only required if you’re using Cosmos’ manifest parsing modeproject_name
: The name of the project. Ifdbt_project_path
is provided, theproject_name
defaults to the folder name containingdbt_project.yml
. Ifdbt_project_path
is not provided, andmanifest_path
is provided,project_name
is required as the name can not be inferred fromdbt_project_path
dbt_vars
: (new in v1.3) A dictionary of dbt variables for the project rendering and execution. This argument overrides variables defined in the dbt_project.yml file. The dictionary of variables is dumped to a yaml string and passed to dbt commands as the –vars argument. Variables are only supported for rendering when usingRenderConfig.LoadMode.DBT_LS
andRenderConfig.LoadMode.CUSTOM
load mode. Variables using Airflow templating will only be rendered at execution time, not at render time.env_vars
: (new in v1.3) A dictionary of environment variables used for rendering and execution. Rendering with env vars is only supported when usingRenderConfig.LoadMode.DBT_LS
load mode.partial_parse
: (new in v1.4) If True, then attempt to use thepartial_parse.msgpack
if it exists. This is only used for theLoadMode.DBT_LS
load mode, and for theExecutionMode.LOCAL
andExecutionMode.VIRTUALENV
execution modes. Due to the way that dbt partial parsing works, it does not work with Cosmos profile mapping classes. To benefit from this feature, users have to set theprofiles_yml_filepath
argument inProfileConfig
.
Project Config Example#
from cosmos.config import ProjectConfig
config = ProjectConfig(
dbt_project_path="/path/to/dbt/project",
models_relative_path="models",
seeds_relative_path="data",
snapshots_relative_path="snapshots",
manifest_path="/path/to/manifests",
env_vars={"MY_ENV_VAR": "my_env_value"},
dbt_vars={
"my_dbt_var": "my_value",
"start_time": "{{ data_interval_start.strftime('%Y%m%d%H%M%S') }}",
"end_time": "{{ data_interval_end.strftime('%Y%m%d%H%M%S') }}",
},
)