Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rephrase the two criteria for resolving ref calls with the --defer flag #6660

Merged
merged 7 commits into from
Dec 13, 2024
11 changes: 6 additions & 5 deletions website/docs/reference/node-selection/defer.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,11 +29,12 @@ dbt test --models [...] --defer --state path/to/artifacts

</VersionBlock>

When the `--defer` flag is provided, dbt will resolve `ref` calls differently depending on two criteria:
1. Is the referenced node included in the model selection criteria of the current run?
2. Does the referenced node exist as a database object in the current environment?
By default, dbt uses the [`target`](/reference/dbt-jinja-functions/target) namespace to resolve `ref` calls.

If the answer to both is **no**—a node is not included _and_ it does not exist as a database object in the current environment—references to it will use the other namespace instead, provided by the state manifest.
When `--defer` is enabled, dbt resolves ref calls using the state manifest instead, but only if:

1. The node isn’t in the selected nodes **and**
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved
2. It doesn’t exist in the database (or `--favor-state` is used).

Ephemeral models are never deferred, since they serve as "passthroughs" for other `ref` calls.

Expand All @@ -46,7 +47,7 @@ Deferral requires both `--defer` and `--state` to be set, either by passing flag

#### Favor state

You can optionally skip the second criterion by passing the `--favor-state` flag. If passed, dbt will favor using the node defined in your `--state` namespace, even if the node exists in the current target.
If `--favor-state` is passed, dbt will favor the node definition from the `--state` directory, _unless_ that node is also included among the selected nodes.
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved

### Example

Expand Down
Loading