//go:build integration package events_test import ( "testing" "time" "github.com/brianvoe/gofakeit/v6" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" "github.com/zitadel/zitadel/backend/v3/storage/database/repository" "github.com/zitadel/zitadel/internal/integration" "github.com/zitadel/zitadel/pkg/grpc/system" ) func TestServer_TestInstanceReduces(t *testing.T) { t.Run("test instance add reduces", func(t *testing.T) { instanceName := gofakeit.Name() beforeCreate := time.Now() instance, err := SystemClient.CreateInstance(CTX, &system.CreateInstanceRequest{ InstanceName: instanceName, Owner: &system.CreateInstanceRequest_Machine_{ Machine: &system.CreateInstanceRequest_Machine{ UserName: "owner", Name: "owner", PersonalAccessToken: &system.CreateInstanceRequest_PersonalAccessToken{}, }, }, }) afterCreate := time.Now() require.NoError(t, err) instanceRepo := repository.InstanceRepository(pool) retryDuration, tick := integration.WaitForAndTickWithMaxDuration(CTX, time.Minute) assert.EventuallyWithT(t, func(ttt *assert.CollectT) { instance, err := instanceRepo.Get(CTX, instance.GetInstanceId(), ) require.NoError(ttt, err) // event instance.added assert.Equal(ttt, instanceName, instance.Name) // event instance.default.org.set assert.NotNil(t, instance.DefaultOrgID) // event instance.iam.project.set assert.NotNil(t, instance.IAMProjectID) // event instance.iam.console.set assert.NotNil(t, instance.ConsoleAppID) // event instance.default.language.set assert.NotNil(t, instance.DefaultLanguage) // event instance.added assert.WithinRange(t, instance.CreatedAt, beforeCreate, afterCreate) // event instance.added assert.WithinRange(t, instance.UpdatedAt, beforeCreate, afterCreate) }, retryDuration, tick) }) t.Run("test instance update reduces", func(t *testing.T) { instanceName := gofakeit.Name() res, err := SystemClient.CreateInstance(CTX, &system.CreateInstanceRequest{ InstanceName: instanceName, Owner: &system.CreateInstanceRequest_Machine_{ Machine: &system.CreateInstanceRequest_Machine{ UserName: "owner", Name: "owner", PersonalAccessToken: &system.CreateInstanceRequest_PersonalAccessToken{}, }, }, }) require.NoError(t, err) instanceName += "new" beforeUpdate := time.Now() _, err = SystemClient.UpdateInstance(CTX, &system.UpdateInstanceRequest{ InstanceId: res.InstanceId, InstanceName: instanceName, }) require.NoError(t, err) afterUpdate := time.Now() instanceRepo := repository.InstanceRepository(pool) retryDuration, tick := integration.WaitForAndTickWithMaxDuration(CTX, time.Minute) assert.EventuallyWithT(t, func(ttt *assert.CollectT) { instance, err := instanceRepo.Get(CTX, res.InstanceId, ) require.NoError(ttt, err) // event instance.changed assert.Equal(ttt, instanceName, instance.Name) assert.WithinRange(t, instance.UpdatedAt, beforeUpdate, afterUpdate) }, retryDuration, tick) }) t.Run("test instance delete reduces", func(t *testing.T) { instanceName := gofakeit.Name() res, err := SystemClient.CreateInstance(CTX, &system.CreateInstanceRequest{ InstanceName: instanceName, Owner: &system.CreateInstanceRequest_Machine_{ Machine: &system.CreateInstanceRequest_Machine{ UserName: "owner", Name: "owner", PersonalAccessToken: &system.CreateInstanceRequest_PersonalAccessToken{}, }, }, }) require.NoError(t, err) instanceRepo := repository.InstanceRepository(pool) // check instance exists retryDuration, tick := integration.WaitForAndTickWithMaxDuration(CTX, time.Minute) assert.EventuallyWithT(t, func(ttt *assert.CollectT) { instance, err := instanceRepo.Get(CTX, res.InstanceId, ) require.NoError(ttt, err) assert.Equal(ttt, instanceName, instance.Name) }, retryDuration, tick) _, err = SystemClient.RemoveInstance(CTX, &system.RemoveInstanceRequest{ InstanceId: res.InstanceId, }) require.NoError(t, err) retryDuration, tick = integration.WaitForAndTickWithMaxDuration(CTX, time.Minute) assert.EventuallyWithT(t, func(ttt *assert.CollectT) { instance, err := instanceRepo.Get(CTX, res.InstanceId, ) // event instance.removed assert.Nil(t, instance) require.Equal(t, repository.ErrResourceDoesNotExist, err) }, retryDuration, tick) }) }