smjn commented on code in PR #19026:
URL: https://github.com/apache/kafka/pull/19026#discussion_r1993795193


##########
core/src/test/scala/unit/kafka/server/ShareGroupHeartbeatRequestTest.scala:
##########
@@ -261,7 +273,7 @@ class ShareGroupHeartbeatRequestTest(cluster: 
ClusterInstance) {
 
       val topicPartitionsAssignedToMember2 = 
shareGroupHeartbeatResponse.data.assignment.topicPartitions()
       // Verify the response.
-      assertEquals(3, shareGroupHeartbeatResponse.data.memberEpoch)
+      assertEquals(4, shareGroupHeartbeatResponse.data.memberEpoch)

Review Comment:
   No 4 is correct. In the new implementation, the groupEpoch is incremented 
each time we receive a heartbeat and there are some initialized topics which 
have not been assigned.
   ```
   memberId: mPkH7gtLSki7J3yRAQviIA, req: 1, resp: 2, assign: null
   
   memberId: mPkH7gtLSki7J3yRAQviIA, req: 2, resp: 3, assign: null
   
   memberId: mPkH7gtLSki7J3yRAQviIA, req: 3, resp: 4, assign: 
Assignment(topicPartitions=[TopicPartitions(topicId=1DIJ3JKHTU2pmPXmOR07tw, 
partitions=[2])])
   ```
   
   - This results in the first heartbeat after topic creation (as mentioned 
above) have no subscription metadata attached and no work gets done.
   - In the second heartbeat subscription is attached to group and a persister 
request gets created and then share coord initialization
   - In the third heartbeat, we can actually reconcile the assignment.
   
   If we create the topic before doing any heartbeats, that would have 3 as 
final epoch
   
   @AndrewJSchofield 



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: jira-unsubscr...@kafka.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org

Reply via email to