Ao Li created KAFKA-17112: ----------------------------- Summary: StreamThread shutdown calls completeShutdown only in CREATED state Key: KAFKA-17112 URL: https://issues.apache.org/jira/browse/KAFKA-17112 Project: Kafka Issue Type: Bug Components: streams Affects Versions: 3.9.0 Reporter: Ao Li
While running tests in `StreamThreadTest.java` in kafka/streams, I noticed the test left many lingering threads. Though the class runs `shutdown` after each test, the shutdown only executes `completeShutdown` if the StreamThread is in CREATED state. See [https://github.com/apache/kafka/blob/0b11971f2c94f7aadc3fab2c51d94642065a72e5/streams/src/test/java/org/apache/kafka/streams/processor/internals/StreamThreadTest.java#L231] and [https://github.com/apache/kafka/blob/0b11971f2c94f7aadc3fab2c51d94642065a72e5/streams/src/main/java/org/apache/kafka/streams/processor/internals/StreamThread.java#L1435] For example, you may run test org.apache.kafka.streams.processor.internals.StreamThreadTest#shouldNotCloseTaskProducerWhenSuspending with commit 0b11971f2c94f7aadc3fab2c51d94642065a72e5. When the test calls `thread.shutdown()`, the thread is in `PARTITIONS_REVOKED` state. Thus, `completeShutdown` is not called. The test creates three lingering threads: 2 `StateUpdater` and 1 `TaskExecutor` This means that calls to `thread.shutdown` has no effect in `StreamThreadTest.java`. -- This message was sent by Atlassian Jira (v8.20.10#820010)