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

merge nov 20th - include custom cmd advanced ci #6346

Merged
merged 37 commits into from
Nov 20, 2024
Merged
Show file tree
Hide file tree
Changes from 10 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
f6d9ce5
add optimization tip
mirnawong1 Oct 23, 2024
b47f065
Update ci-jobs.md
mirnawong1 Oct 23, 2024
3cd60d5
Update website/docs/docs/deploy/job-commands.md
mirnawong1 Oct 23, 2024
7c9ccb2
reuben's updates
mirnawong1 Oct 23, 2024
5eaa38b
update
mirnawong1 Oct 23, 2024
1d8f8b6
update header
mirnawong1 Oct 23, 2024
f104df6
Update website/docs/docs/deploy/job-commands.md
mirnawong1 Oct 23, 2024
be7c9d1
Update website/docs/docs/deploy/job-commands.md
mirnawong1 Oct 23, 2024
0c3b983
add url img
mirnawong1 Oct 23, 2024
ff8c1df
Merge branch 'current' into custom-commands
mirnawong1 Oct 24, 2024
ee552c5
Merge branch 'current' into custom-commands
mirnawong1 Oct 28, 2024
169fcd7
Update website/docs/docs/deploy/ci-jobs.md
mirnawong1 Oct 28, 2024
5a6ed0c
Update website/docs/docs/deploy/ci-jobs.md
mirnawong1 Oct 28, 2024
c7f6ac3
Merge branch 'current' into custom-commands
mirnawong1 Oct 29, 2024
58548ee
Merge branch 'current' into custom-commands
mirnawong1 Oct 29, 2024
d7a8fab
Merge branch 'current' into custom-commands
mirnawong1 Oct 30, 2024
44a9a40
Update website/docs/docs/deploy/ci-jobs.md
mirnawong1 Oct 30, 2024
a0e441e
add rn
mirnawong1 Oct 30, 2024
00ceba8
Update website/docs/docs/deploy/job-commands.md
mirnawong1 Nov 4, 2024
ccbef51
Update website/docs/docs/dbt-versions/release-notes.md
mirnawong1 Nov 4, 2024
bbb849c
Merge branch 'current' into custom-commands
mirnawong1 Nov 4, 2024
bb4dd65
add more context
mirnawong1 Nov 4, 2024
6c42ac6
Merge branch 'custom-commands' of github.com:dbt-labs/docs.getdbt.com…
mirnawong1 Nov 4, 2024
4acdd94
Merge branch 'current' into custom-commands
mirnawong1 Nov 4, 2024
e0677f5
Merge branch 'current' into custom-commands
mirnawong1 Nov 4, 2024
1b7347e
Merge branch 'current' into custom-commands
mirnawong1 Nov 4, 2024
17e974a
Update job-commands.md
mirnawong1 Nov 5, 2024
bb435ae
Merge branch 'current' into custom-commands
mirnawong1 Nov 5, 2024
87429f3
add img
mirnawong1 Nov 5, 2024
343cf10
add link
mirnawong1 Nov 5, 2024
b9bc16e
Merge branch 'current' into custom-commands
mirnawong1 Nov 18, 2024
047257b
Merge branch 'current' into custom-commands
mirnawong1 Nov 19, 2024
4a7775f
Update website/docs/docs/deploy/ci-jobs.md
mirnawong1 Nov 19, 2024
e785c3c
Merge branch 'current' into custom-commands
mirnawong1 Nov 19, 2024
c107a90
Merge branch 'current' into custom-commands
mirnawong1 Nov 20, 2024
7258c4e
Update website/docs/docs/dbt-versions/release-notes.md
mirnawong1 Nov 20, 2024
3cfc130
Merge branch 'current' into custom-commands
mirnawong1 Nov 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions website/docs/docs/deploy/advanced-ci.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ title: "Advanced CI"
id: "advanced-ci"
sidebar_label: "Advanced CI"
description: "Advanced CI enables developers to compare changes by demonstrating the changes the code produces."
image: /img/docs/dbt-cloud/example-ci-compare-changes-tab.png
---

# Advanced CI <Lifecycle status="enterprise"/>
Expand Down
18 changes: 11 additions & 7 deletions website/docs/docs/deploy/ci-jobs.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,7 @@ description: "Learn how to create and set up CI checks to test code changes befo

You can set up [continuous integration](/docs/deploy/continuous-integration) (CI) jobs to run when someone opens a new pull request (PR) in your dbt Git repository. By running and testing only _modified_ models, dbt Cloud ensures these jobs are as efficient and resource conscientious as possible on your data platform.

