mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-20 21:39:18 +00:00 
			
		
		
		
	 f680dd934d
			
		
	
	f680dd934d
	
	
	
		
			
			* chore: rename package errors to zerrors * rename package errors to gerrors * fix error related linting issues * fix zitadel error assertion * fix gosimple linting issues * fix deprecated linting issues * resolve gci linting issues * fix import structure --------- Co-authored-by: Elio Bischof <elio@zitadel.com>
		
			
				
	
	
		
			284 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			284 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package command
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"go.uber.org/mock/gomock"
 | |
| 
 | |
| 	"github.com/zitadel/zitadel/internal/crypto"
 | |
| 	"github.com/zitadel/zitadel/internal/domain"
 | |
| 	"github.com/zitadel/zitadel/internal/eventstore"
 | |
| 	"github.com/zitadel/zitadel/internal/eventstore/v1/models"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/idpconfig"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/org"
 | |
| 	"github.com/zitadel/zitadel/internal/zerrors"
 | |
| )
 | |
| 
 | |
| func TestCommandSide_ChangeIDPJWTConfig(t *testing.T) {
 | |
| 	type fields struct {
 | |
| 		eventstore   *eventstore.Eventstore
 | |
| 		secretCrypto crypto.EncryptionAlgorithm
 | |
| 	}
 | |
| 	type (
 | |
| 		args struct {
 | |
| 			ctx           context.Context
 | |
| 			config        *domain.JWTIDPConfig
 | |
| 			resourceOwner string
 | |
| 		}
 | |
| 	)
 | |
| 	type res struct {
 | |
| 		want *domain.JWTIDPConfig
 | |
| 		err  func(error) bool
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name   string
 | |
| 		fields fields
 | |
| 		args   args
 | |
| 		res    res
 | |
| 	}{
 | |
| 		{
 | |
| 			name: "resourceowner missing, error",
 | |
| 			fields: fields{
 | |
| 				eventstore: eventstoreExpect(
 | |
| 					t,
 | |
| 				),
 | |
| 			},
 | |
| 			args: args{
 | |
| 				ctx: context.Background(),
 | |
| 				config: &domain.JWTIDPConfig{
 | |
| 					IDPConfigID: "config1",
 | |
| 				},
 | |
| 			},
 | |
| 			res: res{
 | |
| 				err: zerrors.IsErrorInvalidArgument,
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "invalid config, error",
 | |
| 			fields: fields{
 | |
| 				eventstore: eventstoreExpect(
 | |
| 					t,
 | |
| 				),
 | |
| 			},
 | |
| 			args: args{
 | |
| 				ctx:           context.Background(),
 | |
| 				config:        &domain.JWTIDPConfig{},
 | |
| 				resourceOwner: "org1",
 | |
| 			},
 | |
| 			res: res{
 | |
| 				err: zerrors.IsErrorInvalidArgument,
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "idp config not existing, not found error",
 | |
| 			fields: fields{
 | |
| 				eventstore: eventstoreExpect(
 | |
| 					t,
 | |
| 					expectFilter(),
 | |
| 				),
 | |
| 			},
 | |
| 			args: args{
 | |
| 				ctx: context.Background(),
 | |
| 				config: &domain.JWTIDPConfig{
 | |
| 					IDPConfigID: "config1",
 | |
| 				},
 | |
| 				resourceOwner: "org1",
 | |
| 			},
 | |
| 			res: res{
 | |
| 				err: zerrors.IsNotFound,
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "idp config removed, not found error",
 | |
| 			fields: fields{
 | |
| 				eventstore: eventstoreExpect(
 | |
| 					t,
 | |
| 					expectFilter(
 | |
| 						eventFromEventPusher(
 | |
| 							org.NewIDPConfigAddedEvent(context.Background(),
 | |
| 								&org.NewAggregate("org1").Aggregate,
 | |
| 								"config1",
 | |
| 								"name1",
 | |
| 								domain.IDPConfigTypeJWT,
 | |
| 								domain.IDPConfigStylingTypeGoogle,
 | |
| 								false,
 | |
| 							),
 | |
| 						),
 | |
| 						eventFromEventPusher(
 | |
| 							org.NewIDPJWTConfigAddedEvent(context.Background(),
 | |
| 								&org.NewAggregate("org1").Aggregate,
 | |
| 								"config1",
 | |
| 								"jwt-endpoint",
 | |
| 								"issuer",
 | |
| 								"keys-endpoint",
 | |
| 								"auth",
 | |
| 							),
 | |
| 						),
 | |
| 						eventFromEventPusher(
 | |
| 							org.NewIDPConfigRemovedEvent(context.Background(),
 | |
| 								&org.NewAggregate("org1").Aggregate,
 | |
| 								"config1",
 | |
| 								"name",
 | |
| 							),
 | |
| 						),
 | |
| 					),
 | |
| 				),
 | |
| 			},
 | |
| 			args: args{
 | |
| 				ctx: context.Background(),
 | |
| 				config: &domain.JWTIDPConfig{
 | |
| 					IDPConfigID: "config1",
 | |
| 				},
 | |
| 				resourceOwner: "org1",
 | |
| 			},
 | |
| 			res: res{
 | |
| 				err: zerrors.IsNotFound,
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "no changes, precondition error",
 | |
| 			fields: fields{
 | |
| 				eventstore: eventstoreExpect(
 | |
| 					t,
 | |
| 					expectFilter(
 | |
| 						eventFromEventPusher(
 | |
| 							org.NewIDPConfigAddedEvent(context.Background(),
 | |
| 								&org.NewAggregate("org1").Aggregate,
 | |
| 								"config1",
 | |
| 								"name1",
 | |
| 								domain.IDPConfigTypeJWT,
 | |
| 								domain.IDPConfigStylingTypeGoogle,
 | |
| 								false,
 | |
| 							),
 | |
| 						),
 | |
| 						eventFromEventPusher(
 | |
| 							org.NewIDPJWTConfigAddedEvent(context.Background(),
 | |
| 								&org.NewAggregate("org1").Aggregate,
 | |
| 								"config1",
 | |
| 								"jwt-endpoint",
 | |
| 								"issuer",
 | |
| 								"keys-endpoint",
 | |
| 								"auth",
 | |
| 							),
 | |
| 						),
 | |
| 					),
 | |
| 				),
 | |
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			args: args{
 | |
| 				ctx: context.Background(),
 | |
| 				config: &domain.JWTIDPConfig{
 | |
| 					IDPConfigID:  "config1",
 | |
| 					JWTEndpoint:  "jwt-endpoint",
 | |
| 					Issuer:       "issuer",
 | |
| 					KeysEndpoint: "keys-endpoint",
 | |
| 					HeaderName:   "auth",
 | |
| 				},
 | |
| 				resourceOwner: "org1",
 | |
| 			},
 | |
| 			res: res{
 | |
| 				err: zerrors.IsPreconditionFailed,
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "idp config jwt add, ok",
 | |
| 			fields: fields{
 | |
| 				eventstore: eventstoreExpect(
 | |
| 					t,
 | |
| 					expectFilter(
 | |
| 						eventFromEventPusher(
 | |
| 							org.NewIDPConfigAddedEvent(context.Background(),
 | |
| 								&org.NewAggregate("org1").Aggregate,
 | |
| 								"config1",
 | |
| 								"name1",
 | |
| 								domain.IDPConfigTypeJWT,
 | |
| 								domain.IDPConfigStylingTypeGoogle,
 | |
| 								false,
 | |
| 							),
 | |
| 						),
 | |
| 						eventFromEventPusher(
 | |
| 							org.NewIDPJWTConfigAddedEvent(context.Background(),
 | |
| 								&org.NewAggregate("org1").Aggregate,
 | |
| 								"config1",
 | |
| 								"jwt-endpoint",
 | |
| 								"issuer",
 | |
| 								"keys-endpoint",
 | |
| 								"auth",
 | |
| 							),
 | |
| 						),
 | |
| 					),
 | |
| 					expectPush(
 | |
| 						newIDPJWTConfigChangedEvent(context.Background(),
 | |
| 							"org1",
 | |
| 							"config1",
 | |
| 							"jwt-endpoint-changed",
 | |
| 							"issuer-changed",
 | |
| 							"keys-endpoint-changed",
 | |
| 							"auth-changed",
 | |
| 						),
 | |
| 					),
 | |
| 				),
 | |
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)),
 | |
| 			},
 | |
| 			args: args{
 | |
| 				ctx: context.Background(),
 | |
| 				config: &domain.JWTIDPConfig{
 | |
| 					IDPConfigID:  "config1",
 | |
| 					JWTEndpoint:  "jwt-endpoint-changed",
 | |
| 					Issuer:       "issuer-changed",
 | |
| 					KeysEndpoint: "keys-endpoint-changed",
 | |
| 					HeaderName:   "auth-changed",
 | |
| 				},
 | |
| 				resourceOwner: "org1",
 | |
| 			},
 | |
| 			res: res{
 | |
| 				want: &domain.JWTIDPConfig{
 | |
| 					ObjectRoot: models.ObjectRoot{
 | |
| 						AggregateID:   "org1",
 | |
| 						ResourceOwner: "org1",
 | |
| 					},
 | |
| 					IDPConfigID:  "config1",
 | |
| 					JWTEndpoint:  "jwt-endpoint-changed",
 | |
| 					Issuer:       "issuer-changed",
 | |
| 					KeysEndpoint: "keys-endpoint-changed",
 | |
| 					HeaderName:   "auth-changed",
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			r := &Commands{
 | |
| 				eventstore:          tt.fields.eventstore,
 | |
| 				idpConfigEncryption: tt.fields.secretCrypto,
 | |
| 			}
 | |
| 			got, err := r.ChangeIDPJWTConfig(tt.args.ctx, tt.args.config, tt.args.resourceOwner)
 | |
| 			if tt.res.err == nil {
 | |
| 				assert.NoError(t, err)
 | |
| 			}
 | |
| 			if tt.res.err != nil && !tt.res.err(err) {
 | |
| 				t.Errorf("got wrong err: %v ", err)
 | |
| 			}
 | |
| 			if tt.res.err == nil {
 | |
| 				assert.Equal(t, tt.res.want, got)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func newIDPJWTConfigChangedEvent(ctx context.Context, orgID, configID, jwtEndpoint, issuer, keysEndpoint, headerName string) *org.IDPJWTConfigChangedEvent {
 | |
| 	event, _ := org.NewIDPJWTConfigChangedEvent(ctx,
 | |
| 		&org.NewAggregate(orgID).Aggregate,
 | |
| 		configID,
 | |
| 		[]idpconfig.JWTConfigChanges{
 | |
| 			idpconfig.ChangeJWTEndpoint(jwtEndpoint),
 | |
| 			idpconfig.ChangeJWTIssuer(issuer),
 | |
| 			idpconfig.ChangeKeysEndpoint(keysEndpoint),
 | |
| 			idpconfig.ChangeHeaderName(headerName),
 | |
| 		},
 | |
| 	)
 | |
| 	return event
 | |
| }
 |