mirror of
https://github.com/zitadel/zitadel.git
synced 2025-12-09 17:22:19 +00:00
feat: push telemetry (#6027)
* document analytics config
* rework configuration and docs
* describe HandleActiveInstances better
* describe active instances on quotas better
* only projected events are considered
* cleanup
* describe changes at runtime
* push milestones
* stop tracking events
* calculate and push 4 in 6 milestones
* reduce milestone pushed
* remove docs
* fix scheduled pseudo event projection
* push 5 in 6 milestones
* push 6 in 6 milestones
* ignore client ids
* fix text array contains
* push human readable milestone type
* statement unit tests
* improve dev and db performance
* organize imports
* cleanup
* organize imports
* test projection
* check rows.Err()
* test search query
* pass linting
* review
* test 4 milestones
* simplify milestone by instance ids query
* use type NamespacedCondition
* cleanup
* lint
* lint
* dont overwrite original error
* no opt-in in examples
* cleanup
* prerelease
* enable request headers
* make limit configurable
* review fixes
* only requeue special handlers secondly
* include integration tests
* Revert "include integration tests"
This reverts commit 96db9504ec.
* pass reducers
* test handlers
* fix unit test
* feat: increment version
* lint
* remove prerelease
* fix integration tests
This commit is contained in:
@@ -18,6 +18,7 @@ import (
|
||||
"github.com/zitadel/zitadel/internal/eventstore/repository"
|
||||
es_repo_mock "github.com/zitadel/zitadel/internal/eventstore/repository/mock"
|
||||
"github.com/zitadel/zitadel/internal/id"
|
||||
"github.com/zitadel/zitadel/internal/repository/pseudo"
|
||||
)
|
||||
|
||||
var (
|
||||
@@ -60,7 +61,7 @@ func TestProjectionHandler_SearchQuery(t *testing.T) {
|
||||
type fields struct {
|
||||
sequenceTable string
|
||||
projectionName string
|
||||
aggregates []eventstore.AggregateType
|
||||
reducers []handler.AggregateReducer
|
||||
bulkLimit uint64
|
||||
}
|
||||
type args struct {
|
||||
@@ -77,7 +78,7 @@ func TestProjectionHandler_SearchQuery(t *testing.T) {
|
||||
fields: fields{
|
||||
sequenceTable: "my_sequences",
|
||||
projectionName: "my_projection",
|
||||
aggregates: []eventstore.AggregateType{"testAgg"},
|
||||
reducers: failingAggregateReducers("testAgg"),
|
||||
bulkLimit: 5,
|
||||
},
|
||||
args: args{
|
||||
@@ -99,7 +100,7 @@ func TestProjectionHandler_SearchQuery(t *testing.T) {
|
||||
fields: fields{
|
||||
sequenceTable: "my_sequences",
|
||||
projectionName: "my_projection",
|
||||
aggregates: []eventstore.AggregateType{"testAgg"},
|
||||
reducers: failingAggregateReducers("testAgg"),
|
||||
bulkLimit: 5,
|
||||
},
|
||||
args: args{
|
||||
@@ -129,7 +130,7 @@ func TestProjectionHandler_SearchQuery(t *testing.T) {
|
||||
fields: fields{
|
||||
sequenceTable: "my_sequences",
|
||||
projectionName: "my_projection",
|
||||
aggregates: []eventstore.AggregateType{"testAgg"},
|
||||
reducers: failingAggregateReducers("testAgg"),
|
||||
bulkLimit: 5,
|
||||
},
|
||||
args: args{
|
||||
@@ -158,6 +159,32 @@ func TestProjectionHandler_SearchQuery(t *testing.T) {
|
||||
Limit(5),
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "scheduled pseudo event",
|
||||
fields: fields{
|
||||
sequenceTable: "my_sequences",
|
||||
projectionName: "my_projection",
|
||||
reducers: []handler.AggregateReducer{{
|
||||
Aggregate: pseudo.AggregateType,
|
||||
EventRedusers: []handler.EventReducer{
|
||||
{
|
||||
Event: pseudo.ScheduledEventType,
|
||||
Reduce: testReduceErr(errors.New("should not be called")),
|
||||
},
|
||||
},
|
||||
}},
|
||||
bulkLimit: 5,
|
||||
},
|
||||
args: args{
|
||||
instanceIDs: []string{"instanceID1", "instanceID2"},
|
||||
},
|
||||
want: want{
|
||||
limit: 1,
|
||||
isErr: func(err error) bool {
|
||||
return err == nil
|
||||
},
|
||||
},
|
||||
},
|
||||
}
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
@@ -177,15 +204,14 @@ func TestProjectionHandler_SearchQuery(t *testing.T) {
|
||||
Client: &database.DB{
|
||||
DB: client,
|
||||
},
|
||||
Reducers: tt.fields.reducers,
|
||||
})
|
||||
|
||||
h.aggregates = tt.fields.aggregates
|
||||
|
||||
for _, expectation := range tt.want.expectations {
|
||||
expectation(mock)
|
||||
}
|
||||
|
||||
query, limit, err := h.SearchQuery(context.Background(), tt.args.instanceIDs)
|
||||
query, limit, err := h.searchQuery(context.Background(), tt.args.instanceIDs)
|
||||
if !tt.want.isErr(err) {
|
||||
t.Errorf("ProjectionHandler.prepareBulkStmts() error = %v", err)
|
||||
return
|
||||
@@ -1768,3 +1794,17 @@ func testReduceErr(err error) handler.Reduce {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
func failingAggregateReducers(aggregates ...eventstore.AggregateType) []handler.AggregateReducer {
|
||||
reducers := make([]handler.AggregateReducer, len(aggregates))
|
||||
for idx := range aggregates {
|
||||
reducers[idx] = handler.AggregateReducer{
|
||||
Aggregate: aggregates[idx],
|
||||
EventRedusers: []handler.EventReducer{{
|
||||
Event: "any.event",
|
||||
Reduce: testReduceErr(errors.New("should not be called")),
|
||||
}},
|
||||
}
|
||||
}
|
||||
return reducers
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user