## Set up CI jobs {#set-up-ci-jobs}

dbt Labs recommends that you create your CI job in a dedicated dbt Cloud [deployment environment](/docs/deploy/deploy-environments#create-a-deployment-environment) that's connected to a staging database. Having a separate environment dedicated for CI will provide better isolation between your temporary CI schema builds and your production data builds. Additionally, sometimes teams need their CI jobs to be triggered when a PR is made to a branch other than main. If your team maintains a staging branch as part of your release process, having a separate environment will allow you to set a [custom branch](/faqs/Environments/custom-branch-settings) and, accordingly, the CI job in that dedicated environment will be triggered only when PRs are made to the specified custom branch. To learn more, refer to [Get started with CI tests](/guides/set-up-ci).

### Prerequisites
## Prerequisites
- You have a dbt Cloud account.
- CI features:
- For both the [concurrent CI checks](/docs/deploy/continuous-integration#concurrent-ci-checks) and [smart cancellation of stale builds](/docs/deploy/continuous-integration#smart-cancellation) features, your dbt Cloud account must be on the [Team or Enterprise plan](https://www.getdbt.com/pricing/).
Expand All @@ -20,6 +16,9 @@ dbt Labs recommends that you create your CI job in a dedicated dbt Cloud [deploy
- Set up a [connection with your Git provider](/docs/cloud/git/git-configuration-in-dbt-cloud). This integration lets dbt Cloud run jobs on your behalf for job triggering.
- If you're using a native [GitLab](/docs/cloud/git/connect-gitlab) integration, you need a paid or self-hosted account that includes support for GitLab webhooks and [project access tokens](https://docs.gitlab.com/ee/user/project/settings/project_access_tokens.html). If you're using GitLab Free, merge requests will trigger CI jobs but CI job status updates (success or failure of the job) will not be reported back to GitLab.

## Set up CI jobs {#set-up-ci-jobs}

dbt Labs recommends that you create your CI job in a dedicated dbt Cloud [deployment environment](/docs/deploy/deploy-environments#create-a-deployment-environment) that's connected to a staging database. Having a separate environment dedicated for CI will provide better isolation between your temporary CI schema builds and your production data builds. Additionally, sometimes teams need their CI jobs to be triggered when a PR is made to a branch other than main. If your team maintains a staging branch as part of your release process, having a separate environment will allow you to set a [custom branch](/faqs/Environments/custom-branch-settings) and, accordingly, the CI job in that dedicated environment will be triggered only when PRs are made to the specified custom branch. To learn more, refer to [Get started with CI tests](/guides/set-up-ci).

To make CI job creation easier, many options on the **CI job** page are set to default values that dbt Labs recommends that you use. If you don't want to use the defaults, you can change them.

Expand All @@ -38,8 +37,13 @@ To make CI job creation easier, many options on the **CI job** page are set to d
- **Commands** &mdash; By default, it includes the `dbt build --select state:modified+` command. This informs dbt Cloud to build only new or changed models and their downstream dependents. Importantly, state comparison can only happen when there is a deferred environment selected to compare state to. Click **Add command** to add more [commands](/docs/deploy/job-commands) that you want to be invoked when this job runs.
- **Linting**<Lifecycle status="beta" /> &mdash; Enable this option for dbt to [lint the SQL files](/docs/deploy/continuous-integration#sql-linting) in your project as the first step in `dbt run`. If this check runs into an error, dbt can either **Fail job run** or **Continue running job**.
- **Run compare changes**<Lifecycle status="enterprise" /> &mdash; Enable this option to compare the last applied state of the production environment (if one exists) with the latest changes from the pull request, and identify what those differences are. To enable record-level comparison and primary key analysis, you must add a [primary key constraint](/reference/resource-properties/constraints) or [uniqueness test](/reference/resource-properties/data-tests#unique). Otherwise, you'll receive a "Primary key missing" error message in dbt Cloud.

To review the comparison report, navigate to the [Compare tab](/docs/deploy/run-visibility#compare-tab) in the job run's details. A summary of the report is also available from the pull request in your Git provider (see the [CI report example](#example-ci-report)).

:::info Optimization tip
When you enable the **Run compare changes** checkbox, you can customize the comparison command to optimize your CI job. For example, if you have large models that take a long time to compare, you can exclude them to speed up the process using the `--exclude` flag. Use [custom commands](/docs/deploy/job-commands#advanced-ci-compare-changes) to modify the selection criteria.
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved
:::
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved

- **Compare changes against an environment (Deferral)** &mdash; By default, it’s set to the **Production** environment if you created one. This option allows dbt Cloud to check the state of the code in the PR against the code running in the deferred environment, so as to only check the modified code, instead of building the full table or the entire DAG.

:::info
Expand All @@ -49,7 +53,7 @@ To make CI job creation easier, many options on the **CI job** page are set to d
- **Run timeout** &mdash; Cancel the CI job if the run time exceeds the timeout value. You can use this option to help ensure that a CI check doesn't consume too much of your warehouse resources. If you enable the **Run compare changes** option, the timeout value defaults to `3600` (one hour) to prevent long-running comparisons.


1. (optional) Options in the **Advanced settings** section:
2. (optional) Options in the **Advanced settings** section:
- **Environment variables** &mdash; Define [environment variables](/docs/build/environment-variables) to customize the behavior of your project when this CI job runs. You can specify that a CI job is running in a _Staging_ or _CI_ environment by setting an environment variable and modifying your project code to behave differently, depending on the context. It's common for teams to process only a subset of data for CI runs, using environment variables to branch logic in their dbt project code.
- **Target name** &mdash; Define the [target name](/docs/build/custom-target-names). Similar to **Environment Variables**, this option lets you customize the behavior of the project. You can use this option to specify that a CI job is running in a _Staging_ or _CI_ environment by setting the target name and modifying your project code to behave differently, depending on the context.
- **dbt version** &mdash; By default, it’s set to inherit the [dbt version](/docs/dbt-versions/core) from the environment. dbt Labs strongly recommends that you don't change the default setting. This option to change the version at the job level is useful only when you upgrade a project to the next dbt version; otherwise, mismatched versions between the environment and job can lead to confusing behavior.
Expand Down
15 changes: 12 additions & 3 deletions website/docs/docs/deploy/job-commands.md
Original file line number Diff line number Diff line change
Expand Up @@ -42,14 +42,23 @@ For every job, you have the option to select the [Generate docs on run](/docs/co

You can add or remove as many dbt commands as necessary for every job. However, you need to have at least one dbt command. There are few commands listed as "dbt Cloud CLI" or "dbt Core" in the [dbt Command reference page](/reference/dbt-commands) page. This means they are meant for use in dbt Core or dbt Cloud CLI, and not in dbt Cloud IDE.


:::tip Using selectors

Use [selectors](/reference/node-selection/syntax) as a powerful way to select and execute portions of your project in a job run. For example, to run tests for one_specific_model, use the selector: `dbt test --select one_specific_model`. The job will still run if a selector doesn't match any models.
Use [selectors](/reference/node-selection/syntax) as a powerful way to select and execute portions of your project in a job run. For example, to run tests for one _specific_ model, use the selector: `dbt test --select one_specific_model`. The job will still run if a selector doesn't match any models.
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved

:::

**Job outcome** &mdash; During a job run, the commands are "chained" together and executed as run steps. If one of the run steps in the chain fails, then the subsequent steps aren't executed, and the job will fail.
#### Compare changes custom commands

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree this would be a good place to add a screenshot. We should have one available from the product next week once eng has it built.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

will ask @mikaylacrawford for screenshot nxt week

For users that have Advanced CI's [compare changes](/docs/deploy/advanced-ci#compare-changes) feature enabled, you can use a custom dbt syntax to exclude specific large models (or groups of models with tags) to optimize running the comparison. Running comparisons on large models can significantly increase the time it takes for CI jobs to complete.

Here are some examples of how you can customize the comparison command:
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved

- To exclude the large `fct_orders` model from the comparison, use the `--select state:modified --exclude fct_orders` syntax.
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved
- To exclude models based on tags, use `--select state modified --exclude tag:tagname_a tag:tagname_b`.
- To include models that were directly modified and also those one step downstream, use `--select state:modified+1`.
mirnawong1 marked this conversation as resolved.
Show resolved Hide resolved

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@joellabes are there any other examples you would list here?


#### Job outcome
During a job run, the commands are "chained" together and executed as run steps. If one of the run steps in the chain fails, then the subsequent steps aren't executed, and the job will fail.

In the following example image, the first four run steps are successful. However, if the fifth run step (`dbt run --select state:modified+ --full-refresh --fail-fast`) fails, then the next run steps aren't executed, and the entire job fails. The failed job returns a non-zero [exit code](/reference/exit-codes) and "Error" job status:

Expand Down
Loading