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

Resolve variables in a loop #2164

Merged
merged 9 commits into from
Jan 16, 2025
Merged

Resolve variables in a loop #2164

merged 9 commits into from
Jan 16, 2025

Conversation

denik
Copy link
Contributor

@denik denik commented Jan 16, 2025

Changes

Tests

Existing tests, new regression tests.

These tests already passed before, added for completeness:

  • acceptance/bundle/variables/cycle
  • acceptance/bundle/variables/complex-cross-ref

@@ -13,15 +14,22 @@ import (
"github.com/databricks/cli/libs/dyn/dynvar"
)

const maxResolutionRounds = 100
Copy link
Contributor

Choose a reason for hiding this comment

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

I'm not sure if we really should support this, it looks like all configurations can be refactored into 2 level deep anyways. Maybe warning about more deep nesting instead ?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I think it's easier to support this than explain why only 2 levels.

Base automatically changed from denik/complex-vars-3 to main January 16, 2025 12:21
@denik denik requested a review from andrewnester January 16, 2025 12:23
@denik denik force-pushed the denik/complex-vars-loop branch from 12aa6bc to 154a4bf Compare January 16, 2025 12:32
@denik denik temporarily deployed to test-trigger-is January 16, 2025 12:32 — with GitHub Actions Inactive
@@ -1,3 +1,3 @@
{
"spark.databricks.sql.initial.catalog.name": "${var.catalog}"
Copy link
Contributor

Choose a reason for hiding this comment

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

Can you add a test for cases when there are nested cycle dependencies?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

See acceptance/bundle/variables/complex-cycle/databricks.yml

}

