2021-03-19 10:12:56 +00:00
|
|
|
package management
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/caos/zitadel/internal/test"
|
|
|
|
"github.com/caos/zitadel/pkg/grpc/idp"
|
|
|
|
mgmt_pb "github.com/caos/zitadel/pkg/grpc/management"
|
|
|
|
)
|
|
|
|
|
|
|
|
func Test_addOIDCIDPRequestToDomain(t *testing.T) {
|
|
|
|
type args struct {
|
|
|
|
req *mgmt_pb.AddOrgOIDCIDPRequest
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "all fields filled",
|
|
|
|
args: args{
|
|
|
|
req: &mgmt_pb.AddOrgOIDCIDPRequest{
|
2021-07-13 14:06:17 +00:00
|
|
|
Name: "ZITADEL",
|
|
|
|
StylingType: idp.IDPStylingType_STYLING_TYPE_GOOGLE,
|
|
|
|
ClientId: "test1234",
|
|
|
|
ClientSecret: "test4321",
|
|
|
|
Issuer: "zitadel.ch",
|
|
|
|
Scopes: []string{"email", "profile"},
|
|
|
|
DisplayNameMapping: idp.OIDCMappingField_OIDC_MAPPING_FIELD_EMAIL,
|
|
|
|
UsernameMapping: idp.OIDCMappingField_OIDC_MAPPING_FIELD_PREFERRED_USERNAME,
|
2021-03-19 10:12:56 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
got := addOIDCIDPRequestToDomain(tt.args.req)
|
|
|
|
test.AssertFieldsMapped(t, got,
|
|
|
|
"ObjectRoot",
|
|
|
|
"OIDCConfig.ClientSecret",
|
|
|
|
"OIDCConfig.ObjectRoot",
|
|
|
|
"OIDCConfig.IDPConfigID",
|
|
|
|
"IDPConfigID",
|
|
|
|
"State",
|
2021-07-13 14:06:17 +00:00
|
|
|
"OIDCConfig.AuthorizationEndpoint",
|
|
|
|
"OIDCConfig.TokenEndpoint",
|
2021-03-19 10:12:56 +00:00
|
|
|
"Type", //TODO: default (0) is oidc
|
|
|
|
)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_addOIDCIDPRequestToDomainOIDCIDPConfig(t *testing.T) {
|
|
|
|
type args struct {
|
|
|
|
req *mgmt_pb.AddOrgOIDCIDPRequest
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "all fields filled",
|
|
|
|
args: args{
|
|
|
|
req: &mgmt_pb.AddOrgOIDCIDPRequest{
|
2021-07-13 14:06:17 +00:00
|
|
|
ClientId: "test1234",
|
|
|
|
ClientSecret: "test4321",
|
|
|
|
Issuer: "zitadel.ch",
|
|
|
|
Scopes: []string{"email", "profile"},
|
|
|
|
DisplayNameMapping: idp.OIDCMappingField_OIDC_MAPPING_FIELD_EMAIL,
|
|
|
|
UsernameMapping: idp.OIDCMappingField_OIDC_MAPPING_FIELD_PREFERRED_USERNAME,
|
2021-03-19 10:12:56 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
got := addOIDCIDPRequestToDomainOIDCIDPConfig(tt.args.req)
|
|
|
|
test.AssertFieldsMapped(t, got,
|
|
|
|
"ObjectRoot",
|
|
|
|
"ClientSecret", //TODO: is client secret string enough for backend?
|
|
|
|
"IDPConfigID",
|
2021-07-13 14:06:17 +00:00
|
|
|
"AuthorizationEndpoint",
|
|
|
|
"TokenEndpoint",
|
2021-03-19 10:12:56 +00:00
|
|
|
)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_updateIDPToDomain(t *testing.T) {
|
|
|
|
type args struct {
|
|
|
|
req *mgmt_pb.UpdateOrgIDPRequest
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "all fields filled",
|
|
|
|
args: args{
|
|
|
|
req: &mgmt_pb.UpdateOrgIDPRequest{
|
|
|
|
IdpId: "13523",
|
|
|
|
Name: "new name",
|
|
|
|
StylingType: idp.IDPStylingType_STYLING_TYPE_GOOGLE,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
got := updateIDPToDomain(tt.args.req)
|
|
|
|
test.AssertFieldsMapped(t, got,
|
|
|
|
"ObjectRoot",
|
|
|
|
"OIDCConfig",
|
|
|
|
"State",
|
|
|
|
"Type", //TODO: type should not be changeable
|
|
|
|
)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_updateOIDCConfigToDomain(t *testing.T) {
|
|
|
|
type args struct {
|
|
|
|
req *mgmt_pb.UpdateOrgIDPOIDCConfigRequest
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "all fields filled",
|
|
|
|
args: args{
|
|
|
|
req: &mgmt_pb.UpdateOrgIDPOIDCConfigRequest{
|
2021-07-13 14:06:17 +00:00
|
|
|
IdpId: "4208",
|
|
|
|
Issuer: "zitadel.ch",
|
|
|
|
ClientId: "ZITEADEL",
|
|
|
|
ClientSecret: "i'm so secret",
|
|
|
|
Scopes: []string{"profile"},
|
|
|
|
DisplayNameMapping: idp.OIDCMappingField_OIDC_MAPPING_FIELD_EMAIL,
|
|
|
|
UsernameMapping: idp.OIDCMappingField_OIDC_MAPPING_FIELD_PREFERRED_USERNAME,
|
2021-03-19 10:12:56 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
got := updateOIDCConfigToDomain(tt.args.req)
|
|
|
|
test.AssertFieldsMapped(t, got,
|
|
|
|
"ObjectRoot",
|
|
|
|
"ClientSecret",
|
2021-07-13 14:06:17 +00:00
|
|
|
"AuthorizationEndpoint",
|
|
|
|
"TokenEndpoint",
|
2021-03-19 10:12:56 +00:00
|
|
|
)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|