2022-01-20 15:40:25 +01:00
package query
import (
2024-01-17 10:00:10 +01:00
"context"
2022-01-20 15:40:25 +01:00
"database/sql"
"database/sql/driver"
"errors"
"fmt"
"regexp"
"testing"
2024-08-23 08:44:18 +02:00
"github.com/stretchr/testify/assert"
2024-01-17 10:00:10 +01:00
"github.com/stretchr/testify/require"
2022-01-20 15:40:25 +01:00
"golang.org/x/text/language"
2024-08-23 08:44:18 +02:00
"github.com/zitadel/zitadel/internal/api/authz"
2022-08-31 09:52:43 +02:00
"github.com/zitadel/zitadel/internal/database"
2022-04-27 01:01:45 +02:00
"github.com/zitadel/zitadel/internal/domain"
2023-12-08 16:30:55 +02:00
"github.com/zitadel/zitadel/internal/zerrors"
2022-01-20 15:40:25 +01:00
)
2024-08-23 08:44:18 +02:00
func TestUser_usersCheckPermission ( t * testing . T ) {
2024-01-17 10:00:10 +01:00
type want struct {
users [ ] * User
}
tests := [ ] struct {
name string
want want
users * Users
permissions [ ] string
} {
{
"permissions for all users" ,
want {
users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
& Users {
Users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
[ ] string { "first" , "second" , "third" } ,
} ,
{
"permissions for one user, first" ,
want {
users : [ ] * User {
{ ID : "first" } ,
} ,
} ,
& Users {
Users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
[ ] string { "first" } ,
} ,
{
"permissions for one user, second" ,
want {
users : [ ] * User {
{ ID : "second" } ,
} ,
} ,
& Users {
Users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
[ ] string { "second" } ,
} ,
{
"permissions for one user, third" ,
want {
users : [ ] * User {
{ ID : "third" } ,
} ,
} ,
& Users {
Users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
[ ] string { "third" } ,
} ,
{
"permissions for two users, first" ,
want {
users : [ ] * User {
{ ID : "first" } , { ID : "third" } ,
} ,
} ,
& Users {
Users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
[ ] string { "first" , "third" } ,
} ,
{
"permissions for two users, second" ,
want {
users : [ ] * User {
{ ID : "second" } , { ID : "third" } ,
} ,
} ,
& Users {
Users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
[ ] string { "second" , "third" } ,
} ,
{
"no permissions" ,
want {
users : [ ] * User { } ,
} ,
& Users {
Users : [ ] * User {
{ ID : "first" } , { ID : "second" } , { ID : "third" } ,
} ,
} ,
[ ] string { } ,
} ,
}
for _ , tt := range tests {
t . Run ( tt . name , func ( t * testing . T ) {
checkPermission := func ( ctx context . Context , permission , orgID , resourceID string ) ( err error ) {
for _ , perm := range tt . permissions {
if resourceID == perm {
return nil
}
}
return errors . New ( "failed" )
}
2024-08-15 06:37:06 +02:00
usersCheckPermission ( context . Background ( ) , tt . users , checkPermission )
2024-01-17 10:00:10 +01:00
require . Equal ( t , tt . want . users , tt . users . Users )
} )
}
}
2024-08-23 08:44:18 +02:00
func TestUser_userCheckPermission ( t * testing . T ) {
type args struct {
ctxData string
resourceowner string
user string
}
type perm struct {
resourceowner string
user string
}
tests := [ ] struct {
name string
wantErr bool
args args
permissions [ ] perm
} {
{
name : "permission, self" ,
args : args {
resourceowner : "org" ,
user : "user" ,
ctxData : "user" ,
} ,
permissions : [ ] perm { } ,
} ,
{
name : "permission, user" ,
args : args {
resourceowner : "org1" ,
user : "user1" ,
ctxData : "user2" ,
} ,
permissions : [ ] perm { { "org1" , "user1" } } ,
wantErr : false ,
} ,
{
name : "permission, org" ,
args : args {
resourceowner : "org1" ,
user : "user1" ,
ctxData : "user2" ,
} ,
permissions : [ ] perm { { "org1" , "user3" } } ,
} ,
{
name : "permission, none" ,
args : args {
resourceowner : "org1" ,
user : "user1" ,
ctxData : "user2" ,
} ,
permissions : [ ] perm { } ,
wantErr : true ,
} ,
}
for _ , tt := range tests {
t . Run ( tt . name , func ( t * testing . T ) {
checkPermission := func ( ctx context . Context , permission , orgID , resourceID string ) ( err error ) {
for _ , perm := range tt . permissions {
if resourceID == perm . user {
return nil
}
if orgID == perm . resourceowner {
return nil
}
}
return errors . New ( "failed" )
}
granted := userCheckPermission ( authz . SetCtxData ( context . Background ( ) , authz . CtxData { UserID : tt . args . ctxData } ) , tt . args . resourceowner , tt . args . user , checkPermission )
if tt . wantErr {
assert . Error ( t , granted )
} else {
assert . NoError ( t , granted )
}
} )
}
}
2022-01-20 15:40:25 +01:00
var (
2023-11-20 16:21:08 +01:00
loginNamesQuery = ` SELECT login_names.user_id, ARRAY_AGG(login_names.login_name)::TEXT[] AS loginnames, ARRAY_AGG(LOWER(login_names.login_name))::TEXT[] AS loginnames_lower, login_names.instance_id ` +
` FROM projections.login_names3 AS login_names ` +
` GROUP BY login_names.user_id, login_names.instance_id `
preferredLoginNameQuery = ` SELECT preferred_login_name.user_id, preferred_login_name.login_name, preferred_login_name.instance_id ` +
` FROM projections.login_names3 AS preferred_login_name ` +
2022-11-30 17:01:17 +01:00
` WHERE preferred_login_name.is_primary = $1 `
2024-06-18 13:27:44 +02:00
userQuery = ` SELECT projections.users13.id, ` +
` projections.users13.creation_date, ` +
` projections.users13.change_date, ` +
` projections.users13.resource_owner, ` +
` projections.users13.sequence, ` +
` projections.users13.state, ` +
` projections.users13.type, ` +
` projections.users13.username, ` +
2022-02-02 08:21:54 +01:00
` login_names.loginnames, ` +
2022-01-20 15:40:25 +01:00
` preferred_login_name.login_name, ` +
2024-06-18 13:27:44 +02:00
` projections.users13_humans.user_id, ` +
` projections.users13_humans.first_name, ` +
` projections.users13_humans.last_name, ` +
` projections.users13_humans.nick_name, ` +
` projections.users13_humans.display_name, ` +
` projections.users13_humans.preferred_language, ` +
` projections.users13_humans.gender, ` +
` projections.users13_humans.avatar_key, ` +
` projections.users13_humans.email, ` +
` projections.users13_humans.is_email_verified, ` +
` projections.users13_humans.phone, ` +
` projections.users13_humans.is_phone_verified, ` +
` projections.users13_humans.password_change_required, ` +
` projections.users13_humans.password_changed, ` +
` projections.users13_machines.user_id, ` +
` projections.users13_machines.name, ` +
` projections.users13_machines.description, ` +
` projections.users13_machines.secret, ` +
` projections.users13_machines.access_token_type, ` +
2022-10-17 21:19:15 +02:00
` COUNT(*) OVER () ` +
2024-06-18 13:27:44 +02:00
` FROM projections.users13 ` +
` LEFT JOIN projections.users13_humans ON projections.users13.id = projections.users13_humans.user_id AND projections.users13.instance_id = projections.users13_humans.instance_id ` +
` LEFT JOIN projections.users13_machines ON projections.users13.id = projections.users13_machines.user_id AND projections.users13.instance_id = projections.users13_machines.instance_id ` +
2022-01-20 15:40:25 +01:00
` LEFT JOIN ` +
2022-11-30 17:01:17 +01:00
` ( ` + loginNamesQuery + ` ) AS login_names ` +
2024-06-18 13:27:44 +02:00
` ON login_names.user_id = projections.users13.id AND login_names.instance_id = projections.users13.instance_id ` +
2022-01-20 15:40:25 +01:00
` LEFT JOIN ` +
2022-11-30 17:01:17 +01:00
` ( ` + preferredLoginNameQuery + ` ) AS preferred_login_name ` +
2024-06-18 13:27:44 +02:00
` ON preferred_login_name.user_id = projections.users13.id AND preferred_login_name.instance_id = projections.users13.instance_id ` +
2023-02-27 22:36:43 +01:00
` AS OF SYSTEM TIME '-1 ms' `
2022-01-20 15:40:25 +01:00
userCols = [ ] string {
"id" ,
"creation_date" ,
"change_date" ,
"resource_owner" ,
"sequence" ,
"state" ,
"type" ,
"username" ,
2022-02-02 08:21:54 +01:00
"loginnames" ,
2022-01-20 15:40:25 +01:00
"login_name" ,
2023-12-05 19:01:03 +02:00
// human
2022-01-20 15:40:25 +01:00
"user_id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"preferred_language" ,
"gender" ,
"avatar_key" ,
"email" ,
"is_email_verified" ,
"phone" ,
"is_phone_verified" ,
2024-03-28 07:21:21 +01:00
"password_change_required" ,
2024-06-18 13:27:44 +02:00
"password_changed" ,
2023-12-05 19:01:03 +02:00
// machine
2022-01-20 15:40:25 +01:00
"user_id" ,
"name" ,
"description" ,
2023-12-05 19:01:03 +02:00
"secret" ,
2023-02-08 09:06:34 +01:00
"access_token_type" ,
2022-10-17 21:19:15 +02:00
"count" ,
2022-01-20 15:40:25 +01:00
}
2024-06-18 13:27:44 +02:00
profileQuery = ` SELECT projections.users13.id, ` +
` projections.users13.creation_date, ` +
` projections.users13.change_date, ` +
` projections.users13.resource_owner, ` +
` projections.users13.sequence, ` +
` projections.users13_humans.user_id, ` +
` projections.users13_humans.first_name, ` +
` projections.users13_humans.last_name, ` +
` projections.users13_humans.nick_name, ` +
` projections.users13_humans.display_name, ` +
` projections.users13_humans.preferred_language, ` +
` projections.users13_humans.gender, ` +
` projections.users13_humans.avatar_key ` +
` FROM projections.users13 ` +
` LEFT JOIN projections.users13_humans ON projections.users13.id = projections.users13_humans.user_id AND projections.users13.instance_id = projections.users13_humans.instance_id ` +
2023-02-27 22:36:43 +01:00
` AS OF SYSTEM TIME '-1 ms' `
2022-01-20 15:40:25 +01:00
profileCols = [ ] string {
"id" ,
"creation_date" ,
"change_date" ,
"resource_owner" ,
"sequence" ,
"user_id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"preferred_language" ,
"gender" ,
"avatar_key" ,
}
2024-06-18 13:27:44 +02:00
emailQuery = ` SELECT projections.users13.id, ` +
` projections.users13.creation_date, ` +
` projections.users13.change_date, ` +
` projections.users13.resource_owner, ` +
` projections.users13.sequence, ` +
` projections.users13_humans.user_id, ` +
` projections.users13_humans.email, ` +
` projections.users13_humans.is_email_verified ` +
` FROM projections.users13 ` +
` LEFT JOIN projections.users13_humans ON projections.users13.id = projections.users13_humans.user_id AND projections.users13.instance_id = projections.users13_humans.instance_id ` +
2023-02-27 22:36:43 +01:00
` AS OF SYSTEM TIME '-1 ms' `
2022-01-20 15:40:25 +01:00
emailCols = [ ] string {
"id" ,
"creation_date" ,
"change_date" ,
"resource_owner" ,
"sequence" ,
"user_id" ,
"email" ,
"is_email_verified" ,
}
2024-06-18 13:27:44 +02:00
phoneQuery = ` SELECT projections.users13.id, ` +
` projections.users13.creation_date, ` +
` projections.users13.change_date, ` +
` projections.users13.resource_owner, ` +
` projections.users13.sequence, ` +
` projections.users13_humans.user_id, ` +
` projections.users13_humans.phone, ` +
` projections.users13_humans.is_phone_verified ` +
` FROM projections.users13 ` +
` LEFT JOIN projections.users13_humans ON projections.users13.id = projections.users13_humans.user_id AND projections.users13.instance_id = projections.users13_humans.instance_id ` +
2023-02-27 22:36:43 +01:00
` AS OF SYSTEM TIME '-1 ms' `
2022-01-20 15:40:25 +01:00
phoneCols = [ ] string {
"id" ,
"creation_date" ,
"change_date" ,
"resource_owner" ,
"sequence" ,
"user_id" ,
"phone" ,
"is_phone_verified" ,
}
2024-06-18 13:27:44 +02:00
userUniqueQuery = ` SELECT projections.users13.id, ` +
` projections.users13.state, ` +
` projections.users13.username, ` +
` projections.users13_humans.user_id, ` +
` projections.users13_humans.email, ` +
` projections.users13_humans.is_email_verified ` +
` FROM projections.users13 ` +
` LEFT JOIN projections.users13_humans ON projections.users13.id = projections.users13_humans.user_id AND projections.users13.instance_id = projections.users13_humans.instance_id ` +
2023-02-27 22:36:43 +01:00
` AS OF SYSTEM TIME '-1 ms' `
2022-01-20 15:40:25 +01:00
userUniqueCols = [ ] string {
"id" ,
"state" ,
"username" ,
"user_id" ,
"email" ,
"is_email_verified" ,
}
2024-06-18 13:27:44 +02:00
notifyUserQuery = ` SELECT projections.users13.id, ` +
` projections.users13.creation_date, ` +
` projections.users13.change_date, ` +
` projections.users13.resource_owner, ` +
` projections.users13.sequence, ` +
` projections.users13.state, ` +
` projections.users13.type, ` +
` projections.users13.username, ` +
2022-07-06 14:09:49 +02:00
` login_names.loginnames, ` +
` preferred_login_name.login_name, ` +
2024-06-18 13:27:44 +02:00
` projections.users13_humans.user_id, ` +
` projections.users13_humans.first_name, ` +
` projections.users13_humans.last_name, ` +
` projections.users13_humans.nick_name, ` +
` projections.users13_humans.display_name, ` +
` projections.users13_humans.preferred_language, ` +
` projections.users13_humans.gender, ` +
` projections.users13_humans.avatar_key, ` +
` projections.users13_notifications.user_id, ` +
` projections.users13_notifications.last_email, ` +
` projections.users13_notifications.verified_email, ` +
` projections.users13_notifications.last_phone, ` +
` projections.users13_notifications.verified_phone, ` +
` projections.users13_notifications.password_set, ` +
2022-10-17 21:19:15 +02:00
` COUNT(*) OVER () ` +
2024-06-18 13:27:44 +02:00
` FROM projections.users13 ` +
` LEFT JOIN projections.users13_humans ON projections.users13.id = projections.users13_humans.user_id AND projections.users13.instance_id = projections.users13_humans.instance_id ` +
` LEFT JOIN projections.users13_notifications ON projections.users13.id = projections.users13_notifications.user_id AND projections.users13.instance_id = projections.users13_notifications.instance_id ` +
2022-07-06 14:09:49 +02:00
` LEFT JOIN ` +
2022-11-30 17:01:17 +01:00
` ( ` + loginNamesQuery + ` ) AS login_names ` +
2024-06-18 13:27:44 +02:00
` ON login_names.user_id = projections.users13.id AND login_names.instance_id = projections.users13.instance_id ` +
2022-07-06 14:09:49 +02:00
` LEFT JOIN ` +
2022-11-30 17:01:17 +01:00
` ( ` + preferredLoginNameQuery + ` ) AS preferred_login_name ` +
2024-06-18 13:27:44 +02:00
` ON preferred_login_name.user_id = projections.users13.id AND preferred_login_name.instance_id = projections.users13.instance_id ` +
2023-02-27 22:36:43 +01:00
` AS OF SYSTEM TIME '-1 ms' `
2022-07-06 14:09:49 +02:00
notifyUserCols = [ ] string {
"id" ,
"creation_date" ,
"change_date" ,
"resource_owner" ,
"sequence" ,
"state" ,
"type" ,
"username" ,
"loginnames" ,
"login_name" ,
2023-12-05 19:01:03 +02:00
// human
2022-07-06 14:09:49 +02:00
"user_id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"preferred_language" ,
"gender" ,
"avatar_key" ,
2023-12-05 19:01:03 +02:00
// machine
2022-07-06 14:09:49 +02:00
"user_id" ,
"last_email" ,
"verified_email" ,
"last_phone" ,
"verified_phone" ,
"password_set" ,
2022-10-17 21:19:15 +02:00
"count" ,
2022-07-06 14:09:49 +02:00
}
2024-06-18 13:27:44 +02:00
usersQuery = ` SELECT projections.users13.id, ` +
` projections.users13.creation_date, ` +
` projections.users13.change_date, ` +
` projections.users13.resource_owner, ` +
` projections.users13.sequence, ` +
` projections.users13.state, ` +
` projections.users13.type, ` +
` projections.users13.username, ` +
2022-02-02 08:21:54 +01:00
` login_names.loginnames, ` +
2022-01-20 15:40:25 +01:00
` preferred_login_name.login_name, ` +
2024-06-18 13:27:44 +02:00
` projections.users13_humans.user_id, ` +
` projections.users13_humans.first_name, ` +
` projections.users13_humans.last_name, ` +
` projections.users13_humans.nick_name, ` +
` projections.users13_humans.display_name, ` +
` projections.users13_humans.preferred_language, ` +
` projections.users13_humans.gender, ` +
` projections.users13_humans.avatar_key, ` +
` projections.users13_humans.email, ` +
` projections.users13_humans.is_email_verified, ` +
` projections.users13_humans.phone, ` +
` projections.users13_humans.is_phone_verified, ` +
` projections.users13_humans.password_change_required, ` +
` projections.users13_humans.password_changed, ` +
` projections.users13_machines.user_id, ` +
` projections.users13_machines.name, ` +
` projections.users13_machines.description, ` +
` projections.users13_machines.secret, ` +
` projections.users13_machines.access_token_type, ` +
2022-01-20 15:40:25 +01:00
` COUNT(*) OVER () ` +
2024-06-18 13:27:44 +02:00
` FROM projections.users13 ` +
` LEFT JOIN projections.users13_humans ON projections.users13.id = projections.users13_humans.user_id AND projections.users13.instance_id = projections.users13_humans.instance_id ` +
` LEFT JOIN projections.users13_machines ON projections.users13.id = projections.users13_machines.user_id AND projections.users13.instance_id = projections.users13_machines.instance_id ` +
2022-01-20 15:40:25 +01:00
` LEFT JOIN ` +
2022-11-30 17:01:17 +01:00
` ( ` + loginNamesQuery + ` ) AS login_names ` +
2024-06-18 13:27:44 +02:00
` ON login_names.user_id = projections.users13.id AND login_names.instance_id = projections.users13.instance_id ` +
2022-01-20 15:40:25 +01:00
` LEFT JOIN ` +
2022-11-30 17:01:17 +01:00
` ( ` + preferredLoginNameQuery + ` ) AS preferred_login_name ` +
2024-06-18 13:27:44 +02:00
` ON preferred_login_name.user_id = projections.users13.id AND preferred_login_name.instance_id = projections.users13.instance_id ` +
2023-02-27 22:36:43 +01:00
` AS OF SYSTEM TIME '-1 ms' `
2022-01-20 15:40:25 +01:00
usersCols = [ ] string {
"id" ,
"creation_date" ,
"change_date" ,
"resource_owner" ,
"sequence" ,
"state" ,
"type" ,
"username" ,
2022-02-02 08:21:54 +01:00
"loginnames" ,
2022-01-20 15:40:25 +01:00
"login_name" ,
2023-12-05 19:01:03 +02:00
// human
2022-01-20 15:40:25 +01:00
"user_id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"preferred_language" ,
"gender" ,
"avatar_key" ,
"email" ,
"is_email_verified" ,
"phone" ,
"is_phone_verified" ,
2024-03-28 07:21:21 +01:00
"password_change_required" ,
2024-06-18 13:27:44 +02:00
"password_changed" ,
2023-12-05 19:01:03 +02:00
// machine
2022-01-20 15:40:25 +01:00
"user_id" ,
"name" ,
"description" ,
2023-12-05 19:01:03 +02:00
"secret" ,
2023-02-08 09:06:34 +01:00
"access_token_type" ,
2022-01-20 15:40:25 +01:00
"count" ,
}
)
func Test_UserPrepares ( t * testing . T ) {
type want struct {
sqlExpectations sqlExpectation
err checkErr
}
tests := [ ] struct {
name string
prepare interface { }
want want
object interface { }
} {
{
2023-02-27 22:36:43 +01:00
name : "prepareUserQuery no result" ,
prepare : prepareUserQuery ,
2022-01-20 15:40:25 +01:00
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( userQuery ) ,
nil ,
nil ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsNotFound ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.NotFoundError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * User ) ( nil ) ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareUserQuery human found" ,
prepare : prepareUserQuery ,
2022-01-20 15:40:25 +01:00
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( userQuery ) ,
userCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeHuman ,
"username" ,
2023-10-19 12:19:10 +02:00
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
"login_name1" ,
2023-12-05 19:01:03 +02:00
// human
2022-01-20 15:40:25 +01:00
"id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"de" ,
domain . GenderUnspecified ,
"avatar_key" ,
"email" ,
true ,
"phone" ,
true ,
2024-03-28 07:21:21 +01:00
true ,
2024-06-18 13:27:44 +02:00
testNow ,
2023-12-05 19:01:03 +02:00
// machine
2022-01-20 15:40:25 +01:00
nil ,
nil ,
nil ,
2023-01-31 20:52:47 +01:00
nil ,
2023-02-08 09:06:34 +01:00
nil ,
2022-10-17 21:19:15 +02:00
1 ,
2022-01-20 15:40:25 +01:00
} ,
) ,
} ,
object : & User {
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
State : domain . UserStateActive ,
Type : domain . UserTypeHuman ,
Username : "username" ,
2023-10-19 12:19:10 +02:00
LoginNames : database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
PreferredLoginName : "login_name1" ,
Human : & Human {
2024-03-28 07:21:21 +01:00
FirstName : "first_name" ,
LastName : "last_name" ,
NickName : "nick_name" ,
DisplayName : "display_name" ,
AvatarKey : "avatar_key" ,
PreferredLanguage : language . German ,
Gender : domain . GenderUnspecified ,
Email : "email" ,
IsEmailVerified : true ,
Phone : "phone" ,
IsPhoneVerified : true ,
PasswordChangeRequired : true ,
2024-06-18 13:27:44 +02:00
PasswordChanged : testNow ,
2022-01-20 15:40:25 +01:00
} ,
} ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareUserQuery machine found" ,
prepare : prepareUserQuery ,
2022-01-20 15:40:25 +01:00
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( userQuery ) ,
userCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeMachine ,
"username" ,
2023-10-19 12:19:10 +02:00
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
"login_name1" ,
2023-12-05 19:01:03 +02:00
// human
2022-01-20 15:40:25 +01:00
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
2024-03-28 07:21:21 +01:00
nil ,
2024-06-18 13:27:44 +02:00
nil ,
2023-12-05 19:01:03 +02:00
// machine
2022-01-20 15:40:25 +01:00
"id" ,
"name" ,
"description" ,
2023-12-05 19:01:03 +02:00
nil ,
2023-02-08 09:06:34 +01:00
domain . OIDCTokenTypeBearer ,
2022-10-17 21:19:15 +02:00
1 ,
2022-01-20 15:40:25 +01:00
} ,
) ,
} ,
object : & User {
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
State : domain . UserStateActive ,
Type : domain . UserTypeMachine ,
Username : "username" ,
2023-10-19 12:19:10 +02:00
LoginNames : database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
PreferredLoginName : "login_name1" ,
Machine : & Machine {
2023-02-08 09:06:34 +01:00
Name : "name" ,
Description : "description" ,
2024-04-05 12:35:49 +03:00
EncodedSecret : "" ,
2023-12-05 19:01:03 +02:00
AccessTokenType : domain . OIDCTokenTypeBearer ,
} ,
} ,
} ,
{
name : "prepareUserQuery machine with secret found" ,
prepare : prepareUserQuery ,
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( userQuery ) ,
userCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeMachine ,
"username" ,
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
"login_name1" ,
// human
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
2024-03-28 07:21:21 +01:00
nil ,
2024-06-18 13:27:44 +02:00
nil ,
2023-12-05 19:01:03 +02:00
// machine
"id" ,
"name" ,
"description" ,
2024-04-05 12:35:49 +03:00
"secret" ,
2023-12-05 19:01:03 +02:00
domain . OIDCTokenTypeBearer ,
1 ,
} ,
) ,
} ,
object : & User {
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
State : domain . UserStateActive ,
Type : domain . UserTypeMachine ,
Username : "username" ,
LoginNames : database . TextArray [ string ] { "login_name1" , "login_name2" } ,
PreferredLoginName : "login_name1" ,
Machine : & Machine {
2024-04-05 12:35:49 +03:00
Name : "name" ,
Description : "description" ,
EncodedSecret : "secret" ,
2023-02-08 09:06:34 +01:00
AccessTokenType : domain . OIDCTokenTypeBearer ,
2022-01-20 15:40:25 +01:00
} ,
} ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareUserQuery sql err" ,
prepare : prepareUserQuery ,
2022-01-20 15:40:25 +01:00
want : want {
sqlExpectations : mockQueryErr (
regexp . QuoteMeta ( userQuery ) ,
sql . ErrConnDone ,
) ,
err : func ( err error ) ( error , bool ) {
if ! errors . Is ( err , sql . ErrConnDone ) {
return fmt . Errorf ( "err should be sql.ErrConnDone got: %w" , err ) , false
}
return nil , true
} ,
} ,
2023-08-22 14:49:02 +02:00
object : ( * User ) ( nil ) ,
2022-01-20 15:40:25 +01:00
} ,
{
name : "prepareProfileQuery no result" ,
prepare : prepareProfileQuery ,
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( profileQuery ) ,
nil ,
nil ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsNotFound ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.NotFoundError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * Profile ) ( nil ) ,
} ,
{
name : "prepareProfileQuery human found" ,
prepare : prepareProfileQuery ,
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( profileQuery ) ,
profileCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
"id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"de" ,
domain . GenderUnspecified ,
"avatar_key" ,
} ,
) ,
} ,
object : & Profile {
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
FirstName : "first_name" ,
LastName : "last_name" ,
NickName : "nick_name" ,
DisplayName : "display_name" ,
AvatarKey : "avatar_key" ,
PreferredLanguage : language . German ,
Gender : domain . GenderUnspecified ,
} ,
} ,
{
name : "prepareProfileQuery not human found (error)" ,
prepare : prepareProfileQuery ,
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( profileQuery ) ,
profileCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
} ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsPreconditionFailed ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.PredconditionError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * Profile ) ( nil ) ,
} ,
{
name : "prepareProfileQuery sql err" ,
prepare : prepareProfileQuery ,
want : want {
sqlExpectations : mockQueryErr (
regexp . QuoteMeta ( profileQuery ) ,
sql . ErrConnDone ,
) ,
err : func ( err error ) ( error , bool ) {
if ! errors . Is ( err , sql . ErrConnDone ) {
return fmt . Errorf ( "err should be sql.ErrConnDone got: %w" , err ) , false
}
return nil , true
} ,
} ,
2023-08-22 14:49:02 +02:00
object : ( * Profile ) ( nil ) ,
2022-01-20 15:40:25 +01:00
} ,
{
name : "prepareEmailQuery no result" ,
prepare : prepareEmailQuery ,
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( emailQuery ) ,
nil ,
nil ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsNotFound ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.NotFoundError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * Email ) ( nil ) ,
} ,
{
name : "prepareEmailQuery human found" ,
prepare : prepareEmailQuery ,
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( emailQuery ) ,
emailCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
//domain.UserStateActive,
"id" ,
"email" ,
true ,
} ,
) ,
} ,
object : & Email {
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
//State: domain.UserStateActive,
Email : "email" ,
IsVerified : true ,
} ,
} ,
{
name : "prepareEmailQuery not human found (error)" ,
prepare : prepareEmailQuery ,
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( emailQuery ) ,
emailCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
//domain.UserStateActive,
nil ,
nil ,
nil ,
} ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsPreconditionFailed ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.PredconditionError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * Email ) ( nil ) ,
} ,
{
name : "prepareEmailQuery sql err" ,
prepare : prepareEmailQuery ,
want : want {
sqlExpectations : mockQueryErr (
regexp . QuoteMeta ( emailQuery ) ,
sql . ErrConnDone ,
) ,
err : func ( err error ) ( error , bool ) {
if ! errors . Is ( err , sql . ErrConnDone ) {
return fmt . Errorf ( "err should be sql.ErrConnDone got: %w" , err ) , false
}
return nil , true
} ,
} ,
2023-08-22 14:49:02 +02:00
object : ( * Email ) ( nil ) ,
2022-01-20 15:40:25 +01:00
} ,
{
name : "preparePhoneQuery no result" ,
prepare : preparePhoneQuery ,
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( phoneQuery ) ,
nil ,
nil ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsNotFound ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.NotFoundError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * Phone ) ( nil ) ,
} ,
{
name : "preparePhoneQuery human found" ,
prepare : preparePhoneQuery ,
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( phoneQuery ) ,
phoneCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
//domain.UserStateActive,
"id" ,
"phone" ,
true ,
} ,
) ,
} ,
object : & Phone {
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
//State: domain.UserStateActive,
Phone : "phone" ,
IsVerified : true ,
} ,
} ,
{
name : "preparePhoneQuery not human found (error)" ,
prepare : preparePhoneQuery ,
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( phoneQuery ) ,
phoneCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
//domain.UserStateActive,
nil ,
nil ,
nil ,
} ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsPreconditionFailed ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.PredconditionError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * Phone ) ( nil ) ,
} ,
{
name : "preparePhoneQuery sql err" ,
prepare : preparePhoneQuery ,
want : want {
sqlExpectations : mockQueryErr (
regexp . QuoteMeta ( phoneQuery ) ,
sql . ErrConnDone ,
) ,
err : func ( err error ) ( error , bool ) {
if ! errors . Is ( err , sql . ErrConnDone ) {
return fmt . Errorf ( "err should be sql.ErrConnDone got: %w" , err ) , false
}
return nil , true
} ,
} ,
2023-08-22 14:49:02 +02:00
object : ( * Phone ) ( nil ) ,
2022-01-20 15:40:25 +01:00
} ,
{
name : "prepareUserUniqueQuery no result" ,
prepare : prepareUserUniqueQuery ,
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( userUniqueQuery ) ,
nil ,
nil ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsNotFound ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.NotFoundError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : true ,
} ,
{
name : "prepareUserUniqueQuery found" ,
prepare : prepareUserUniqueQuery ,
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( userUniqueQuery ) ,
userUniqueCols ,
[ ] driver . Value {
"id" ,
domain . UserStateActive ,
"username" ,
"id" ,
"email" ,
true ,
} ,
) ,
} ,
object : false ,
} ,
{
name : "prepareUserUniqueQuery sql err" ,
prepare : prepareUserUniqueQuery ,
want : want {
sqlExpectations : mockQueryErr (
regexp . QuoteMeta ( userUniqueQuery ) ,
sql . ErrConnDone ,
) ,
err : func ( err error ) ( error , bool ) {
if ! errors . Is ( err , sql . ErrConnDone ) {
return fmt . Errorf ( "err should be sql.ErrConnDone got: %w" , err ) , false
}
return nil , true
} ,
} ,
2023-08-22 14:49:02 +02:00
object : false ,
2022-01-20 15:40:25 +01:00
} ,
2022-07-06 14:09:49 +02:00
{
2023-02-27 22:36:43 +01:00
name : "prepareNotifyUserQuery no result" ,
prepare : prepareNotifyUserQuery ,
2022-07-06 14:09:49 +02:00
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-07-06 14:09:49 +02:00
regexp . QuoteMeta ( notifyUserQuery ) ,
nil ,
nil ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsNotFound ( err ) {
2022-07-06 14:09:49 +02:00
return fmt . Errorf ( "err should be zitadel.NotFoundError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * NotifyUser ) ( nil ) ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareNotifyUserQuery notify found" ,
prepare : prepareNotifyUserQuery ,
2022-07-06 14:09:49 +02:00
want : want {
sqlExpectations : mockQuery (
regexp . QuoteMeta ( notifyUserQuery ) ,
notifyUserCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeHuman ,
"username" ,
2023-10-19 12:19:10 +02:00
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-07-06 14:09:49 +02:00
"login_name1" ,
2023-12-05 19:01:03 +02:00
// human
2022-07-06 14:09:49 +02:00
"id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"de" ,
domain . GenderUnspecified ,
"avatar_key" ,
//notify
"id" ,
"lastEmail" ,
"verifiedEmail" ,
"lastPhone" ,
"verifiedPhone" ,
true ,
2022-10-17 21:19:15 +02:00
1 ,
2022-07-06 14:09:49 +02:00
} ,
) ,
} ,
object : & NotifyUser {
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
State : domain . UserStateActive ,
Type : domain . UserTypeHuman ,
Username : "username" ,
2023-10-19 12:19:10 +02:00
LoginNames : database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-07-06 14:09:49 +02:00
PreferredLoginName : "login_name1" ,
FirstName : "first_name" ,
LastName : "last_name" ,
NickName : "nick_name" ,
DisplayName : "display_name" ,
AvatarKey : "avatar_key" ,
PreferredLanguage : language . German ,
Gender : domain . GenderUnspecified ,
LastEmail : "lastEmail" ,
VerifiedEmail : "verifiedEmail" ,
LastPhone : "lastPhone" ,
VerifiedPhone : "verifiedPhone" ,
PasswordSet : true ,
} ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareNotifyUserQuery not notify found (error)" ,
prepare : prepareNotifyUserQuery ,
2022-07-06 14:09:49 +02:00
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQueryScanErr (
2022-07-06 14:09:49 +02:00
regexp . QuoteMeta ( notifyUserQuery ) ,
notifyUserCols ,
[ ] driver . Value {
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeHuman ,
"username" ,
2023-10-19 12:19:10 +02:00
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-07-06 14:09:49 +02:00
"login_name1" ,
2023-12-05 19:01:03 +02:00
// human
2022-07-06 14:09:49 +02:00
"id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"de" ,
domain . GenderUnspecified ,
"avatar_key" ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
2022-10-17 21:19:15 +02:00
1 ,
2022-07-06 14:09:49 +02:00
} ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsPreconditionFailed ( err ) {
2022-07-06 14:09:49 +02:00
return fmt . Errorf ( "err should be zitadel.PredconditionError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : ( * NotifyUser ) ( nil ) ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareNotifyUserQuery sql err" ,
prepare : prepareNotifyUserQuery ,
2022-07-06 14:09:49 +02:00
want : want {
sqlExpectations : mockQueryErr (
regexp . QuoteMeta ( notifyUserQuery ) ,
sql . ErrConnDone ,
) ,
err : func ( err error ) ( error , bool ) {
if ! errors . Is ( err , sql . ErrConnDone ) {
return fmt . Errorf ( "err should be sql.ErrConnDone got: %w" , err ) , false
}
return nil , true
} ,
} ,
2023-08-22 14:49:02 +02:00
object : ( * NotifyUser ) ( nil ) ,
2022-07-06 14:09:49 +02:00
} ,
2022-01-20 15:40:25 +01:00
{
2023-02-27 22:36:43 +01:00
name : "prepareUsersQuery no result" ,
prepare : prepareUsersQuery ,
2022-01-20 15:40:25 +01:00
want : want {
2023-08-22 14:49:02 +02:00
sqlExpectations : mockQuery (
2022-01-20 15:40:25 +01:00
regexp . QuoteMeta ( usersQuery ) ,
nil ,
nil ,
) ,
err : func ( err error ) ( error , bool ) {
2023-12-08 16:30:55 +02:00
if ! zerrors . IsNotFound ( err ) {
2022-01-20 15:40:25 +01:00
return fmt . Errorf ( "err should be zitadel.NotFoundError got: %w" , err ) , false
}
return nil , true
} ,
} ,
object : & Users { Users : [ ] * User { } } ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareUsersQuery one result" ,
prepare : prepareUsersQuery ,
2022-01-20 15:40:25 +01:00
want : want {
sqlExpectations : mockQueries (
regexp . QuoteMeta ( usersQuery ) ,
usersCols ,
[ ] [ ] driver . Value {
{
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeHuman ,
"username" ,
2023-10-19 12:19:10 +02:00
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
"login_name1" ,
2023-12-05 19:01:03 +02:00
// human
2022-01-20 15:40:25 +01:00
"id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"de" ,
domain . GenderUnspecified ,
"avatar_key" ,
"email" ,
true ,
"phone" ,
true ,
2024-03-28 07:21:21 +01:00
true ,
2024-06-18 13:27:44 +02:00
testNow ,
2023-12-05 19:01:03 +02:00
// machine
2022-01-20 15:40:25 +01:00
nil ,
nil ,
nil ,
2023-01-31 20:52:47 +01:00
nil ,
2023-02-08 09:06:34 +01:00
nil ,
2022-01-20 15:40:25 +01:00
} ,
} ,
) ,
} ,
object : & Users {
SearchResponse : SearchResponse {
Count : 1 ,
} ,
Users : [ ] * User {
{
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
State : domain . UserStateActive ,
Type : domain . UserTypeHuman ,
Username : "username" ,
2023-10-19 12:19:10 +02:00
LoginNames : database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
PreferredLoginName : "login_name1" ,
Human : & Human {
2024-03-28 07:21:21 +01:00
FirstName : "first_name" ,
LastName : "last_name" ,
NickName : "nick_name" ,
DisplayName : "display_name" ,
AvatarKey : "avatar_key" ,
PreferredLanguage : language . German ,
Gender : domain . GenderUnspecified ,
Email : "email" ,
IsEmailVerified : true ,
Phone : "phone" ,
IsPhoneVerified : true ,
PasswordChangeRequired : true ,
2024-06-18 13:27:44 +02:00
PasswordChanged : testNow ,
2022-01-20 15:40:25 +01:00
} ,
} ,
} ,
} ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareUsersQuery multiple results" ,
prepare : prepareUsersQuery ,
2022-01-20 15:40:25 +01:00
want : want {
sqlExpectations : mockQueries (
regexp . QuoteMeta ( usersQuery ) ,
usersCols ,
[ ] [ ] driver . Value {
{
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeHuman ,
"username" ,
2023-10-19 12:19:10 +02:00
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
"login_name1" ,
2023-12-05 19:01:03 +02:00
// human
2022-01-20 15:40:25 +01:00
"id" ,
"first_name" ,
"last_name" ,
"nick_name" ,
"display_name" ,
"de" ,
domain . GenderUnspecified ,
"avatar_key" ,
"email" ,
true ,
"phone" ,
true ,
2024-03-28 07:21:21 +01:00
true ,
2024-06-18 13:27:44 +02:00
testNow ,
2023-12-05 19:01:03 +02:00
// machine
2022-01-20 15:40:25 +01:00
nil ,
nil ,
nil ,
2023-01-31 20:52:47 +01:00
nil ,
2023-02-08 09:06:34 +01:00
nil ,
2022-01-20 15:40:25 +01:00
} ,
{
"id" ,
testNow ,
testNow ,
"resource_owner" ,
uint64 ( 20211108 ) ,
domain . UserStateActive ,
domain . UserTypeMachine ,
"username" ,
2023-10-19 12:19:10 +02:00
database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
"login_name1" ,
2023-12-05 19:01:03 +02:00
// human
2022-01-20 15:40:25 +01:00
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
nil ,
2024-03-28 07:21:21 +01:00
nil ,
2024-06-18 13:27:44 +02:00
nil ,
2023-12-05 19:01:03 +02:00
// machine
2022-01-20 15:40:25 +01:00
"id" ,
"name" ,
"description" ,
2024-04-05 12:35:49 +03:00
"secret" ,
2023-02-08 09:06:34 +01:00
domain . OIDCTokenTypeBearer ,
2022-01-20 15:40:25 +01:00
} ,
} ,
) ,
} ,
object : & Users {
SearchResponse : SearchResponse {
Count : 2 ,
} ,
Users : [ ] * User {
{
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
State : domain . UserStateActive ,
Type : domain . UserTypeHuman ,
Username : "username" ,
2023-10-19 12:19:10 +02:00
LoginNames : database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
PreferredLoginName : "login_name1" ,
Human : & Human {
2024-03-28 07:21:21 +01:00
FirstName : "first_name" ,
LastName : "last_name" ,
NickName : "nick_name" ,
DisplayName : "display_name" ,
AvatarKey : "avatar_key" ,
PreferredLanguage : language . German ,
Gender : domain . GenderUnspecified ,
Email : "email" ,
IsEmailVerified : true ,
Phone : "phone" ,
IsPhoneVerified : true ,
PasswordChangeRequired : true ,
2024-06-18 13:27:44 +02:00
PasswordChanged : testNow ,
2022-01-20 15:40:25 +01:00
} ,
} ,
{
ID : "id" ,
CreationDate : testNow ,
ChangeDate : testNow ,
ResourceOwner : "resource_owner" ,
Sequence : 20211108 ,
State : domain . UserStateActive ,
Type : domain . UserTypeMachine ,
Username : "username" ,
2023-10-19 12:19:10 +02:00
LoginNames : database . TextArray [ string ] { "login_name1" , "login_name2" } ,
2022-01-20 15:40:25 +01:00
PreferredLoginName : "login_name1" ,
Machine : & Machine {
2024-04-05 12:35:49 +03:00
Name : "name" ,
Description : "description" ,
EncodedSecret : "secret" ,
2023-02-08 09:06:34 +01:00
AccessTokenType : domain . OIDCTokenTypeBearer ,
2022-01-20 15:40:25 +01:00
} ,
} ,
} ,
} ,
} ,
{
2023-02-27 22:36:43 +01:00
name : "prepareUsersQuery sql err" ,
prepare : prepareUsersQuery ,
2022-01-20 15:40:25 +01:00
want : want {
sqlExpectations : mockQueryErr (
regexp . QuoteMeta ( usersQuery ) ,
sql . ErrConnDone ,
) ,
err : func ( err error ) ( error , bool ) {
if ! errors . Is ( err , sql . ErrConnDone ) {
return fmt . Errorf ( "err should be sql.ErrConnDone got: %w" , err ) , false
}
return nil , true
} ,
} ,
2023-08-22 14:49:02 +02:00
object : ( * Users ) ( nil ) ,
2022-01-20 15:40:25 +01:00
} ,
}
for _ , tt := range tests {
t . Run ( tt . name , func ( t * testing . T ) {
2023-02-27 22:36:43 +01:00
assertPrepare ( t , tt . prepare , tt . object , tt . want . sqlExpectations , tt . want . err , defaultPrepareArgs ... )
2022-01-20 15:40:25 +01:00
} )
}
}