diff --git a/x-pack/elastic-agent/CHANGELOG.next.asciidoc b/x-pack/elastic-agent/CHANGELOG.next.asciidoc index 7070601056a..c1b68361131 100644 --- a/x-pack/elastic-agent/CHANGELOG.next.asciidoc +++ b/x-pack/elastic-agent/CHANGELOG.next.asciidoc @@ -82,6 +82,7 @@ - Add validation for certificate flags to ensure they are absolute paths. {pull}27779[27779] - Migrate state on upgrade {pull}27825[27825] - Snapshot artifact lookup will use agent.download proxy settings. {issue}27903[27903] {pull}27904[27904] +- Fix lazy acker to only add new actions to the batch. {pull}27981[27981] ==== New features diff --git a/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker.go b/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker.go index 39f6fb5cd30..c48ac004233 100644 --- a/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker.go +++ b/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker.go @@ -37,8 +37,7 @@ func NewAcker(baseAcker batchAcker, log *logger.Logger) *Acker { // Ack acknowledges action. func (f *Acker) Ack(ctx context.Context, action fleetapi.Action) error { - f.queue = append(f.queue, action) - f.log.Debugf("appending action with id '%s' to the queue", action.ID()) + f.enqueue(action) if _, isAckForced := action.(ackForcer); isAckForced { return f.Commit(ctx) @@ -58,3 +57,14 @@ func (f *Acker) Commit(ctx context.Context) error { f.queue = make([]fleetapi.Action, 0) return nil } + +func (f *Acker) enqueue(action fleetapi.Action) { + for _, a := range f.queue { + if a.ID() == action.ID() { + f.log.Debugf("action with id '%s' has already been queued", action.ID()) + return + } + } + f.queue = append(f.queue, action) + f.log.Debugf("appending action with id '%s' to the queue", action.ID()) +} diff --git a/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker_test.go b/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker_test.go index 1e34d303bc5..216349b90af 100644 --- a/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker_test.go +++ b/x-pack/elastic-agent/pkg/fleetapi/acker/lazy/lazy_acker_test.go @@ -79,12 +79,21 @@ func TestLazyAcker(t *testing.T) { }() c := context.Background() + if err := lacker.Ack(c, testAction1); err != nil { + t.Fatal(err) + } if err := lacker.Ack(c, testAction1); err != nil { t.Fatal(err) } if err := lacker.Ack(c, testAction2); err != nil { t.Fatal(err) } + if err := lacker.Ack(c, testAction2); err != nil { + t.Fatal(err) + } + if err := lacker.Ack(c, testAction3); err != nil { + t.Fatal(err) + } if err := lacker.Ack(c, testAction3); err != nil { t.Fatal(err) }