2023-05-24 10:22:00 +00:00
|
|
|
package user
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
2023-06-07 15:28:42 +00:00
|
|
|
"google.golang.org/protobuf/proto"
|
|
|
|
"google.golang.org/protobuf/types/known/structpb"
|
2023-05-24 10:22:00 +00:00
|
|
|
"google.golang.org/protobuf/types/known/timestamppb"
|
|
|
|
|
|
|
|
"github.com/zitadel/zitadel/internal/api/grpc"
|
|
|
|
"github.com/zitadel/zitadel/internal/domain"
|
2023-06-07 15:28:42 +00:00
|
|
|
caos_errs "github.com/zitadel/zitadel/internal/errors"
|
2023-05-24 10:22:00 +00:00
|
|
|
object "github.com/zitadel/zitadel/pkg/grpc/object/v2alpha"
|
|
|
|
user "github.com/zitadel/zitadel/pkg/grpc/user/v2alpha"
|
|
|
|
)
|
|
|
|
|
|
|
|
func Test_passkeyAuthenticatorToDomain(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
pa user.PasskeyAuthenticator
|
|
|
|
want domain.AuthenticatorAttachment
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
pa: user.PasskeyAuthenticator_PASSKEY_AUTHENTICATOR_UNSPECIFIED,
|
|
|
|
want: domain.AuthenticatorAttachmentUnspecified,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
pa: user.PasskeyAuthenticator_PASSKEY_AUTHENTICATOR_PLATFORM,
|
|
|
|
want: domain.AuthenticatorAttachmentPlattform,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
pa: user.PasskeyAuthenticator_PASSKEY_AUTHENTICATOR_CROSS_PLATFORM,
|
|
|
|
want: domain.AuthenticatorAttachmentCrossPlattform,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
pa: 999,
|
|
|
|
want: domain.AuthenticatorAttachmentUnspecified,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.pa.String(), func(t *testing.T) {
|
|
|
|
got := passkeyAuthenticatorToDomain(tt.pa)
|
|
|
|
assert.Equal(t, tt.want, got)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_passkeyRegistrationDetailsToPb(t *testing.T) {
|
|
|
|
type args struct {
|
2023-06-15 05:32:40 +00:00
|
|
|
details *domain.WebAuthNRegistrationDetails
|
2023-05-24 10:22:00 +00:00
|
|
|
err error
|
|
|
|
}
|
|
|
|
tests := []struct {
|
2023-06-07 15:28:42 +00:00
|
|
|
name string
|
|
|
|
args args
|
|
|
|
want *user.RegisterPasskeyResponse
|
|
|
|
wantErr error
|
2023-05-24 10:22:00 +00:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "an error",
|
|
|
|
args: args{
|
|
|
|
details: nil,
|
|
|
|
err: io.ErrClosedPipe,
|
|
|
|
},
|
2023-06-07 15:28:42 +00:00
|
|
|
wantErr: io.ErrClosedPipe,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "unmarshall error",
|
|
|
|
args: args{
|
2023-06-15 05:32:40 +00:00
|
|
|
details: &domain.WebAuthNRegistrationDetails{
|
2023-06-07 15:28:42 +00:00
|
|
|
ObjectDetails: &domain.ObjectDetails{
|
|
|
|
Sequence: 22,
|
|
|
|
EventDate: time.Unix(3000, 22),
|
|
|
|
ResourceOwner: "me",
|
|
|
|
},
|
2023-06-15 05:32:40 +00:00
|
|
|
ID: "123",
|
2023-06-07 15:28:42 +00:00
|
|
|
PublicKeyCredentialCreationOptions: []byte(`\\`),
|
|
|
|
},
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
wantErr: caos_errs.ThrowInternal(nil, "USERv2-Dohr6", "Errors.Internal"),
|
2023-05-24 10:22:00 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ok",
|
|
|
|
args: args{
|
2023-06-15 05:32:40 +00:00
|
|
|
details: &domain.WebAuthNRegistrationDetails{
|
2023-05-24 10:22:00 +00:00
|
|
|
ObjectDetails: &domain.ObjectDetails{
|
|
|
|
Sequence: 22,
|
|
|
|
EventDate: time.Unix(3000, 22),
|
|
|
|
ResourceOwner: "me",
|
|
|
|
},
|
2023-06-15 05:32:40 +00:00
|
|
|
ID: "123",
|
2023-06-07 15:28:42 +00:00
|
|
|
PublicKeyCredentialCreationOptions: []byte(`{"foo": "bar"}`),
|
2023-05-24 10:22:00 +00:00
|
|
|
},
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
want: &user.RegisterPasskeyResponse{
|
|
|
|
Details: &object.Details{
|
|
|
|
Sequence: 22,
|
|
|
|
ChangeDate: ×tamppb.Timestamp{
|
|
|
|
Seconds: 3000,
|
|
|
|
Nanos: 22,
|
|
|
|
},
|
|
|
|
ResourceOwner: "me",
|
|
|
|
},
|
2023-06-07 15:28:42 +00:00
|
|
|
PasskeyId: "123",
|
|
|
|
PublicKeyCredentialCreationOptions: &structpb.Struct{
|
|
|
|
Fields: map[string]*structpb.Value{"foo": {Kind: &structpb.Value_StringValue{StringValue: "bar"}}},
|
|
|
|
},
|
2023-05-24 10:22:00 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
got, err := passkeyRegistrationDetailsToPb(tt.args.details, tt.args.err)
|
2023-06-07 15:28:42 +00:00
|
|
|
require.ErrorIs(t, err, tt.wantErr)
|
|
|
|
if !proto.Equal(tt.want, got) {
|
|
|
|
t.Errorf("Not equal:\nExpected\n%s\nActual:%s", tt.want, got)
|
|
|
|
}
|
2023-05-24 10:22:00 +00:00
|
|
|
if tt.want != nil {
|
|
|
|
grpc.AllFieldsSet(t, got.ProtoReflect())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_passkeyDetailsToPb(t *testing.T) {
|
|
|
|
type args struct {
|
|
|
|
details *domain.ObjectDetails
|
|
|
|
err error
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
want *user.CreatePasskeyRegistrationLinkResponse
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "an error",
|
|
|
|
args: args{
|
|
|
|
details: nil,
|
|
|
|
err: io.ErrClosedPipe,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ok",
|
|
|
|
args: args{
|
|
|
|
details: &domain.ObjectDetails{
|
|
|
|
Sequence: 22,
|
|
|
|
EventDate: time.Unix(3000, 22),
|
|
|
|
ResourceOwner: "me",
|
|
|
|
},
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
want: &user.CreatePasskeyRegistrationLinkResponse{
|
|
|
|
Details: &object.Details{
|
|
|
|
Sequence: 22,
|
|
|
|
ChangeDate: ×tamppb.Timestamp{
|
|
|
|
Seconds: 3000,
|
|
|
|
Nanos: 22,
|
|
|
|
},
|
|
|
|
ResourceOwner: "me",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
got, err := passkeyDetailsToPb(tt.args.details, tt.args.err)
|
|
|
|
require.ErrorIs(t, err, tt.args.err)
|
|
|
|
assert.Equal(t, tt.want, got)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_passkeyCodeDetailsToPb(t *testing.T) {
|
|
|
|
type args struct {
|
|
|
|
details *domain.PasskeyCodeDetails
|
|
|
|
err error
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
want *user.CreatePasskeyRegistrationLinkResponse
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "an error",
|
|
|
|
args: args{
|
|
|
|
details: nil,
|
|
|
|
err: io.ErrClosedPipe,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ok",
|
|
|
|
args: args{
|
|
|
|
details: &domain.PasskeyCodeDetails{
|
|
|
|
ObjectDetails: &domain.ObjectDetails{
|
|
|
|
Sequence: 22,
|
|
|
|
EventDate: time.Unix(3000, 22),
|
|
|
|
ResourceOwner: "me",
|
|
|
|
},
|
|
|
|
CodeID: "123",
|
|
|
|
Code: "456",
|
|
|
|
},
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
want: &user.CreatePasskeyRegistrationLinkResponse{
|
|
|
|
Details: &object.Details{
|
|
|
|
Sequence: 22,
|
|
|
|
ChangeDate: ×tamppb.Timestamp{
|
|
|
|
Seconds: 3000,
|
|
|
|
Nanos: 22,
|
|
|
|
},
|
|
|
|
ResourceOwner: "me",
|
|
|
|
},
|
|
|
|
Code: &user.PasskeyRegistrationCode{
|
|
|
|
Id: "123",
|
|
|
|
Code: "456",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
got, err := passkeyCodeDetailsToPb(tt.args.details, tt.args.err)
|
|
|
|
require.ErrorIs(t, err, tt.args.err)
|
|
|
|
assert.Equal(t, tt.want, got)
|
|
|
|
if tt.want != nil {
|
|
|
|
grpc.AllFieldsSet(t, got.ProtoReflect())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|