if round >= maxResolutionRounds-1 {
diags = diags.Append(diag.Diagnostic{
Copy link
Contributor

Choose a reason for hiding this comment

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

shall we break here as well?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Well it's the last stmt in the last loop iteration, so it does not matter.

Copy link
Contributor

Choose a reason for hiding this comment

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

it's not necessarily last one if I pass extraRounds bigger than maxResolutionRounds

Copy link
Contributor Author

Choose a reason for hiding this comment

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

good catch! it's a bug. c3ac311

@denik denik temporarily deployed to test-trigger-is January 16, 2025 12:44 — with GitHub Actions Inactive
name: cycle

variables:
a:
Copy link
Contributor

@andrewnester andrewnester Jan 16, 2025

Choose a reason for hiding this comment

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

I meant a deeper level of nesting for cycle :) something like


variables:
  a:
    default: ${var.complex.a}
  b:
    default: ${var.a}
  c: 
    default: ${var.b}
  complex:
    default: 
        a: ${var.c}
        b: foo

maxRounds vs test time
 9          0.10s
10          0.13s
11          0.27s
12          0.68s
13          1.98s
14          6.28s
15         21.70s
16         78.16s

~/work/cli/acceptance/bundle/variables/complex-cycle % time testme
+ go test ../../.. -v -run ^TestAccept$/^bundle$/^variables$/^complex-cycle$
=== RUN   TestAccept
    acceptance_test.go:289: [go build -mod vendor -o /Users/denis.bilenko/work/cli/acceptance/build/databricks] took 459.577542ms
    acceptance_test.go:64: $TMPHOME=/var/folders/5y/9kkdnjw91p11vsqwk0cvmk200000gp/T/TestAccept3684472427/001
=== RUN   TestAccept/bundle/variables/complex-cycle
=== PAUSE TestAccept/bundle/variables/complex-cycle
=== CONT  TestAccept/bundle/variables/complex-cycle
    acceptance_test.go:212:
                Error Trace:    /Users/denis.bilenko/work/cli/libs/testdiff/testdiff.go:24
                                                        /Users/denis.bilenko/work/cli/acceptance/acceptance_test.go:212
                                                        /Users/denis.bilenko/work/cli/acceptance/acceptance_test.go:162
                                                        /Users/denis.bilenko/work/cli/acceptance/acceptance_test.go:100
                Error:          Not equal:
                                expected: "Warning: Detected unresolved variables after 12 resolution rounds\n\nName: cycle\nTarget: default\nWorkspace:\n  User: $USERNAME\n  Path: /Workspace/Users/$USERNAME/.bundle/cycle/default\n\nFound 1 warning\n"
                                actual  : "Warning: Detected unresolved variables after 14 resolution rounds\n\nName: cycle\nTarget: default\nWorkspace:\n  User: $USERNAME\n  Path: /Workspace/Users/$USERNAME/.bundle/cycle/default\n\nFound 1 warning\n"

                                Diff:
                                --- Expected
                                +++ Actual
                                @@ -1,2 +1,2 @@
                                -Warning: Detected unresolved variables after 12 resolution rounds
                                +Warning: Detected unresolved variables after 14 resolution rounds

                Test:           TestAccept/bundle/variables/complex-cycle
                Messages:       bundle/variables/complex-cycle/output.txt vs script output
--- FAIL: TestAccept (0.93s)
    --- FAIL: TestAccept/bundle/variables/complex-cycle (6.28s)
FAIL
FAIL    github.com/databricks/cli/acceptance    7.585s
FAIL
testme  14.04s user 7.50s system 257% cpu 8.370 total
@denik denik temporarily deployed to test-trigger-is January 16, 2025 13:06 — with GitHub Actions Inactive
@@ -13,15 +14,22 @@ import (
"github.com/databricks/cli/libs/dyn/dynvar"
)

const maxResolutionRounds = 12
Copy link
Contributor

Choose a reason for hiding this comment

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

Can you add a comment why 12? It might not be obvious for someone reading the code later

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Added a comment

@denik denik temporarily deployed to test-trigger-is January 16, 2025 13:14 — with GitHub Actions Inactive
@denik denik temporarily deployed to test-trigger-is January 16, 2025 13:21 — with GitHub Actions Inactive
On CI timings for complex-cycle are worse than my laptop (for 12 rounds):

ubuntu: acceptance.TestAccept/bundle/variables/complex-cycle (2.57s)
mac: acceptance.TestAccept/bundle/variables/complex-cycle (1.54s)
windows: acceptance.TestAccept/bundle/variables/complex-cycle (2.80s)
@denik denik temporarily deployed to test-trigger-is January 16, 2025 13:25 — with GitHub Actions Inactive
@denik denik temporarily deployed to test-trigger-is January 16, 2025 13:30 — with GitHub Actions Inactive
@denik denik temporarily deployed to test-trigger-is January 16, 2025 13:48 — with GitHub Actions Inactive
@denik
Copy link
Contributor Author

denik commented Jan 16, 2025

After changing to 11 rounds, times on CI:

ubuntu: acceptance.TestAccept/bundle/variables/complex-cycle (1.28s)
mac: acceptance.TestAccept/bundle/variables/complex-cycle (0.64s)
win: acceptance.TestAccept/bundle/variables/complex-cycle (1.65s)

with 12 it was:
ubuntu: acceptance.TestAccept/bundle/variables/complex-cycle (2.57s)
mac: acceptance.TestAccept/bundle/variables/complex-cycle (1.54s)
windows: acceptance.TestAccept/bundle/variables/complex-cycle (2.80s)

@denik denik added this pull request to the merge queue Jan 16, 2025
Merged via the queue into main with commit 2e70558 Jan 16, 2025
9 checks passed
@denik denik deleted the denik/complex-vars-loop branch January 16, 2025 14:45
andrewnester added a commit that referenced this pull request Jan 16, 2025
New feature announcement.

You can now manage Databricks Apps using DABs by defining an `app` resource in your bundle configuration.
For more information see Databricks documentation https://docs.databricks.com/en/dev-tools/bundles/resources.html#app

CLI:
 * Filter out system clusters in cluster picker ([#2131](#2131)).
 * Process all the fields in top level request object even if it contains request body ([#2155](#2155)).

Bundles:
 * Added support for Databricks Apps in DABs ([#1928](#1928)).
 * Allow artifact path to be located outside the sync root ([#2128](#2128)).
 * Retry app deployment if there is an active deployment in progress ([#2153](#2153)).
 * Resolve variables in a loop ([#2164](#2164)).
 * Improve resolution of complex variables within complex variables ([#2157](#2157)).
 * Added output message to warn about slower deployments with apps ([#2161](#2161)).
 * Patch references to UC schemas to capture dependencies automatically ([#1989](#1989)).
 * Format default-python template ([#2110](#2110)).
 * Encourage the use of root_path in production to ensure single deployment ([#1712](#1712)).
 * Log warnings to stderr for "bundle validate -o json" ([#2109](#2109)).

Internal:
 * Move merge fix-ups after variable resolution ([#2125](#2125)).
 * Enable linter 'unconvert' and fix the issues found ([#2136](#2136)).
 * Coverage for acceptance tests ([#2123](#2123)).
 * Add acceptance tests for builtin templates ([#2135](#2135)).
 * Add a unique schema for recreate pipeline test ([#2159](#2159)).
 * Migrate resolution tests to acceptance tests ([#2143](#2143)).
 * Update runner for the publish-winget job ([#2105](#2105)).
 * Add a test for complex variable resolution with 3 levels ([#2163](#2163)).

API Changes:
 * Changed `databricks account federation-policy update` command with new required argument order.
 * Changed `databricks account service-principal-federation-policy update` command with new required argument order.

OpenAPI commit 779817ed8d63031f5ea761fbd25ee84f38feec0d (2025-01-08)
Dependency updates:
 * Upgrade TF provider to 1.63.0 ([#2162](#2162)).
 * Bump golangci-lint version to v1.63.4 from v1.63.1 ([#2114](#2114)).
 * Bump astral-sh/setup-uv from 4 to 5 ([#2116](#2116)).
 * Bump golang.org/x/oauth2 from 0.24.0 to 0.25.0 ([#2080](#2080)).
 * Bump github.com/hashicorp/hc-install from 0.9.0 to 0.9.1 ([#2079](#2079)).
 * Bump golang.org/x/term from 0.27.0 to 0.28.0 ([#2078](#2078)).
 * Bump github.com/databricks/databricks-sdk-go from 0.54.0 to 0.55.0 ([#2126](#2126)).
github-merge-queue bot pushed a commit that referenced this pull request Jan 16, 2025
### New feature announcement

#### Databricks Apps support

You can now manage Databricks Apps using DABs by defining an `app`
resource in your bundle configuration.
For more information see Databricks documentation
https://docs.databricks.com/en/dev-tools/bundles/resources.html#app

#### Referencing complex variables in complex variables

You can now reference complex variables within other complex variables.
For more details see #2157

CLI:
* Filter out system clusters in cluster picker
([#2131](#2131)).
* Add command line flags for fields that are not in the API request body
([#2155](#2155)).

Bundles:
* Added support for Databricks Apps in DABs
([#1928](#1928)).
* Allow artifact path to be located outside the sync root
([#2128](#2128)).
* Retry app deployment if there is an active deployment in progress
([#2153](#2153)).
* Resolve variables in a loop
([#2164](#2164)).
* Improve resolution of complex variables within complex variables
([#2157](#2157)).
* Added output message to warn about slower deployments with apps
([#2161](#2161)).
* Patch references to UC schemas to capture dependencies automatically
([#1989](#1989)).
* Format default-python template
([#2110](#2110)).
* Encourage the use of root_path in production to ensure single
deployment ([#1712](#1712)).
* Log warnings to stderr for "bundle validate -o json"
([#2109](#2109)).

API Changes:
* Changed `databricks account federation-policy update` command with new
required argument order.
* Changed `databricks account service-principal-federation-policy
update` command with new required argument order.

OpenAPI commit 779817ed8d63031f5ea761fbd25ee84f38feec0d (2025-01-08)
Dependency updates:
* Upgrade TF provider to 1.63.0
([#2162](#2162)).
* Bump golangci-lint version to v1.63.4 from v1.63.1
([#2114](#2114)).
* Bump astral-sh/setup-uv from 4 to 5
([#2116](#2116)).
* Bump golang.org/x/oauth2 from 0.24.0 to 0.25.0
([#2080](#2080)).
* Bump github.com/hashicorp/hc-install from 0.9.0 to 0.9.1
([#2079](#2079)).
* Bump golang.org/x/term from 0.27.0 to 0.28.0
([#2078](#2078)).
* Bump github.com/databricks/databricks-sdk-go from 0.54.0 to 0.55.0
([#2126](#2126)).

---------

Co-authored-by: shreyas-goenka <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants