fix: wait for projection initialization to be done (#4473)

* fix: wait for projection initialization to be done

* close channel

Co-authored-by: Silvan <silvan.reusser@gmail.com>
This commit is contained in:
Livio Spring 2022-10-03 16:09:59 +02:00 committed by GitHub
parent df624f0de5
commit fcb36cd406
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 16 additions and 5 deletions

View File

@ -74,9 +74,11 @@ func NewStatementHandler(
bulkLimit: config.BulkLimit, bulkLimit: config.BulkLimit,
Locker: NewLocker(config.Client, config.LockTable, config.ProjectionName), Locker: NewLocker(config.Client, config.LockTable, config.ProjectionName),
} }
h.ProjectionHandler = handler.NewProjectionHandler(ctx, config.ProjectionHandlerConfig, h.reduce, h.Update, h.SearchQuery, h.Lock, h.Unlock)
err := h.Init(ctx, config.InitCheck) initialized := make(chan bool)
h.ProjectionHandler = handler.NewProjectionHandler(ctx, config.ProjectionHandlerConfig, h.reduce, h.Update, h.SearchQuery, h.Lock, h.Unlock, initialized)
err := h.Init(ctx, initialized, config.InitCheck)
logging.OnError(err).WithField("projection", config.ProjectionName).Fatal("unable to initialize projections") logging.OnError(err).WithField("projection", config.ProjectionName).Fatal("unable to initialize projections")
h.Subscribe(h.aggregates...) h.Subscribe(h.aggregates...)

View File

@ -186,9 +186,11 @@ type ForeignKey struct {
} }
// Init implements handler.Init // Init implements handler.Init
func (h *StatementHandler) Init(ctx context.Context, checks ...*handler.Check) error { func (h *StatementHandler) Init(ctx context.Context, initialized chan<- bool, checks ...*handler.Check) error {
for _, check := range checks { for _, check := range checks {
if check == nil || check.IsNoop() { if check == nil || check.IsNoop() {
initialized <- true
close(initialized)
return nil return nil
} }
tx, err := h.client.BeginTx(ctx, nil) tx, err := h.client.BeginTx(ctx, nil)
@ -211,6 +213,8 @@ func (h *StatementHandler) Init(ctx context.Context, checks ...*handler.Check) e
return err return err
} }
} }
initialized <- true
close(initialized)
return nil return nil
} }

View File

@ -62,6 +62,7 @@ func NewProjectionHandler(
query SearchQuery, query SearchQuery,
lock Lock, lock Lock,
unlock Unlock, unlock Unlock,
initialized <-chan bool,
) *ProjectionHandler { ) *ProjectionHandler {
concurrentInstances := int(config.ConcurrentInstances) concurrentInstances := int(config.ConcurrentInstances)
if concurrentInstances < 1 { if concurrentInstances < 1 {
@ -82,9 +83,12 @@ func NewProjectionHandler(
concurrentInstances: concurrentInstances, concurrentInstances: concurrentInstances,
} }
go func() {
<-initialized
go h.subscribe(ctx) go h.subscribe(ctx)
go h.schedule(ctx) go h.schedule(ctx)
}()
return h return h
} }

View File

@ -337,6 +337,7 @@ func TestProjectionHandler_Process(t *testing.T) {
nil, nil,
nil, nil,
nil, nil,
nil,
) )
index, err := h.Process(tt.args.ctx, tt.args.events...) index, err := h.Process(tt.args.ctx, tt.args.events...)