2021-04-12 15:03:09 +00:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
|
|
|
"github.com/caos/zitadel/internal/domain"
|
|
|
|
caos_errs "github.com/caos/zitadel/internal/errors"
|
|
|
|
"github.com/caos/zitadel/internal/eventstore"
|
|
|
|
"github.com/caos/zitadel/internal/eventstore/repository"
|
|
|
|
"github.com/caos/zitadel/internal/repository/features"
|
|
|
|
"github.com/caos/zitadel/internal/repository/iam"
|
|
|
|
"github.com/caos/zitadel/internal/repository/org"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestCommandSide_SetOrgFeatures(t *testing.T) {
|
|
|
|
type fields struct {
|
|
|
|
eventstore *eventstore.Eventstore
|
2021-04-19 14:43:36 +00:00
|
|
|
iamDomain string
|
2021-04-12 15:03:09 +00:00
|
|
|
}
|
|
|
|
type args struct {
|
|
|
|
ctx context.Context
|
|
|
|
resourceOwner string
|
|
|
|
features *domain.Features
|
|
|
|
}
|
|
|
|
type res struct {
|
|
|
|
want *domain.ObjectDetails
|
|
|
|
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(),
|
|
|
|
features: &domain.Features{
|
|
|
|
TierName: "Test",
|
|
|
|
State: domain.FeaturesStateActive,
|
|
|
|
AuditLogRetention: time.Hour,
|
|
|
|
LoginPolicyFactors: false,
|
|
|
|
LoginPolicyIDP: false,
|
|
|
|
LoginPolicyPasswordless: false,
|
|
|
|
LoginPolicyRegistration: false,
|
|
|
|
LoginPolicyUsernameLogin: false,
|
|
|
|
PasswordComplexityPolicy: false,
|
|
|
|
LabelPolicy: false,
|
2021-04-19 14:43:36 +00:00
|
|
|
CustomDomain: false,
|
2021-04-12 15:03:09 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
err: caos_errs.IsErrorInvalidArgument,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "no change, error",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
newFeaturesSetEvent(context.Background(), "org1", "Test", domain.FeaturesStateActive, time.Hour),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
features: &domain.Features{
|
|
|
|
TierName: "Test",
|
|
|
|
State: domain.FeaturesStateActive,
|
|
|
|
AuditLogRetention: time.Hour,
|
|
|
|
LoginPolicyFactors: false,
|
|
|
|
LoginPolicyIDP: false,
|
|
|
|
LoginPolicyPasswordless: false,
|
|
|
|
LoginPolicyRegistration: false,
|
|
|
|
LoginPolicyUsernameLogin: false,
|
|
|
|
PasswordComplexityPolicy: false,
|
|
|
|
LabelPolicy: false,
|
2021-04-19 14:43:36 +00:00
|
|
|
CustomDomain: false,
|
2021-04-12 15:03:09 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
err: caos_errs.IsPreconditionFailed,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "set with default policies, ok",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
expectFilter(),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
domain.PasswordlessTypeAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewPasswordComplexityPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
8,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLabelPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
"primary",
|
|
|
|
"secondary",
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2021-04-19 14:43:36 +00:00
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewOrgAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2021-04-12 15:03:09 +00:00
|
|
|
expectPush(
|
|
|
|
[]*repository.Event{
|
|
|
|
eventFromEventPusher(
|
|
|
|
newFeaturesSetEvent(context.Background(), "org1", "Test", domain.FeaturesStateActive, time.Hour),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
2021-04-19 14:43:36 +00:00
|
|
|
iamDomain: "iam-domain",
|
2021-04-12 15:03:09 +00:00
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
features: &domain.Features{
|
|
|
|
TierName: "Test",
|
|
|
|
State: domain.FeaturesStateActive,
|
|
|
|
AuditLogRetention: time.Hour,
|
|
|
|
LoginPolicyFactors: false,
|
|
|
|
LoginPolicyIDP: false,
|
|
|
|
LoginPolicyPasswordless: false,
|
|
|
|
LoginPolicyRegistration: false,
|
|
|
|
LoginPolicyUsernameLogin: false,
|
|
|
|
PasswordComplexityPolicy: false,
|
|
|
|
LabelPolicy: false,
|
2021-04-19 14:43:36 +00:00
|
|
|
CustomDomain: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
want: &domain.ObjectDetails{
|
|
|
|
ResourceOwner: "org1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "set with default policies, custom domains, ok",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
expectFilter(),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
domain.PasswordlessTypeAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewPasswordComplexityPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
8,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLabelPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
"primary",
|
|
|
|
"secondary",
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewOrgAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test2",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectPush(
|
|
|
|
[]*repository.Event{
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "test1", true),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "test2", false),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
newFeaturesSetEvent(context.Background(), "org1", "Test", domain.FeaturesStateActive, time.Hour),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
uniqueConstraintsFromEventConstraint(org.NewRemoveOrgDomainUniqueConstraint("test1")),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
iamDomain: "iam-domain",
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
features: &domain.Features{
|
|
|
|
TierName: "Test",
|
|
|
|
State: domain.FeaturesStateActive,
|
|
|
|
AuditLogRetention: time.Hour,
|
|
|
|
LoginPolicyFactors: false,
|
|
|
|
LoginPolicyIDP: false,
|
|
|
|
LoginPolicyPasswordless: false,
|
|
|
|
LoginPolicyRegistration: false,
|
|
|
|
LoginPolicyUsernameLogin: false,
|
|
|
|
PasswordComplexityPolicy: false,
|
|
|
|
LabelPolicy: false,
|
|
|
|
CustomDomain: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
want: &domain.ObjectDetails{
|
|
|
|
ResourceOwner: "org1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "set with default policies, custom domains, default not primary, ok",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
expectFilter(),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
domain.PasswordlessTypeAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewPasswordComplexityPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
8,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLabelPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
"primary",
|
|
|
|
"secondary",
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewOrgAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test2",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectPush(
|
|
|
|
[]*repository.Event{
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "org1.iam-domain"),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "test1", true),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "test2", false),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
newFeaturesSetEvent(context.Background(), "org1", "Test", domain.FeaturesStateActive, time.Hour),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
uniqueConstraintsFromEventConstraint(org.NewRemoveOrgDomainUniqueConstraint("test1")),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
iamDomain: "iam-domain",
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
features: &domain.Features{
|
|
|
|
TierName: "Test",
|
|
|
|
State: domain.FeaturesStateActive,
|
|
|
|
AuditLogRetention: time.Hour,
|
|
|
|
LoginPolicyFactors: false,
|
|
|
|
LoginPolicyIDP: false,
|
|
|
|
LoginPolicyPasswordless: false,
|
|
|
|
LoginPolicyRegistration: false,
|
|
|
|
LoginPolicyUsernameLogin: false,
|
|
|
|
PasswordComplexityPolicy: false,
|
|
|
|
LabelPolicy: false,
|
|
|
|
CustomDomain: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
want: &domain.ObjectDetails{
|
|
|
|
ResourceOwner: "org1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "set with default policies, custom domains, default not existing, ok",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
expectFilter(),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
domain.PasswordlessTypeAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewPasswordComplexityPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
8,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLabelPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
"primary",
|
|
|
|
"secondary",
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewOrgAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"test2",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainRemovedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain", true,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectPush(
|
|
|
|
[]*repository.Event{
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "org1.iam-domain"),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "org1.iam-domain"),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "test1", true),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, "test2", false),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
newFeaturesSetEvent(context.Background(), "org1", "Test", domain.FeaturesStateActive, time.Hour),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
uniqueConstraintsFromEventConstraint(org.NewRemoveOrgDomainUniqueConstraint("test1")),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
iamDomain: "iam-domain",
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
features: &domain.Features{
|
|
|
|
TierName: "Test",
|
|
|
|
State: domain.FeaturesStateActive,
|
|
|
|
AuditLogRetention: time.Hour,
|
|
|
|
LoginPolicyFactors: false,
|
|
|
|
LoginPolicyIDP: false,
|
|
|
|
LoginPolicyPasswordless: false,
|
|
|
|
LoginPolicyRegistration: false,
|
|
|
|
LoginPolicyUsernameLogin: false,
|
|
|
|
PasswordComplexityPolicy: false,
|
|
|
|
LabelPolicy: false,
|
|
|
|
CustomDomain: false,
|
2021-04-12 15:03:09 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
want: &domain.ObjectDetails{
|
|
|
|
ResourceOwner: "org1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "set with custom policies, ok",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
//NewOrgFeaturesWriteModel
|
|
|
|
expectFilter(),
|
|
|
|
//begin ensureOrgSettingsToFeatures
|
|
|
|
//begin setAllowedLoginPolicy
|
|
|
|
//orgLoginPolicyWriteModelByID
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
domain.PasswordlessTypeAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
domain.PasswordlessTypeNotAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
//getDefaultLoginPolicy
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
domain.PasswordlessTypeAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
//begin setDefaultAuthFactorsInCustomLoginPolicy
|
|
|
|
//orgLoginPolicyAuthFactorsWriteModel
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicySecondFactorAddedEvent(context.Background(), &iam.NewAggregate().Aggregate, domain.SecondFactorTypeU2F),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyMultiFactorAddedEvent(context.Background(), &iam.NewAggregate().Aggregate, domain.MultiFactorTypeU2FWithPIN),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewLoginPolicySecondFactorAddedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, domain.SecondFactorTypeOTP),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
//addSecondFactorToLoginPolicy
|
|
|
|
expectFilter(),
|
|
|
|
//removeSecondFactorFromLoginPolicy
|
|
|
|
expectFilter(),
|
|
|
|
//addMultiFactorToLoginPolicy
|
|
|
|
expectFilter(),
|
|
|
|
//end setDefaultAuthFactorsInCustomLoginPolicy
|
|
|
|
//orgPasswordComplexityPolicyWriteModelByID
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewPasswordComplexityPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
8,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewPasswordComplexityPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
7,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
//orgLabelPolicyWriteModelByID
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLabelPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
"primary",
|
|
|
|
"secondary",
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewLabelPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
"custom",
|
|
|
|
"secondary",
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2021-04-19 14:43:36 +00:00
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewOrgAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2021-04-12 15:03:09 +00:00
|
|
|
expectPush(
|
|
|
|
[]*repository.Event{
|
|
|
|
eventFromEventPusher(
|
2021-04-15 13:30:19 +00:00
|
|
|
org.NewLoginPolicySecondFactorRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, domain.SecondFactorTypeOTP),
|
2021-04-12 15:03:09 +00:00
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
2021-04-15 13:30:19 +00:00
|
|
|
org.NewLoginPolicySecondFactorAddedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, domain.SecondFactorTypeU2F),
|
2021-04-12 15:03:09 +00:00
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewLoginPolicyMultiFactorAddedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate, domain.MultiFactorTypeU2FWithPIN),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
newLoginPolicyChangedEvent(context.Background(), "org1", true, true, true, true, domain.PasswordlessTypeAllowed),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewPasswordComplexityPolicyRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewLabelPolicyRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
newFeaturesSetEvent(context.Background(), "org1", "Test", domain.FeaturesStateActive, time.Hour),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
2021-04-19 14:43:36 +00:00
|
|
|
iamDomain: "iam-domain",
|
2021-04-12 15:03:09 +00:00
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
features: &domain.Features{
|
|
|
|
TierName: "Test",
|
|
|
|
State: domain.FeaturesStateActive,
|
|
|
|
AuditLogRetention: time.Hour,
|
|
|
|
LoginPolicyFactors: false,
|
|
|
|
LoginPolicyIDP: false,
|
|
|
|
LoginPolicyPasswordless: false,
|
|
|
|
LoginPolicyRegistration: false,
|
|
|
|
LoginPolicyUsernameLogin: false,
|
|
|
|
PasswordComplexityPolicy: false,
|
|
|
|
LabelPolicy: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
want: &domain.ObjectDetails{
|
|
|
|
ResourceOwner: "org1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
r := &Commands{
|
|
|
|
eventstore: tt.fields.eventstore,
|
2021-04-19 14:43:36 +00:00
|
|
|
iamDomain: tt.fields.iamDomain,
|
2021-04-12 15:03:09 +00:00
|
|
|
}
|
|
|
|
got, err := r.SetOrgFeatures(tt.args.ctx, tt.args.resourceOwner, tt.args.features)
|
|
|
|
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 TestCommandSide_RemoveOrgFeatures(t *testing.T) {
|
|
|
|
type fields struct {
|
|
|
|
eventstore *eventstore.Eventstore
|
2021-04-19 14:43:36 +00:00
|
|
|
iamDomain string
|
2021-04-12 15:03:09 +00:00
|
|
|
}
|
|
|
|
type args struct {
|
|
|
|
ctx context.Context
|
|
|
|
resourceOwner string
|
|
|
|
}
|
|
|
|
type res struct {
|
|
|
|
want *domain.ObjectDetails
|
|
|
|
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(),
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
err: caos_errs.IsErrorInvalidArgument,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "no features set, error",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
expectFilter(),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
err: caos_errs.IsNotFound,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "remove with default policies, ok",
|
|
|
|
fields: fields{
|
|
|
|
eventstore: eventstoreExpect(
|
|
|
|
t,
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
newFeaturesSetEvent(context.Background(), "org1", "Test", domain.FeaturesStateActive, time.Hour)),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
newIAMFeaturesSetEvent(context.Background(), "Default", domain.FeaturesStateActive, time.Hour)),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLoginPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
domain.PasswordlessTypeAllowed,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewPasswordComplexityPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
8,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
iam.NewLabelPolicyAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
"primary",
|
|
|
|
"secondary",
|
|
|
|
false,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2021-04-19 14:43:36 +00:00
|
|
|
expectFilter(
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewOrgAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainAddedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainVerifiedEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewDomainPrimarySetEvent(
|
|
|
|
context.Background(),
|
|
|
|
&org.NewAggregate("org1", "org1").Aggregate,
|
|
|
|
"org1.iam-domain",
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2021-04-12 15:03:09 +00:00
|
|
|
expectPush(
|
|
|
|
[]*repository.Event{
|
|
|
|
eventFromEventPusher(
|
|
|
|
org.NewFeaturesRemovedEvent(context.Background(), &org.NewAggregate("org1", "org1").Aggregate),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
2021-04-19 14:43:36 +00:00
|
|
|
iamDomain: "iam-domain",
|
2021-04-12 15:03:09 +00:00
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
ctx: context.Background(),
|
|
|
|
resourceOwner: "org1",
|
|
|
|
},
|
|
|
|
res: res{
|
|
|
|
want: &domain.ObjectDetails{
|
|
|
|
ResourceOwner: "org1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
r := &Commands{
|
|
|
|
eventstore: tt.fields.eventstore,
|
2021-04-19 14:43:36 +00:00
|
|
|
iamDomain: tt.fields.iamDomain,
|
2021-04-12 15:03:09 +00:00
|
|
|
}
|
|
|
|
got, err := r.RemoveOrgFeatures(tt.args.ctx, 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 newIAMFeaturesSetEvent(ctx context.Context, tierName string, state domain.FeaturesState, auditLog time.Duration) *iam.FeaturesSetEvent {
|
|
|
|
event, _ := iam.NewFeaturesSetEvent(
|
|
|
|
ctx,
|
|
|
|
&iam.NewAggregate().Aggregate,
|
|
|
|
[]features.FeaturesChanges{
|
|
|
|
features.ChangeTierName(tierName),
|
|
|
|
features.ChangeState(state),
|
|
|
|
features.ChangeAuditLogRetention(auditLog),
|
|
|
|
},
|
|
|
|
)
|
|
|
|
return event
|
|
|
|
}
|
|
|
|
|
|
|
|
func newFeaturesSetEvent(ctx context.Context, orgID string, tierName string, state domain.FeaturesState, auditLog time.Duration) *org.FeaturesSetEvent {
|
|
|
|
event, _ := org.NewFeaturesSetEvent(
|
|
|
|
ctx,
|
|
|
|
&org.NewAggregate(orgID, orgID).Aggregate,
|
|
|
|
[]features.FeaturesChanges{
|
|
|
|
features.ChangeTierName(tierName),
|
|
|
|
features.ChangeState(state),
|
|
|
|
features.ChangeAuditLogRetention(auditLog),
|
|
|
|
},
|
|
|
|
)
|
|
|
|
return event
|
|
|
|
}
|