Skip to content

Commit

Permalink
Added Unit Test support for plugin framework
Browse files Browse the repository at this point in the history
  • Loading branch information
tanmay-db committed Aug 15, 2024
1 parent d76955e commit 0abb9b4
Show file tree
Hide file tree
Showing 110 changed files with 717 additions and 378 deletions.
2 changes: 1 addition & 1 deletion internal/acceptance/acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ func TestRunningRealTerraformWithFixtureBackend(t *testing.T) {
t.Setenv("DATABRICKS_HOST", client.Config.Host)
t.Setenv("DATABRICKS_TOKEN", client.Config.Token)

workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `resource "databricks_token" "this" {
lifetime_seconds = 6000
comment = "Testing token"
Expand Down
4 changes: 2 additions & 2 deletions internal/acceptance/account_rule_set_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ func getServicePrincipalResource(t *testing.T) string {
func TestMwsAccAccountServicePrincipalRuleSetsFullLifeCycle(t *testing.T) {
loadAccountEnv(t)
spResource := getServicePrincipalResource(t)
accountLevel(t, step{
accountLevel(t, LegacyStep{
Template: spResource + `
resource "databricks_group" "this" {
display_name = "Group {var.RANDOM}"
Expand Down Expand Up @@ -69,7 +69,7 @@ func TestMwsAccAccountServicePrincipalRuleSetsFullLifeCycle(t *testing.T) {

func TestMwsAccAccountGroupRuleSetsFullLifeCycle(t *testing.T) {
username := qa.RandomEmail()
accountLevel(t, step{
accountLevel(t, LegacyStep{
Template: `
resource "databricks_user" "this" {
user_name = "` + username + `"
Expand Down
2 changes: 1 addition & 1 deletion internal/acceptance/artifact_allowlist_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import (
)

func TestUcAccArtifactAllowlistResourceFullLifecycle(t *testing.T) {
unityWorkspaceLevel(t, step{
unityWorkspaceLevel(t, LegacyStep{
Template: `
resource "databricks_artifact_allowlist" "init" {
artifact_type = "INIT_SCRIPT"
Expand Down
16 changes: 8 additions & 8 deletions internal/acceptance/catalog_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import (

func TestUcAccCatalog(t *testing.T) {
loadUcwsEnv(t)
unityWorkspaceLevel(t, step{
unityWorkspaceLevel(t, LegacyStep{
Template: fmt.Sprintf(`
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.RANDOM}"
Expand All @@ -21,7 +21,7 @@ func TestUcAccCatalog(t *testing.T) {
}

func TestUcAccCatalogIsolated(t *testing.T) {
unityWorkspaceLevel(t, step{
unityWorkspaceLevel(t, LegacyStep{
Template: `
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.STICKY_RANDOM}"
Expand All @@ -30,7 +30,7 @@ func TestUcAccCatalogIsolated(t *testing.T) {
purpose = "testing"
}
}`,
}, step{
}, LegacyStep{
Template: `
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.STICKY_RANDOM}"
Expand All @@ -40,7 +40,7 @@ func TestUcAccCatalogIsolated(t *testing.T) {
purpose = "testing"
}
}`,
}, step{
}, LegacyStep{
Template: `
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.STICKY_RANDOM}"
Expand All @@ -55,7 +55,7 @@ func TestUcAccCatalogIsolated(t *testing.T) {

func TestUcAccCatalogUpdate(t *testing.T) {
loadUcwsEnv(t)
unityWorkspaceLevel(t, step{
unityWorkspaceLevel(t, LegacyStep{
Template: fmt.Sprintf(`
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.STICKY_RANDOM}"
Expand All @@ -65,7 +65,7 @@ func TestUcAccCatalogUpdate(t *testing.T) {
}
%s
}`, getPredictiveOptimizationSetting(t, true)),
}, step{
}, LegacyStep{
Template: fmt.Sprintf(`
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.STICKY_RANDOM}"
Expand All @@ -76,7 +76,7 @@ func TestUcAccCatalogUpdate(t *testing.T) {
%s
owner = "account users"
}`, getPredictiveOptimizationSetting(t, true)),
}, step{
}, LegacyStep{
Template: fmt.Sprintf(`
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.STICKY_RANDOM}"
Expand All @@ -87,7 +87,7 @@ func TestUcAccCatalogUpdate(t *testing.T) {
%s
owner = "{env.TEST_DATA_ENG_GROUP}"
}`, getPredictiveOptimizationSetting(t, true)),
}, step{
}, LegacyStep{
Template: fmt.Sprintf(`
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.STICKY_RANDOM}"
Expand Down
8 changes: 4 additions & 4 deletions internal/acceptance/cluster_policy_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import (
)

func TestAccClusterPolicyResourceFullLifecycle(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `resource "databricks_cluster_policy" "external_metastore" {
name = "Terraform policy {var.RANDOM}"
definition = jsonencode({
Expand All @@ -15,7 +15,7 @@ func TestAccClusterPolicyResourceFullLifecycle(t *testing.T) {
}
})
}`,
}, step{
}, LegacyStep{
// renaming to a new random name
Template: `resource "databricks_cluster_policy" "external_metastore" {
name = "Terraform policy {var.RANDOM}"
Expand All @@ -30,7 +30,7 @@ func TestAccClusterPolicyResourceFullLifecycle(t *testing.T) {
}

func TestAccClusterPolicyResourceOverrideBuiltIn(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `resource "databricks_cluster_policy" "personal_vm" {
name = "Personal Compute"
policy_family_id = "personal-vm"
Expand All @@ -46,7 +46,7 @@ func TestAccClusterPolicyResourceOverrideBuiltIn(t *testing.T) {
}

func TestAccClusterPolicyResourceOverrideNew(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `resource "databricks_cluster_policy" "policyoverrideempty" {
policy_family_id = "personal-vm"
name = "Policy Override {var.RANDOM}"
Expand Down
10 changes: 5 additions & 5 deletions internal/acceptance/cluster_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import (
)

func TestAccClusterResource_CreateClusterWithLibraries(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `data "databricks_spark_version" "latest" {
}
resource "databricks_cluster" "this" {
Expand Down Expand Up @@ -71,9 +71,9 @@ func singleNodeClusterTemplate(autoTerminationMinutes string) string {
}

func TestAccClusterResource_CreateSingleNodeCluster(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: singleNodeClusterTemplate("10"),
}, step{
}, LegacyStep{
Template: singleNodeClusterTemplate("20"),
})
}
Expand Down Expand Up @@ -101,9 +101,9 @@ func awsClusterTemplate(availability string) string {
func TestAccClusterResource_CreateAndUpdateAwsAttributes(t *testing.T) {
loadWorkspaceEnv(t)
if isAws(t) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: awsClusterTemplate("SPOT"),
}, step{
}, LegacyStep{
Template: awsClusterTemplate("SPOT_WITH_FALLBACK"),
})
}
Expand Down
10 changes: 5 additions & 5 deletions internal/acceptance/connection_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,19 +49,19 @@ func connectionTemplateWithoutOwner() string {
`
}
func TestUcAccConnectionsResourceFullLifecycle(t *testing.T) {
unityWorkspaceLevel(t, step{
unityWorkspaceLevel(t, LegacyStep{
Template: connectionTemplateWithOwner("test.mysql.database.azure.com", "account users"),
}, step{
}, LegacyStep{
Template: connectionTemplateWithOwner("test.mysql.database.aws.com", "account users"),
}, step{
}, LegacyStep{
Template: connectionTemplateWithOwner("test.mysql.database.azure.com", "{env.TEST_METASTORE_ADMIN_GROUP_NAME}"),
})
}

func TestUcAccConnectionsWithoutOwnerResourceFullLifecycle(t *testing.T) {
unityWorkspaceLevel(t, step{
unityWorkspaceLevel(t, LegacyStep{
Template: connectionTemplateWithoutOwner(),
}, step{
}, LegacyStep{
Template: connectionTemplateWithoutOwner(),
})
}
28 changes: 14 additions & 14 deletions internal/acceptance/dashboard_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ func (t *templateStruct) SetAttributes(mapper map[string]string) templateStruct
func TestAccBasicDashboard(t *testing.T) {
var template templateStruct
displayName := fmt.Sprintf("Test Dashboard - %s", qa.RandomName())
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: makeTemplate(template.SetAttributes(map[string]string{
"display_name": displayName,
"warehouse_id": "{env.TEST_DEFAULT_WAREHOUSE_ID}",
Expand Down Expand Up @@ -119,7 +119,7 @@ func TestAccBasicDashboard(t *testing.T) {
func TestAccDashboardWithSerializedJSON(t *testing.T) {
var template templateStruct
displayName := fmt.Sprintf("Test Dashboard - %s", qa.RandomName())
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: makeTemplate(template.SetAttributes(map[string]string{
"display_name": displayName,
"warehouse_id": "{env.TEST_DEFAULT_WAREHOUSE_ID}",
Expand All @@ -142,7 +142,7 @@ func TestAccDashboardWithSerializedJSON(t *testing.T) {
require.NoError(t, err)
return nil
}),
}, step{
}, LegacyStep{
Template: makeTemplate(template.SetAttributes(map[string]string{
"serialized_dashboard": `{\"pages\":[{\"name\":\"new_name\",\"displayName\":\"New Page Modified\"}]}`,
"embed_credentials": "true",
Expand Down Expand Up @@ -174,7 +174,7 @@ func TestAccDashboardWithFilePath(t *testing.T) {
fileName := tmpDir + "/Dashboard.json"
var template templateStruct
displayName := fmt.Sprintf("Test Dashboard - %s", qa.RandomName())
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
PreConfig: func() {
os.Mkdir(tmpDir, 0755)
os.WriteFile(fileName, []byte("{\"pages\":[{\"name\":\"new_name\",\"displayName\":\"New Page\"}]}"), 0644)
Expand All @@ -200,7 +200,7 @@ func TestAccDashboardWithFilePath(t *testing.T) {
require.NoError(t, err)
return nil
}),
}, step{
}, LegacyStep{
PreConfig: func() {
os.WriteFile(fileName, []byte("{\"pages\":[{\"name\":\"new_name\",\"displayName\":\"New Page Modified\"}]}"), 0644)
},
Expand Down Expand Up @@ -231,7 +231,7 @@ func TestAccDashboardWithNoChange(t *testing.T) {
initial_update_time := ""
var template templateStruct
displayName := fmt.Sprintf("Test Dashboard - %s", qa.RandomName())
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: makeTemplate(template.SetAttributes(map[string]string{
"display_name": displayName,
"warehouse_id": "{env.TEST_DEFAULT_WAREHOUSE_ID}",
Expand All @@ -254,7 +254,7 @@ func TestAccDashboardWithNoChange(t *testing.T) {
initial_update_time = dashboard.UpdateTime
return nil
}),
}, step{
}, LegacyStep{
Template: makeTemplate(template),
Check: resourceCheck("databricks_dashboard.d1", func(ctx context.Context, client *common.DatabricksClient, id string) error {
w, err := client.WorkspaceClient()
Expand Down Expand Up @@ -284,7 +284,7 @@ func TestAccDashboardWithRemoteChange(t *testing.T) {
etag := ""
var template templateStruct
displayName := fmt.Sprintf("Test Dashboard - %s", qa.RandomName())
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: makeTemplate(template.SetAttributes(map[string]string{
"display_name": displayName,
"warehouse_id": "{env.TEST_DEFAULT_WAREHOUSE_ID}",
Expand All @@ -310,7 +310,7 @@ func TestAccDashboardWithRemoteChange(t *testing.T) {
etag = dashboard.Etag
return nil
}),
}, step{
}, LegacyStep{
PreConfig: func() {
w, err := databricks.NewWorkspaceClient(&databricks.Config{})
require.NoError(t, err)
Expand Down Expand Up @@ -355,7 +355,7 @@ func TestAccDashboardTestAll(t *testing.T) {
fileName := tmpDir + "/Dashboard.json"
var template templateStruct
displayName := fmt.Sprintf("Test Dashboard - %s", qa.RandomName())
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
PreConfig: func() {
os.Mkdir(tmpDir, 0755)
os.WriteFile(fileName, []byte("{\"pages\":[{\"name\":\"new_name\",\"displayName\":\"New Page in file\"}]}"), 0644)
Expand Down Expand Up @@ -388,7 +388,7 @@ func TestAccDashboardTestAll(t *testing.T) {
require.Equal(t, publish_dash.EmbedCredentials, false)
return nil
}),
}, step{
}, LegacyStep{
PreConfig: func() {
os.WriteFile(fileName, []byte("{\"pages\":[{\"name\":\"new_name\",\"displayName\":\"New Page Modified\"}]}"), 0644)
},
Expand All @@ -414,7 +414,7 @@ func TestAccDashboardTestAll(t *testing.T) {
assert.NotEqual(t, "", dashboard.SerializedDashboard)
return nil
}),
}, step{
}, LegacyStep{
PreConfig: func() {
w, err := databricks.NewWorkspaceClient(&databricks.Config{})
require.NoError(t, err)
Expand Down Expand Up @@ -444,7 +444,7 @@ func TestAccDashboardTestAll(t *testing.T) {
require.NoError(t, err)
return nil
}),
}, step{
}, LegacyStep{
Template: makeTemplate(template.SetAttributes(map[string]string{
"embed_credentials": "true",
"parent_path": "/Shared/Teams",
Expand All @@ -466,7 +466,7 @@ func TestAccDashboardTestAll(t *testing.T) {
assert.NotEqual(t, "", dashboard.SerializedDashboard)
return nil
}),
}, step{
}, LegacyStep{
PreConfig: func() {
os.WriteFile(fileName, []byte("{\"pages\":[{\"name\":\"new_name\",\"displayName\":\"New Page Modified again\"}]}"), 0644)
},
Expand Down
2 changes: 1 addition & 1 deletion internal/acceptance/data_aws_crossaccount_policy_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import (

func TestMwsAccDataSourceAwsCrossaccountPolicy(t *testing.T) {
GetEnvOrSkipTest(t, "TEST_ROOT_BUCKET") // marker for AWS test env
accountLevel(t, step{
accountLevel(t, LegacyStep{
Template: `
data "databricks_aws_crossaccount_policy" "this" {
}`,
Expand Down
2 changes: 1 addition & 1 deletion internal/acceptance/data_catalog_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import (
)

func TestUcAccDataSourceCatalog(t *testing.T) {
unityWorkspaceLevel(t, step{
unityWorkspaceLevel(t, LegacyStep{
Template: `
resource "databricks_catalog" "sandbox" {
name = "sandbox{var.RANDOM}"
Expand Down
2 changes: 1 addition & 1 deletion internal/acceptance/data_cluster_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import (
)

func TestAccDataSourceCluster(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `
data "databricks_cluster" "this" {
cluster_id = "{env.TEST_DEFAULT_CLUSTER_ID}"
Expand Down
4 changes: 2 additions & 2 deletions internal/acceptance/data_clusters_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,15 @@ import (
)

func TestAccDataSourceClustersNoFilter(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `
data "databricks_clusters" "this" {
} `,
})
}

func TestAccDataSourceClustersWithFilter(t *testing.T) {
workspaceLevel(t, step{
workspaceLevel(t, LegacyStep{
Template: `
data "databricks_clusters" "this" {
cluster_name_contains = "Default"
Expand Down
Loading

0 comments on commit 0abb9b4

Please sign in to comment.