package sqlserverflexalpha import ( "testing" "github.com/google/go-cmp/cmp" "github.com/hashicorp/terraform-plugin-framework/attr" "github.com/hashicorp/terraform-plugin-framework/types" "github.com/stackitcloud/stackit-sdk-go/core/utils" "tf-provider.git.onstackit.cloud/stackit-dev-tools/terraform-provider-stackitprivatepreview/pkg_gen/sqlserverflexalpha" ) func TestMapDataSourceFields(t *testing.T) { const testRegion = "region" tests := []struct { description string input *sqlserverflexalpha.GetUserResponse region string expected dataSourceModel isValid bool }{ { "default_values", &sqlserverflexalpha.GetUserResponse{}, testRegion, dataSourceModel{ Id: types.StringValue("pid,region,iid,1"), UserId: types.Int64Value(1), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringNull(), Roles: types.SetNull(types.StringType), Host: types.StringNull(), Port: types.Int64Null(), Region: types.StringValue(testRegion), Status: types.StringNull(), DefaultDatabase: types.StringNull(), }, true, }, { "simple_values", &sqlserverflexalpha.GetUserResponse{ Roles: &[]string{ "role_1", "role_2", "", }, Username: utils.Ptr("username"), Host: utils.Ptr("host"), Port: utils.Ptr(int64(1234)), Status: utils.Ptr("active"), DefaultDatabase: utils.Ptr("default_db"), }, testRegion, dataSourceModel{ Id: types.StringValue("pid,region,iid,1"), UserId: types.Int64Value(1), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringValue("username"), Roles: types.SetValueMust( types.StringType, []attr.Value{ types.StringValue("role_1"), types.StringValue("role_2"), types.StringValue(""), }, ), Host: types.StringValue("host"), Port: types.Int64Value(1234), Region: types.StringValue(testRegion), Status: types.StringValue("active"), DefaultDatabase: types.StringValue("default_db"), }, true, }, { "null_fields_and_int_conversions", &sqlserverflexalpha.GetUserResponse{ Id: utils.Ptr(int64(1)), Roles: &[]string{}, Username: nil, Host: nil, Port: utils.Ptr(int64(2123456789)), }, testRegion, dataSourceModel{ Id: types.StringValue("pid,region,iid,1"), UserId: types.Int64Value(1), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringNull(), Roles: types.SetValueMust(types.StringType, []attr.Value{}), Host: types.StringNull(), Port: types.Int64Value(2123456789), Region: types.StringValue(testRegion), }, true, }, { "nil_response", nil, testRegion, dataSourceModel{}, false, }, { "nil_response_2", &sqlserverflexalpha.GetUserResponse{}, testRegion, dataSourceModel{}, false, }, { "no_resource_id", &sqlserverflexalpha.GetUserResponse{}, testRegion, dataSourceModel{}, false, }, } for _, tt := range tests { t.Run( tt.description, func(t *testing.T) { state := &dataSourceModel{ ProjectId: tt.expected.ProjectId, InstanceId: tt.expected.InstanceId, UserId: tt.expected.UserId, } err := mapDataSourceFields(tt.input, state, tt.region) if !tt.isValid && err == nil { t.Fatalf("Should have failed") } if tt.isValid && err != nil { t.Fatalf("Should not have failed: %v", err) } if tt.isValid { diff := cmp.Diff(state, &tt.expected) if diff != "" { t.Fatalf("Data does not match: %s", diff) } } }, ) } } func TestMapFieldsCreate(t *testing.T) { const testRegion = "region" tests := []struct { description string input *sqlserverflexalpha.CreateUserResponse region string expected resourceModel isValid bool }{ { "default_values", &sqlserverflexalpha.CreateUserResponse{ Id: utils.Ptr(int64(1)), Password: utils.Ptr(""), }, testRegion, resourceModel{ Id: types.Int64Value(1), UserId: types.Int64Value(1), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringNull(), Roles: types.List(types.SetNull(types.StringType)), Password: types.StringValue(""), Host: types.StringNull(), Port: types.Int64Null(), Region: types.StringValue(testRegion), }, true, }, { "simple_values", &sqlserverflexalpha.CreateUserResponse{ Id: utils.Ptr(int64(2)), Roles: &[]string{ "role_1", "role_2", "", }, Username: utils.Ptr("username"), Password: utils.Ptr("password"), Host: utils.Ptr("host"), Port: utils.Ptr(int64(1234)), Status: utils.Ptr("status"), DefaultDatabase: utils.Ptr("default_db"), }, testRegion, resourceModel{ Id: types.Int64Value(2), UserId: types.Int64Value(2), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringValue("username"), Roles: types.List( types.SetValueMust( types.StringType, []attr.Value{ types.StringValue("role_1"), types.StringValue("role_2"), types.StringValue(""), }, ), ), Password: types.StringValue("password"), Host: types.StringValue("host"), Port: types.Int64Value(1234), Region: types.StringValue(testRegion), Status: types.StringValue("status"), DefaultDatabase: types.StringValue("default_db"), }, true, }, { "null_fields_and_int_conversions", &sqlserverflexalpha.CreateUserResponse{ Id: utils.Ptr(int64(3)), Roles: &[]string{}, Username: nil, Password: utils.Ptr(""), Host: nil, Port: utils.Ptr(int64(2123456789)), }, testRegion, resourceModel{ Id: types.Int64Value(3), UserId: types.Int64Value(3), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringNull(), Roles: types.List(types.SetValueMust(types.StringType, []attr.Value{})), Password: types.StringValue(""), Host: types.StringNull(), Port: types.Int64Value(2123456789), Region: types.StringValue(testRegion), DefaultDatabase: types.StringNull(), Status: types.StringNull(), }, true, }, { "nil_response", nil, testRegion, resourceModel{}, false, }, { "nil_response_2", &sqlserverflexalpha.CreateUserResponse{}, testRegion, resourceModel{}, false, }, { "no_resource_id", &sqlserverflexalpha.CreateUserResponse{}, testRegion, resourceModel{}, false, }, { "no_password", &sqlserverflexalpha.CreateUserResponse{ Id: utils.Ptr(int64(1)), }, testRegion, resourceModel{}, false, }, } for _, tt := range tests { t.Run( tt.description, func(t *testing.T) { state := &resourceModel{ ProjectId: tt.expected.ProjectId, InstanceId: tt.expected.InstanceId, } err := mapFieldsCreate(tt.input, state, tt.region) if !tt.isValid && err == nil { t.Fatalf("Should have failed") } if tt.isValid && err != nil { t.Fatalf("Should not have failed: %v", err) } if tt.isValid { diff := cmp.Diff(state, &tt.expected) if diff != "" { t.Fatalf("Data does not match: %s", diff) } } }, ) } } func TestMapFields(t *testing.T) { const testRegion = "region" tests := []struct { description string input *sqlserverflexalpha.GetUserResponse region string expected resourceModel isValid bool }{ { "default_values", &sqlserverflexalpha.GetUserResponse{}, testRegion, resourceModel{ Id: types.Int64Value(1), UserId: types.Int64Value(1), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringNull(), Roles: types.List(types.SetNull(types.StringType)), Host: types.StringNull(), Port: types.Int64Null(), Region: types.StringValue(testRegion), }, true, }, { "simple_values", &sqlserverflexalpha.GetUserResponse{ Roles: &[]string{ "role_1", "role_2", "", }, Username: utils.Ptr("username"), Host: utils.Ptr("host"), Port: utils.Ptr(int64(1234)), }, testRegion, resourceModel{ Id: types.Int64Value(2), UserId: types.Int64Value(2), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringValue("username"), Roles: types.List( types.SetValueMust( types.StringType, []attr.Value{ types.StringValue("role_1"), types.StringValue("role_2"), types.StringValue(""), }, ), ), Host: types.StringValue("host"), Port: types.Int64Value(1234), Region: types.StringValue(testRegion), }, true, }, { "null_fields_and_int_conversions", &sqlserverflexalpha.GetUserResponse{ Id: utils.Ptr(int64(1)), Roles: &[]string{}, Username: nil, Host: nil, Port: utils.Ptr(int64(2123456789)), }, testRegion, resourceModel{ Id: types.Int64Value(1), UserId: types.Int64Value(1), InstanceId: types.StringValue("iid"), ProjectId: types.StringValue("pid"), Username: types.StringNull(), Roles: types.List(types.SetValueMust(types.StringType, []attr.Value{})), Host: types.StringNull(), Port: types.Int64Value(2123456789), Region: types.StringValue(testRegion), }, true, }, { "nil_response", nil, testRegion, resourceModel{}, false, }, { "nil_response_2", &sqlserverflexalpha.GetUserResponse{}, testRegion, resourceModel{}, false, }, { "no_resource_id", &sqlserverflexalpha.GetUserResponse{}, testRegion, resourceModel{}, false, }, } for _, tt := range tests { t.Run( tt.description, func(t *testing.T) { state := &resourceModel{ ProjectId: tt.expected.ProjectId, InstanceId: tt.expected.InstanceId, UserId: tt.expected.UserId, } err := mapFields(tt.input, state, tt.region) if !tt.isValid && err == nil { t.Fatalf("Should have failed") } if tt.isValid && err != nil { t.Fatalf("Should not have failed: %v", err) } if tt.isValid { diff := cmp.Diff(state, &tt.expected) if diff != "" { t.Fatalf("Data does not match: %s", diff) } } }, ) } } func TestToCreatePayload(t *testing.T) { tests := []struct { description string input *resourceModel inputRoles []string expected *sqlserverflexalpha.CreateUserRequestPayload isValid bool }{ { "default_values", &resourceModel{}, []string{}, &sqlserverflexalpha.CreateUserRequestPayload{ Roles: &[]string{}, Username: nil, }, true, }, { "default_values", &resourceModel{ Username: types.StringValue("username"), }, []string{ "role_1", "role_2", }, &sqlserverflexalpha.CreateUserRequestPayload{ Roles: &[]string{ "role_1", "role_2", }, Username: utils.Ptr("username"), }, true, }, { "null_fields_and_int_conversions", &resourceModel{ Username: types.StringNull(), }, []string{ "", }, &sqlserverflexalpha.CreateUserRequestPayload{ Roles: &[]string{ "", }, Username: nil, }, true, }, { "nil_model", nil, []string{}, nil, false, }, { "nil_roles", &resourceModel{ Username: types.StringValue("username"), }, []string{}, &sqlserverflexalpha.CreateUserRequestPayload{ Roles: &[]string{}, Username: utils.Ptr("username"), }, true, }, } for _, tt := range tests { t.Run( tt.description, func(t *testing.T) { output, err := toCreatePayload(tt.input, tt.inputRoles) if !tt.isValid && err == nil { t.Fatalf("Should have failed") } if tt.isValid && err != nil { t.Fatalf("Should not have failed: %v", err) } if tt.isValid { diff := cmp.Diff(output, tt.expected) if diff != "" { t.Fatalf("Data does not match: %s", diff) } } }, ) } }