Skip to content

Commit

Permalink
Add test for close.reader.after_interval to filestream input (elastic…
Browse files Browse the repository at this point in the history
  • Loading branch information
kvch authored Mar 11, 2021
1 parent 994bb2b commit ef505c2
Showing 1 changed file with 32 additions and 0 deletions.
32 changes: 32 additions & 0 deletions filebeat/input/filestream/input_integration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -279,3 +279,35 @@ func TestFilestreamUTF16BOMs(t *testing.T) {
})
}
}

// test_close_timeout from test_harvester.py
func TestFilestreamCloseTimeout(t *testing.T) {
env := newInputTestingEnvironment(t)

testlogName := "test.log"
inp := env.mustCreateInput(map[string]interface{}{
"paths": []string{env.abspath(testlogName)},
"prospector.scanner.check_interval": "24h",
"close.on_state_change.check_interval": "100ms",
"close.reader.after_interval": "500ms",
})

testlines := []byte("first line\n")
env.mustWriteLinesToFile(testlogName, testlines)

ctx, cancelInput := context.WithCancel(context.Background())
env.startInput(ctx, inp)

env.waitUntilEventCount(1)
env.requireOffsetInRegistry(testlogName, len(testlines))
env.waitUntilHarvesterIsDone()

env.mustWriteLinesToFile(testlogName, []byte("first line\nsecond log line\n"))

env.waitUntilEventCount(1)

cancelInput()
env.waitUntilInputStops()

env.requireOffsetInRegistry(testlogName, len(testlines))
}

0 comments on commit ef505c2

Please sign in to comment.