- 
                Notifications
    You must be signed in to change notification settings 
- Fork 14.7k
KAFKA-18913: Remove state.updater.enabled flag from StreamThread and … #20392
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
…related flow This change removes the `state.updater.enabled` negation from StreamThread, making the StateUpdater always active by default. As part of this cleanup: - Removed conditional code paths in StreamThread, ActiveTaskCreator, ProcessorStateManager, and StandbyTaskCreator. - Removed the unused ChangelogReader, since it is no longer required in the execution flow. - Updated affected tests (StreamThreadTest, ProcessorStateManagerTest, ActiveTaskCreatorTest, StreamThreadStateStoreProviderTest, etc.) to align with the new default behavior. This is the first step in a series of PRs to fully eliminate the `state.updater.enabled` configuration and simplify task management.
| This is the first in a series of PRs to remove the  The  For updating the  If there are any adjustments you’d like me to make in this PR, or if the way I am approaching this series is not ideal, please let me know. | 
| @janchilling -- You did go silent on your other PR, and I am just seeing this PR now. We thought you did loose interest and @shashankhs11 started to pickup this work.... I have no personal preference, but would kindly ask you and @shashankhs11 to agree on who will complete this work. -- Sorry for all this mix up, but you did go silent on the other PR :/ \cc @lucasbru | 
| I am happy to hand this work over to @janchilling completely as they were the first to work on this and I think it would not be fair for me to continue. However, I believe that I have a good understanding of the work that is required along with a systematic approach after having discussed this in detail offline. I would love to continue to work on this task but only if @janchilling hands it over to me. I would like to leave it to @janchilling to ultimately make the decision. | 
| Sounds good to me. Once @janchilling confirms taking on the whole work, we can close the other PRs. Note that completing the work does not only involve removing code, but also porting / reimplementing some tests that are currently only covered on the non-state-updater code path. It would be good to commit to completing the whole work, including those tests. | 
| Hi @mjsax , @lucasbru , @shashankhs11 , I’m happy to share this PR with @shashankhs11, and it would be great if I can collaborate with him on this. The main place I got stuck was while updating the test cases in the  
 Since the Earlier PR (Excuse my messiness) became quite large, I believe it was suggested to split it into smaller ones. So this is the first in a series of PRs I planned to create. Again, I’d be happy to share this with @shashankhs11 and contribute in any way that’s helpful. | 
| That would be awesome! I would really love to collaborate and help resolve the issue. However, I think collaborating might be a difficult task to tackle, but I've got a plan. I got some insights from @mjsax a few weeks ago on how we can approach this. I believe that this PR is still large and might be harder to review. Therefore, I would like to propose that we come up with an initial detailed plan (but flexible) wherein we can split the main task into smaller tasks. I would like to take the ownership of coming up with this detailed plan and will share an initial draft plan as soon as possible. You can then review the plan and add/remove details. If we can target to finalize a plan within the next few days, that would be awesome. Once we finalize a plan, we can then work on them and I believe it would also make it easier and quicker for @lucasbru to review smaller PRs. Does this sound good to you? Please feel free to give your insights on this idea. | 
| If you want to divide the work, a good approach would be to first split up the work to update all integrations test, before we merge any actual code changes? | 
| A label of 'needs-attention' was automatically added to this PR in order to raise the | 
| 
 from my analysis, I have identified these integration tests that requires update. 
 I think it would be best for us if we split this updates into 2 seperate tasks for each of us to work on Task 1
 Task 2
 We can further also have one PR per integration test to make it cleaner and easier to review. I can pickup Task 2 to get started with and @janchilling can pick up Task 1? Does this sound like a good plan? @mjsax @lucasbru Please add if I have missed anything. | 
| Cleaning up integration tests sounds good. However, before starting to actually removing the production code path, I would suggest starting with the tricky bit, and then working your way to the easier parts. We don't want to remove half of the old code path first, to then realize that we cannot figure out how to preserve test coverage without the old code path. IIRC the "tricky bit" that @janchilling was stuck with is porting the tests that use  Once we have solved this, the rest should just be removing code. | 
| A label of 'needs-attention' was automatically added to this PR in order to raise the | 
| I created a new subtask KAFKA-19666 to this parent issue to track the cleanup of all related integration tests. @lucasbru clean up of the below tests are ready for review 
 | 
| A label of 'needs-attention' was automatically added to this PR in order to raise the | 
| 
 Since, we did not hear back yet, I decided to proceed with the cleanup of all integration tests. @lucasbru cleanup of the remaining integration tests are available for review. This should complete the subtask KAFKA-19666 | 
| A label of 'needs-attention' was automatically added to this PR in order to raise the | 
| IIUC we are moving away from this PR and do it in separate RPs, so I am closing this. Let me know if we want to resurrect this | 
…related flow
This change removes the
state.updater.enablednegation fromStreamThread, making the StateUpdater always active by default. As part
of this cleanup:
ProcessorStateManager, and StandbyTaskCreator.
the execution flow.
ActiveTaskCreatorTest, StreamThreadStateStoreProviderTest, etc.) to
align with the new default behavior.
This is the first step in a series of PRs to fully eliminate the
state.updater.enabledconfiguration and simplify task management.