Skip to content

Commit

Permalink
chore: Add external removal tests to functions and procedures (#3305)
Browse files Browse the repository at this point in the history
- Add external removal tests to functions and procedures (done during
old issues closing)
- Fix the following tests:
  - TestAcc_FunctionJava_InlineFull
  - TestAcc_FunctionPython_InlineBasic
  - TestAcc_FunctionPython_InlineFull
  - TestAcc_FunctionScala_InlineFull
  - TestAcc_FunctionSql_InlineBasic
  • Loading branch information
sfc-gh-asawicki committed Dec 20, 2024
1 parent e0ed15b commit e2d0705
Show file tree
Hide file tree
Showing 10 changed files with 171 additions and 3 deletions.
17 changes: 17 additions & 0 deletions pkg/resources/function_java_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,22 @@ func TestAcc_FunctionJava_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(functionModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Function.DropFunctionFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(functionModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, functionModel),
Check: assert.AssertThat(t,
resourceassert.FunctionJavaResource(t, functionModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: functionModel.ResourceReference(),
Expand Down Expand Up @@ -183,6 +199,7 @@ func TestAcc_FunctionJava_InlineBasicDefaultArg(t *testing.T) {
func TestAcc_FunctionJava_InlineFull(t *testing.T) {
_ = testenvs.GetOrSkipTest(t, testenvs.EnableAcceptance)
acc.TestAccPreCheck(t)
t.Setenv(string(testenvs.ConfigureClientOnce), "")

stage, stageCleanup := acc.TestClient().Stage.CreateStage(t)
t.Cleanup(stageCleanup)
Expand Down
16 changes: 16 additions & 0 deletions pkg/resources/function_javascript_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,22 @@ func TestAcc_FunctionJavascript_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(functionModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Function.DropFunctionFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(functionModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, functionModel),
Check: assert.AssertThat(t,
resourceassert.FunctionJavascriptResource(t, functionModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// RENAME
{
Config: config.FromModels(t, functionModelRenamed),
Expand Down
21 changes: 21 additions & 0 deletions pkg/resources/function_python_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,10 @@ import (
)

func TestAcc_FunctionPython_InlineBasic(t *testing.T) {
_ = testenvs.GetOrSkipTest(t, testenvs.EnableAcceptance)
acc.TestAccPreCheck(t)
t.Setenv(string(testenvs.ConfigureClientOnce), "")

funcName := "some_function"
argName := "x"
dataType := testdatatypes.DataTypeNumber_36_2
Expand Down Expand Up @@ -64,6 +68,22 @@ func TestAcc_FunctionPython_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(functionModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Function.DropFunctionFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(functionModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, functionModel),
Check: assert.AssertThat(t,
resourceassert.FunctionPythonResource(t, functionModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: functionModel.ResourceReference(),
Expand Down Expand Up @@ -94,6 +114,7 @@ func TestAcc_FunctionPython_InlineBasic(t *testing.T) {
func TestAcc_FunctionPython_InlineFull(t *testing.T) {
_ = testenvs.GetOrSkipTest(t, testenvs.EnableAcceptance)
acc.TestAccPreCheck(t)
t.Setenv(string(testenvs.ConfigureClientOnce), "")

secretId := acc.TestClient().Ids.RandomSchemaObjectIdentifier()
secretId2 := acc.TestClient().Ids.RandomSchemaObjectIdentifier()
Expand Down
17 changes: 17 additions & 0 deletions pkg/resources/function_scala_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,22 @@ func TestAcc_FunctionScala_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(functionModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Function.DropFunctionFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(functionModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, functionModel),
Check: assert.AssertThat(t,
resourceassert.FunctionScalaResource(t, functionModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: functionModel.ResourceReference(),
Expand Down Expand Up @@ -99,6 +115,7 @@ func TestAcc_FunctionScala_InlineBasic(t *testing.T) {
func TestAcc_FunctionScala_InlineFull(t *testing.T) {
_ = testenvs.GetOrSkipTest(t, testenvs.EnableAcceptance)
acc.TestAccPreCheck(t)
t.Setenv(string(testenvs.ConfigureClientOnce), "")

stage, stageCleanup := acc.TestClient().Stage.CreateStage(t)
t.Cleanup(stageCleanup)
Expand Down
23 changes: 20 additions & 3 deletions pkg/resources/function_sql_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,28 +4,29 @@ import (
"testing"

acc "github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/helpers/random"
r "github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/resources"

"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/bettertestspoc/assert"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/bettertestspoc/assert/resourceassert"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/bettertestspoc/assert/resourceshowoutputassert"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/bettertestspoc/config"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/bettertestspoc/config/model"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/helpers/random"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/importchecks"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/acceptance/testdatatypes"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/helpers"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/provider/resources"
"github.com/Snowflake-Labs/terraform-provider-snowflake/pkg/sdk"
"github.com/hashicorp/terraform-plugin-testing/helper/resource"
"github.com/hashicorp/terraform-plugin-testing/plancheck"
"github.com/hashicorp/terraform-plugin-testing/tfversion"
)

func TestAcc_FunctionSql_InlineBasic(t *testing.T) {
argName := "abc"
dataType := testdatatypes.DataTypeFloat
id := acc.TestClient().Ids.RandomSchemaObjectIdentifierWithArgumentsNewDataTypes(dataType)
idWithChangedNameButTheSameDataType := acc.TestClient().Ids.RandomSchemaObjectIdentifierWithArgumentsNewDataTypes()
idWithChangedNameButTheSameDataType := acc.TestClient().Ids.RandomSchemaObjectIdentifierWithArgumentsNewDataTypes(dataType)

definition := acc.TestClient().Function.SampleSqlDefinitionWithArgument(t, argName)

Expand Down Expand Up @@ -60,12 +61,28 @@ func TestAcc_FunctionSql_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(functionModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Function.DropFunctionFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(functionModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, functionModel),
Check: assert.AssertThat(t,
resourceassert.FunctionSqlResource(t, functionModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: functionModel.ResourceReference(),
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{},
ImportStateVerifyIgnore: []string{"is_secure"},
ImportStateCheck: assert.AssertThatImport(t,
resourceassert.ImportedFunctionSqlResource(t, id.FullyQualifiedName()).
HasFullyQualifiedNameString(id.FullyQualifiedName()),
Expand Down
16 changes: 16 additions & 0 deletions pkg/resources/procedure_java_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,22 @@ func TestAcc_ProcedureJava_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(procedureModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Procedure.DropProcedureFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(procedureModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, procedureModel),
Check: assert.AssertThat(t,
resourceassert.ProcedureJavaResource(t, procedureModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: procedureModel.ResourceReference(),
Expand Down
16 changes: 16 additions & 0 deletions pkg/resources/procedure_javascript_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,22 @@ func TestAcc_ProcedureJavascript_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(procedureModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Procedure.DropProcedureFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(procedureModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, procedureModel),
Check: assert.AssertThat(t,
resourceassert.ProcedureJavascriptResource(t, procedureModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: procedureModel.ResourceReference(),
Expand Down
16 changes: 16 additions & 0 deletions pkg/resources/procedure_python_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,22 @@ func TestAcc_ProcedurePython_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(procedureModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Procedure.DropProcedureFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(procedureModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, procedureModel),
Check: assert.AssertThat(t,
resourceassert.ProcedurePythonResource(t, procedureModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: procedureModel.ResourceReference(),
Expand Down
16 changes: 16 additions & 0 deletions pkg/resources/procedure_scala_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,22 @@ func TestAcc_ProcedureScala_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(procedureModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Procedure.DropProcedureFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(procedureModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, procedureModel),
Check: assert.AssertThat(t,
resourceassert.ProcedureScalaResource(t, procedureModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: procedureModel.ResourceReference(),
Expand Down
16 changes: 16 additions & 0 deletions pkg/resources/procedure_sql_acceptance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,22 @@ func TestAcc_ProcedureSql_InlineBasic(t *testing.T) {
assert.Check(resource.TestCheckResourceAttr(procedureModel.ResourceReference(), "arguments.0.arg_default_value", "")),
),
},
// REMOVE EXTERNALLY (CHECK RECREATION)
{
PreConfig: func() {
acc.TestClient().Procedure.DropProcedureFunc(t, id)()
},
ConfigPlanChecks: resource.ConfigPlanChecks{
PreApply: []plancheck.PlanCheck{
plancheck.ExpectResourceAction(procedureModel.ResourceReference(), plancheck.ResourceActionCreate),
},
},
Config: config.FromModels(t, procedureModel),
Check: assert.AssertThat(t,
resourceassert.ProcedureSqlResource(t, procedureModel.ResourceReference()).
HasNameString(id.Name()),
),
},
// IMPORT
{
ResourceName: procedureModel.ResourceReference(),
Expand Down

0 comments on commit e2d0705

Please sign in to comment.