Skip to content

Commit

Permalink
Ignore docker kill signal in add_docker_metadata processor (#5788)
Browse files Browse the repository at this point in the history
  • Loading branch information
exekias authored and andrewkroh committed Dec 1, 2017
1 parent 06fb749 commit 76dd261
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 4 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ https://github.com/elastic/beats/compare/v6.0.0...master[Check the HEAD diff]
*Affecting all Beats*

- Fix documentation links in README.md files. {pull}5710[5710]
- Fix `add_docker_metadata` dropping some containers. {pull}5788[5788]

*Auditbeat*

Expand Down
2 changes: 1 addition & 1 deletion libbeat/processors/add_docker_metadata/watcher.go
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,7 @@ func (w *watcher) watch() {
}

// Delete
if event.Action == "die" || event.Action == "kill" {
if event.Action == "die" {
w.Lock()
w.deleted[event.Actor.ID] = time.Now()
w.Unlock()
Expand Down
30 changes: 27 additions & 3 deletions libbeat/processors/add_docker_metadata/watcher_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,8 @@ func TestWatcherUpdateEvent(t *testing.T) {
}

func TestWatcherKill(t *testing.T) {
watcher := runWatcher(t, false,
// Assert kill is ignored
watcher := runWatcher(t, true,
[]types.Container{
types.Container{
ID: "0332dbd79e20",
Expand All @@ -173,6 +174,29 @@ func TestWatcherKill(t *testing.T) {
},
)

assert.Equal(t, len(watcher.deleted), 0)
}

func TestWatcherDie(t *testing.T) {
watcher := runWatcher(t, false,
[]types.Container{
types.Container{
ID: "0332dbd79e20",
Names: []string{"/containername", "othername"},
Image: "busybox",
Labels: map[string]string{"label": "foo"},
},
},
[]interface{}{
events.Message{
Action: "die",
Actor: events.Actor{
ID: "0332dbd79e20",
},
},
},
)

// Check it doesn't get removed while we request meta for the container
for i := 0; i < 18; i++ {
watcher.Container("0332dbd79e20")
Expand All @@ -181,7 +205,7 @@ func TestWatcherKill(t *testing.T) {
}

// Now it should get removed
time.Sleep(150 * time.Millisecond)
time.Sleep(300 * time.Millisecond)
assert.Equal(t, len(watcher.Containers()), 0)
}

Expand All @@ -192,7 +216,7 @@ func runWatcher(t *testing.T, kill bool, containers []types.Container, events []
done: make(chan interface{}),
}

watcher, err := NewWatcherWithClient(client, 100*time.Millisecond)
watcher, err := NewWatcherWithClient(client, 150*time.Millisecond)
if err != nil {
t.Fatal(err)
}
Expand Down

0 comments on commit 76dd261

Please sign in to comment.