Skip to content

Conversation

@DDShantanuBadmanji
Copy link

Delete this text and replace it with a detailed description of your change. The
PR title and body will become the squashed commit message.

If you would like to tag individuals, add some commentary, upload images, or
include other supplemental information that should not be part of the eventual
commit message, please use a separate comment.

If applicable, please include a summary of the testing strategy (including
rationale) for the proposed change. Unit and/or integration tests are expected
for any behavior change and system tests should be considered for larger
changes.

xijiu and others added 30 commits March 7, 2025 09:45
Add the verify_license.py script to our build to detect missing licenses.

Reviewers: Chia-Ping Tsai <[email protected]>, Ken Huang <[email protected]>, David Arthur <[email protected]>
Add explicit not-null checks in Snapshot so we get a better error message in the event that a Snapshot object is accessed after erase has been called.

Reviewers: David Arthur <[email protected]>
Adds `describeStreamsGroup` to Admin API.

This exposes the result of the `DESCRIBE_STREAMS_GROUP` RPC in the Admin
API.

Reviewers: Bill Bejeck <[email protected]>
This patch allows for the immediatePeriodNs to be passed in when creating a periodic task

Reviewers: Colin P. McCabe <[email protected]>
…pache#19151)

If specified an invalid option then an exception trace appears with
`kafka-client-metrics.sh` and `kafka-groups.sh` utilities. Then once has
to explicitly remove the invalid argument and append `--help` to fetch
correct options. The PR fixes below error message to one with `cause`
and `usage`. This behaviour is similar to `kafka-console-consumer.sh`
and `kafka-console-share-consumer.sh`

Reviewers: Andrew Schofield <[email protected]>
The electionWasClean should also consider if the election is done
through ELR. Otherwise, the metric uncleanLeaderElection will wrongly
count the ELR election
https://issues.apache.org/jira/browse/KAFKA-18940

Reviewers: Jun Rao <[email protected]>
…pache#19125)

- Adding a space, article and punctuation to the Producer config doc
strings for consistency and readability.

Reviewers: TengYao Chi <[email protected]>, Ken Huang <[email protected]>, Justine Olshan <[email protected]>
…sponse (apache#19127)

The kafka controllers need to set kraft.version in their
ApiVersionsResponse messages according to the current kraft.version
reported by the Raft layer. Instead, currently they always set it to 0.

Also remove FeatureControlManager.latestFinalizedFeatures. It is not
needed and it does a lot of copying.

Reviewers: Jun Rao <[email protected]>, Chia-Ping Tsai <[email protected]>
…19160)

Running `bin/kafka-features.sh upgrade --release-version 4.0` results in
the following error. This PR fixes the issue by adding the required
argument.

`kafka-features: error: one of the arguments --bootstrap-server
--bootstrap-controller is required.`

Reviewers: Colin P. McCabe <[email protected]>
…, and LogAppendInfo to record classes (apache#19062)

Migrate the following data carrier class to records to eliminate
constructors, `equals`, `hashCode`, and `toString`.
* `Entry` in `LogHistory`
* `SnapshotPath`

Additionally, migrate the following classes as discussed:
* OffsetAndEpoch
* LogFetchInfo
* LogAppendInfo

In Java, accessing a field in record class requires parentheses.
In Scala, parentheses are not needed because Scala allows omitting them
when calling parameterless methods; hence, there is no need to change
the Scala code.

Reviewers: Ken Huang <[email protected]>, Chia-Ping Tsai <[email protected]>
* Add `DynamicThreadPool.java` to the server module.
* Remove the old DynamicThreadPool object in the `DynamicBrokerConfig.scala`.

Reviewers: TengYao Chi <[email protected]>, Chia-Ping Tsai <[email protected]>
Remove unused `saslServerProperties`, `saslClientProperties`,
`adminClientProperties`, `producerProperties`, and `consumerProperties`
in ClusterConfig.

First, I quickly fixed the unused adminClientProperties, and then I will
move on to apache#19094 to fix the related
issues.

Pass AdminClientRebootstrapTest
<img width="1398" alt="Screenshot 2025-03-09 at 12 54 57 PM"
src="https://github.com/user-attachments/assets/73c50376-6602-493d-8abd-0eb2bb304114"
/>

Pass ClusterConfigTest
<img width="1117" alt="Screenshot 2025-03-09 at 12 55 28 PM"
src="https://github.com/user-attachments/assets/b4da59da-dfdf-4698-9077-5086854360ab"
/>

Reviewers: Chia-Ping Tsai <[email protected]>
Move AclPublisher to org.apache.kafka.metadata.publisher package.

Reviewers: Christo Lolov <[email protected]>, Chia-Ping Tsai <[email protected]>
This PR addresses minor grammar and clarity issues in upgrade.html doc.

Reviewers: mingdaoy <[email protected]>, Colin P. McCabe <[email protected]>, TengYao Chi <[email protected]>, Ken Huang <[email protected]>, Jhen-Yung Hsu <[email protected]>, Chia-Ping Tsai <[email protected]>
Recently, we found a regression that could have been detected by static
analysis, since a local variable wasn't being passed to a method during
a refactoring, and was left unused. It was fixed in
[7a749b5](apache@7a749b5),
but almost slipped into 4.0. Unused variables are typically detected by
IDEs, but this is insufficient to prevent these kinds of bugs. This
change enables unused local variable detection in checkstyle for Kafka.

A few notes on the usage:
- There are two situations in which people actually want to have a local
variable but not use it. First, there are `for (Type ignored:
collection)` loops which have to loop `collection.length` number of
times, but that do not use `ignored` in the loop body. These are
typically still easier to read than a classical `for` loop. Second, some
IDEs detect it if a return value of a function such as `File.delete` is
not being used. In this case, people sometimes store the result in an
unused local variable to make ignoring the return value explicit and to
avoid the squiggly lines.
- In Java 22, unsued local variables can be omitted by using a single
underscore `_`. This is supported by checkstyle. In pre-22 versions,
IntelliJ allows such variables to be named `ignored` to suppress the
unused local variable warning. This pattern is often (but not
consistently) used in the Kafka codebase. This is, however, not
supported by checkstyle.

Since we cannot switch to Java 22, yet, and we want to use automated
detection using checkstyle, we have to resort to prefixing the unused
local variables with `@SuppressWarnings("UnusedLocalVariable")`. We have
to apply this in 11 cases across the Kafka codebase. While not being
pretty, I'd argue it's worth it to prevent bugs like the one fixed in
[7a749b5](apache@7a749b5).

Reviewers: Andrew Schofield <[email protected]>, David Arthur
<[email protected]>, Matthias J. Sax <[email protected]>, Bruno
Cadonna <[email protected]>, Kirk True <[email protected]>
Infra has manually setup rulesets for trunk and our release branches
(INFRA-26603). We need to disable the legacy branch protections to avoid
interfering with the new rulesets.

Reviewers: Chia-Ping Tsai <[email protected]>
…dinator is loaded (apache#19173)

This PR adds `scheduleShareGroupSessionTimeout` for all the persisted
members of a share group when the group coordinator is loaded.

Reviewers: Andrew Schofield <[email protected]>
…nment and AbstractCoordinatorTest (apache#18945)

Reviewers: Lianet Magrans <[email protected]>
This commit adds the conditions to decide when a Streams group heartbeat
should be sent.
A heartbeat should be sent when:
- the group coordinator is available
- the member is part of the Streams group or wants to join it
- the heartbeat interval expired or the member is leaving the group or
acknowledging the assginment

This commit does not implement:
- not sending fields that did not change
- handling errors

Reviewers: Zheguang Zhao <[email protected]>, Lucas
Brutschy <[email protected]>
Add a step summary for the PR linter which shows all the errors in a
more readable format.

Reviewers: Chia-Ping Tsai <[email protected]>
The upgrade test in question is not supported for AK 3.3.2 due to a
[known issue](https://issues.apache.org/jira/browse/KAFKA-18442).
Previous attempt at solving this left the `metadata.log.dir` empty which
leads to the following crash log:

```
ERROR Exiting Kafka due to fatal exception (kafka.Kafka$)
org.apache.kafka.common.KafkaException: No `meta.properties` found in  (have you run `kafka-storage.sh` to format the directory?)
	at kafka.server.BrokerMetadataCheckpoint$.$anonfun$getBrokerMetadataAndOfflineDirs$2(BrokerMetadataCheckpoint.scala:172)
	at scala.collection.Iterator.foreach(Iterator.scala:943)
	at scala.collection.Iterator.foreach$(Iterator.scala:943)
	at scala.collection.AbstractIterator.foreach(Iterator.scala:1431)
	at scala.collection.IterableLike.foreach(IterableLike.scala:74)
	at scala.collection.IterableLike.foreach$(IterableLike.scala:73)
	at scala.collection.AbstractIterable.foreach(Iterable.scala:56)
	at kafka.server.BrokerMetadataCheckpoint$.getBrokerMetadataAndOfflineDirs(BrokerMetadataCheckpoint.scala:161)
	at kafka.server.KafkaRaftServer$.initializeLogDirs(KafkaRaftServer.scala:184)
	at kafka.server.KafkaRaftServer.<init>(KafkaRaftServer.scala:61)
	at kafka.Kafka$.buildServer(Kafka.scala:79)
	at kafka.Kafka$.main(Kafka.scala:87)
	at kafka.Kafka.main(Kafka.scala)
```
In "Upgrading to 4.0.0 from any version 0.8.x through 3.9.x" section, we
directly give instructions about [Upgrading to KRaft-based
clusters](https://kafka.apache.org/documentation/#upgrade_390_kraft),
but there might still be some users under ZK cluster before upgrading to
v4.0.0. We need to make it clear that they need to upgrade to KRaft mode
first before upgrading to v4.0.0 in "Upgrading to 4.0.0 from any version
0.8.x through 3.9.x" section.

Reviewers: TengYao Chi <[email protected]>, Ken Huang <[email protected]>, Chia-Ping Tsai <[email protected]>
The current homogeneous SimpleAssignor for share groups is not very good
at revoking partitions which have previously been assigned when the
number of members increases. This PR improves the situation.

It also fixes the sorting of assignments in `kafka-consumer-groups.sh`
and `kafka-share-groups.sh` so that it sorts partition indices
numerically instead of alphabetically. It also adds the missing number
of partitions column for share groups.
smjn and others added 19 commits April 10, 2025 15:56
…[1/N] (apache#19432)

* We wish to track the time of creation of the `ShareSnapshot` records
so that automated jobs could force their creation if a share partition
has gone cold (no updates for a specified time interval).
* To accomplish this, we have added 2 new fields `CreateTimestamp` and
`WriteTimestamp` in the `ShareSnapshot` record.
* The former tracks snapshot creation due to regular RPC calls while the
latter will track snapshots created by periodic jobs.
* In this PR we have made the requisite changes.
* This is a first of a series of PRs to create the automated jobs and
associated scaffolding.

Reviewers: Andrew Schofield <[email protected]>
…19425)

KIP-1071 creates internal topics broker-side, so this test checks
whether, when KIP-1071 is enabled, basically the same topics are
created.

It also adds a little helper method in `EmbeddedKafkaCluster`, so that
fewer code changes are required to enable KIP-1071. We use that helper
in the already enabled SmokeTestDriverIntegrationTest and revert some of
the changes there (making the cluster `final` again).

Reviewers: Bill Bejeck <[email protected]>, PoAn Yang
 <[email protected]>
…pache#19421)

In the first version of the integration of the stream thread with the
new Streams rebalance protocol, the consumer used a dedicated event
queue for Streams/specific background events to request the stream
thread to call the rebalance callbacks. That  led to an issue where the
consumer times out when unsubscribing.

This commit gets rid of the dedicated queue and incorporates the
Streams-specific background events into event queue used by the
consumer.

Reviewers: Lucas Brutschy <[email protected]>
…apache#19363)

* Currently, the delete share group code flow uses
`group.subscribedTopicNames()` to fetch information about all the share
partitions to which a share group is subscribed to.
* However, this is incorrect since once the group is EMPTY, a
precondition for delete, the aforementioned method will return an empty
list.
* In this PR we have leveraged the `ShareGroupStatePartitionMetadata`
record to grab the `initialized` and `initializing` partitions to build
the delete candidates, which remedies the situation.

Reviewers: Andrew Schofield <[email protected]>
apache#19354)

**Summary**
Extend ApplicationRecoverableException related exceptions

Reviewers: Artem Livshits <[email protected]>, Justine Olshan
 <[email protected]>
…umulator (apache#19399)

Remove unused `ApiVersions` variable from Sender and RecordAccumulator.

Reviewers: PoAn Yang <[email protected]>, Ken Huang
<[email protected]>, Parker Chang <[email protected]>,
Chia-Ping Tsai <[email protected]>
…ed parameter (apache#19410)

It seems `timeMs` this parameter never used in Kafka project, the method
init commit is

apache@b5f90da

Reviewers: Jhen-Yung Hsu <[email protected]>, PoAn Yang
<[email protected]>, TengYao Chi <[email protected]>, Chia-Ping Tsai
<[email protected]>
…tion-tests module (apache#19289)

Use Java to rewrite `TransactionsWithMaxInFlightOneTest` by new test
infra and move it to client-integration-tests module.

Reviewers: Chia-Ping Tsai <[email protected]>
…#19435)

Create a single formatter for use with `kafka-console-consumer.sh` that
formats all record types for share groups on the `__consumer_offsets`
topic.
…pache#19423)

Add support for streams groups in kafka-groups.sh.

The change adds command-line options `--streams` to list only streams
groups, and value `--group-type streams`. Those two options are mutually
exclusive with other group type and protocol filters specified on the
command line.

Includes a small integration test that spins up a kafka streams
application and lists the group.

Reviewers: Bill Bejeck <[email protected]>, Alieh Saeedii
<[email protected]>
…pache#19438)

Enable KIP-1071 parameter in `StandbyTaskCreationIntegrationTest`.

Required a fix: In `ChangelogTopic.setup`, we actually need to return
both the source-topic (optimized) and the non-source-topic changelog
topics, since otherwise we will not find the partition number later on.

Extended `EmbeddedKafkaCluster` to set the number of standby replicas
dynamically for the group. We need to initialize it to one for the
integration test to go through.

Reviewers: Bill Bejeck <[email protected]>
Remove `OffsetConfig` which was used by old coordinator.

Reviewers: PoAn Yang <[email protected]>, Ken Huang
<[email protected]>, David Jacot <[email protected]>, TengYao Chi
<[email protected]>, Chia-Ping Tsai <[email protected]>
…up configs (apache#19436)

This PR introduces integration tests for verifying
- altering configs
- `describe` output

for a streams group.  The configs have been defined in `KIP-1071`.

Reviewers: Lucas Brutschy <[email protected]>
This PR proposes a switch to enable share groups for 4.1 (preview) and
4.2 (GA).

* `share.version=1` to indicate that share groups are enabled. This is
used as the switch for turning share groups on and off.

In 4.1, the default will be `share.version=0`. Then a user wanting to
evaluate the preview of KIP-932 would use `bin/kafka-features.sh
--bootstrap.server xxxx upgrade --feature share.version=1`.

In 4.2, the default will be `share.version=1`.

Reviewers: Jun Rao <[email protected]>
…apache#19447)

There was a bug in `ConsoleShareConsumer` where the delivery count
received in the `ShareFetchResponse` was not sent to the formatter to be
shown to the user. PR fixes the bug by passing in the delivery count in
a different constructor for `ConsumerRecord`.

Reviewers: Andrew Schofield <[email protected]>
…che#19362)

It is currently impossible to set both number of retries and idempotency
in the DucktapeVerifiable producer. This change allows that to occur.

Reviewers: PoAn Yang <[email protected]>, Manikumar Reddy <[email protected]>
Move LogCleaner and related classes to storage module and rewrite in
Java.

Reviewers: Mickael Maison <[email protected]>, Jun Rao <[email protected]>
@coderabbitai
Copy link

coderabbitai bot commented Sep 5, 2025

Important

Review skipped

Auto reviews are disabled on base/target branches other than the default branch.

Please check the settings in the CodeRabbit UI or the .coderabbit.yaml file in this repository. To trigger a single review, invoke the @coderabbitai review command.

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.

Note

Other AI code review bot(s) detected

CodeRabbit has detected other AI code review bot(s) in this pull request and will avoid duplicating their findings in the review comments. This may lead to a less comprehensive review.

✨ Finishing touches
🧪 Generate unit tests
  • Create PR with unit tests
  • Post copyable unit tests in a comment
  • Commit unit tests in branch clone-KAFKA-18894

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

@DDShantanuBadmanji
Copy link
Author

@coderabbitai full review

@DDShantanuBadmanji
Copy link
Author

/gemini review

@coderabbitai
Copy link

coderabbitai bot commented Sep 5, 2025

✅ Actions performed

Full review triggered.

@DDShantanuBadmanji
Copy link
Author

@coderabbitai full review

@coderabbitai
Copy link

coderabbitai bot commented Sep 5, 2025

✅ Actions performed

Full review triggered.

@gemini-code-assist
Copy link

Warning

Gemini encountered an error creating the summary. You can try again by commenting /gemini summary.

@DDShantanuBadmanji
Copy link
Author

/gemini summary

Copy link

@gemini-code-assist gemini-code-assist bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request introduces a massive refactoring of the testing infrastructure, moving away from a dedicated quarantinedTest task to a more flexible tag-based system. It also includes significant updates to the consumer group protocol implementation, adds new admin client APIs for Streams and Share groups, and refactors various internal components. Many new test files and utility scripts have been added to support these changes. The overall direction seems to be towards a more modern and maintainable codebase. My review focuses on a couple of minor issues in the Python scripts.

Comment on lines +213 to +215
test_tags.append("+github")
tags = []
for tag in test_tags:

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

medium

The test_tags list is modified in-place. This is a side effect that can be surprising for callers of this function. It's generally better to avoid modifying input arguments directly. Consider creating a new list that includes the additional tag.

Suggested change
test_tags.append("+github")
tags = []
for tag in test_tags:
all_tags = test_tags + ["+github"]
tags = []
for tag in all_tags:

Comment on lines +488 to +489
print(build_ids)
print(list(build_ids))

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

medium

These print statements appear to be for debugging purposes and should be removed before merging.

@gemini-code-assist
Copy link

Summary of Changes

This pull request significantly modernizes and expands the Kafka project's capabilities. It includes a major overhaul of the testing framework to provide more detailed and actionable insights into test stability and performance. Concurrently, it introduces a suite of new features for managing Kafka Streams applications and enhances the behavior of share consumers, offering more control over their operational aspects. These changes are supported by extensive updates to the build system and underlying dependencies, ensuring a more robust and maintainable codebase.

Highlights

  • Test Infrastructure Overhaul: Enhanced test infrastructure with new Gradle task options, improved Develocity reporting for flaky, new, and persistently failing tests, and refined JUnit parsing for better error handling.
  • Kafka Streams Group Management: Introduced comprehensive Kafka Streams group management capabilities via new AdminClient APIs and command-line tools, supporting description, listing, offset alteration, and deletion.
  • Share Consumer Enhancements: Improved share consumer functionality with explicit acknowledgement modes and robust internal handling of record acknowledgements, along with new configuration options.
  • Build System and Dependency Updates: Upgraded Gradle plugin versions, refactored module structures (especially test utilities), and updated licensing information to ensure a more robust and maintainable codebase.
  • AdminClient API Stability: Marked numerous core AdminClient APIs as stable by removing the @InterfaceStability.Evolving annotation, indicating increased maturity and reliability.
Changelog
  • .asf.yaml
    • Updated ASF configuration for GitHub, including merge button policies and collaborator lists.
  • .github/actions/run-gradle/action.yml
    • Enhanced Gradle test action with new inputs for test retries, repeats, and selective execution of new/flaky tests.
  • .github/actions/setup-gradle/action.yml
    • Upgraded Gradle setup action to v4.3.0.
  • .github/pull_request_template.md
    • Added a new standard pull request template.
  • .github/scripts/develocity_reports.py
    • Refactored Develocity reporting to use tag-based filtering, added persistent failing test reports, and updated Develocity domain.
  • .github/scripts/junit.py
    • Improved JUnit report parsing, added tracking for new tests, and refined error handling.
  • .github/scripts/pr-format.py
    • Introduced a new script for PR title and body linting and reformatting.
  • .github/scripts/thread-dump.sh
    • Minor improvements to thread dump collection.
  • LICENSE-binary
    • Updated bundled third-party component licenses.
  • NOTICE-binary
    • Corrected a typo.
  • PULL_REQUEST_TEMPLATE.md
    • Removed the old pull request template.
  • README.md
    • Updated documentation for test execution commands and Kafka setup examples.
  • bin/kafka-streams-groups.sh
    • Added a new command-line tool for Streams group management.
  • bin/kafka-verifiable-share-consumer.sh
    • Added a new command-line tool for verifiable share consumer.
  • build.gradle
    • Performed extensive refactoring of project dependencies, especially for test utilities, and updated Gradle plugin versions.
  • checkstyle/checkstyle.xml
    • Added UnusedLocalVariable check.
  • checkstyle/import-control-clients-integration-tests.xml
    • Added import control rules for the new clients integration tests module.
  • checkstyle/import-control-coordinator-common.xml
    • Updated import control rules.
  • checkstyle/import-control-core.xml
    • Updated import control rules, including DTD version and new subpackage rules.
  • checkstyle/import-control-examples.xml
    • Added import control rules for the examples module.
  • checkstyle/import-control-group-coordinator.xml
    • Updated import control rules.
  • checkstyle/import-control-metadata.xml
    • Updated import control rules.
  • checkstyle/import-control-server-common.xml
    • Updated import control rules.
  • checkstyle/import-control-server.xml
    • Updated import control rules.
  • checkstyle/import-control-share-coordinator.xml
    • Updated import control rules.
  • checkstyle/import-control-share.xml
    • Removed import control rules.
  • checkstyle/import-control-storage.xml
    • Updated import control rules.
  • checkstyle/import-control-test-common-api.xml
    • Renamed to checkstyle/import-control-test-common-util.xml and updated rules.
  • checkstyle/import-control-test-common-internal-api.xml
    • Added import control rules for the new test-common-internal-api module.
  • checkstyle/import-control-test-common.xml
    • Renamed to checkstyle/import-control-test-common-runtime.xml and updated rules.
  • checkstyle/import-control-transaction-coordinator.xml
    • Updated import control rules.
  • checkstyle/import-control.xml
    • Updated global import control rules, including DTD version.
  • checkstyle/suppressions.xml
    • Updated checkstyle suppressions.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/clients/ClientRebootstrapTest.java
    • Added new integration test for client rebootstrap behavior.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/clients/TransactionsExpirationTest.java
    • Added new integration test for transaction expiration.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/clients/TransactionsWithMaxInFlightOneTest.java
    • Added new integration test for transactions with max.in.flight.requests.per.connection=1.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/clients/admin/DescribeAuthorizedOperationsTest.java
    • Added new integration test for describing authorized operations.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/clients/admin/RackAwareAutoTopicCreationTest.java
    • Added new integration test for rack-aware auto topic creation.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/clients/admin/StaticBrokerConfigTest.java
    • Added new integration test for static broker configs.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/clients/consumer/ConsumerTopicCreationTest.java
    • Added new integration test for consumer topic creation.
  • clients/clients-integration-tests/src/test/java/org/apache/kafka/server/quota/CustomQuotaCallbackTest.java
    • Added new integration test for custom quota callbacks.
  • clients/clients-integration-tests/src/test/resources/log4j2.yaml
    • Added new log4j2 configuration for integration tests.
  • clients/src/main/java/org/apache.kafka/clients/admin/StreamsGroupSubtopologyDescription.java
    • Added new class for Streams group subtopology description.
  • clients/src/main/java/org/apache/kafka/clients/ClientUtils.java
    • Minor type safety improvement.
  • clients/src/main/java/org/apache/kafka/clients/NetworkClient.java
    • Removed ZK migration related field from API versions.
  • clients/src/main/java/org/apache/kafka/clients/NodeApiVersions.java
    • Removed ZK migration related field.
  • clients/src/main/java/org/apache/kafka/clients/admin/AbortTransactionOptions.java
    • Removed @InterfaceStability.Evolving annotation.
  • clients/src/main/java/org/apache/kafka/clients/admin/AbortTransactionResult.java
    • Minor type safety improvement.
  • clients/src/main/java/org/apache/kafka/clients/admin/AbstractOptions.java
  • clients/src/main/java/org/apache/kafka/clients/admin/Admin.java
    • Added new AdminClient APIs for Streams group management and transaction termination.
  • clients/src/main/java/org/apache/kafka/clients/admin/AlterConsumerGroupOffsetsResult.java
    • Made error message more generic.
  • clients/src/main/java/org/apache/kafka/clients/admin/AlterPartitionReassignmentsOptions.java
    • Added allowReplicationFactorChange property.
  • clients/src/main/java/org/apache/kafka/clients/admin/AlterPartitionReassignmentsResult.java
    • Minor type safety improvement.
  • clients/src/main/java/org/apache/kafka/clients/admin/AlterShareGroupOffsetsOptions.java
    • Added new options for altering share group offsets.
  • clients/src/main/java/org/apache/kafka/clients/admin/AlterShareGroupOffsetsResult.java
    • Added new result for altering share group offsets.
  • clients/src/main/java/org/apache/kafka/clients/admin/AlterStreamsGroupOffsetsOptions.java
    • Added new options for altering Streams group offsets.
  • clients/src/main/java/org/apache/kafka/clients/admin/AlterStreamsGroupOffsetsResult.java
    • Added new result for altering Streams group offsets.
  • clients/src/main/java/org/apache/kafka/clients/admin/DeleteShareGroupOffsetsOptions.java
    • Added new options for deleting share group offsets.
  • clients/src/main/java/org/apache/kafka/clients/admin/DeleteShareGroupOffsetsResult.java
    • Added new result for deleting share group offsets.
  • clients/src/main/java/org/apache/kafka/clients/admin/DeleteStreamsGroupsOptions.java
    • Added new options for deleting Streams groups.
  • clients/src/main/java/org/apache/kafka/clients/admin/DeleteStreamsGroupsResult.java
    • Added new result for deleting Streams groups.
  • clients/src/main/java/org/apache/kafka/clients/admin/DescribeClusterResult.java
    • Improved describeCluster functionality and documentation.
  • clients/src/main/java/org/apache/kafka/clients/admin/DescribeConfigsOptions.java
    • Added note about describing broker/controller configs.
  • clients/src/main/java/org/apache/kafka/clients/admin/DescribeStreamsGroupsOptions.java
    • Added new options for describing Streams groups.
  • clients/src/main/java/org/apache/kafka/clients/admin/DescribeStreamsGroupsResult.java
    • Added new result for describing Streams groups.
  • clients/src/main/java/org/apache/kafka/clients/admin/StreamsGroupDescription.java
    • Added new class for Streams group description.
  • clients/src/main/java/org/apache/kafka/clients/admin/StreamsGroupMemberAssignment.java
    • Added new class for Streams group member assignment.
  • clients/src/main/java/org/apache/kafka/clients/admin/StreamsGroupMemberDescription.java
    • Added new class for Streams group member description.
  • clients/src/main/java/org/apache/kafka/clients/admin/TerminateTransactionOptions.java
    • Added new options for terminating transactions.
  • clients/src/main/java/org/apache/kafka/clients/consumer/AcknowledgeType.java
    • Added Javadoc.
  • clients/src/main/java/org/apache/kafka/clients/consumer/AcknowledgementCommitCallback.java
    • Updated Javadoc.
  • clients/src/main/java/org/apache/kafka/clients/consumer/CloseOptions.java
    • Added new options for closing consumers.
  • clients/src/main/java/org/apache/kafka/clients/consumer/Consumer.java
    • Added close(CloseOptions) and deprecated close(Duration).
  • clients/src/main/java/org/apache/kafka/clients/consumer/ConsumerConfig.java
    • Added new config for share consumer acknowledgement mode and updated documentation.
  • clients/src/main/java/org/apache/kafka/clients/consumer/ConsumerInterceptor.java
    • Added Monitorable interface to Javadoc.
  • clients/src/main/java/org/apache/kafka/clients/consumer/ConsumerRecord.java
    • Added detailed thread safety notes.
  • clients/src/main/java/org/apache/kafka/clients/consumer/KafkaConsumer.java
    • Updated close behavior and introduced new close API.
  • clients/src/main/java/org/apache/kafka/clients/consumer/KafkaShareConsumer.java
    • Updated share consumer to use new config and clarified close behavior.
  • clients/src/main/java/org/apache/kafka/clients/consumer/MockConsumer.java
    • Added functionality to control poll behavior and new close API.
  • clients/src/main/java/org/apache/kafka/clients/consumer/OffsetCommitCallback.java
    • Marked as a functional interface.
  • clients/src/main/java/org/apache/kafka/clients/consumer/ShareConsumer.java
    • Clarified purpose of ShareConsumer.
  • clients/src/main/java/org/apache/kafka/clients/consumer/ShareConsumerConfig.java
    • Added new config class for share consumers.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/AbstractCoordinator.java
    • Updated coordinator to support new close options and refactored heartbeat thread.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/AbstractFetch.java
    • Improved fetch logic and logging.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/AcknowledgementCommitCallbackHandler.java
    • Used KafkaException for acknowledgement errors.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/Acknowledgements.java
    • Refactored acknowledgement error handling.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/AsyncKafkaConsumer.java
    • Major refactoring to support Streams rebalance protocol, new close options, and improved error handling.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/BaseHeartbeatThread.java
    • Added new base class for heartbeat threads.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ClassicKafkaConsumer.java
    • Updated classic consumer to support new close options and refactored heartbeat thread.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/CommitRequestManager.java
    • Refactored commit logic, improved error handling, and added new auto-commit functionality.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/CompletedFetch.java
    • Minor refactoring for logging and deserializer usage.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ConsumerCoordinator.java
    • Updated coordinator to support new close options.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ConsumerDelegateCreator.java
    • Allowed passing Streams rebalance data during consumer creation.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ConsumerHeartbeatRequestManager.java
    • Updated heartbeat manager to support new close options.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/CoordinatorRequestManager.java
    • Refactored coordinator request manager for better error handling and close behavior.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/Deserializers.java
    • Integrated deserializers with the plugin system for metrics.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/HeartbeatRequestState.java
    • Added new class for heartbeat request state.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/NodeAcknowledgements.java
    • Added new class to combine acknowledgements with node ID.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/RequestManagers.java
    • Integrated Streams related managers into the request managers.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareCompletedFetch.java
    • Added node ID to share completed fetch.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareConsumeRequestManager.java
    • Major refactoring of share consume request manager to support node-specific acknowledgements and improved error handling.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareHeartbeatRequestManager.java
    • Updated share heartbeat manager to support new close options.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareInFlightBatch.java
    • Added node ID to share in-flight batch.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareMembershipManager.java
    • Updated share membership manager to accept auto-commit enabled flag.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareSessionHandler.java
    • Refactored share session handler for better fetch and acknowledge management.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/StreamsGroupHeartbeatRequestManager.java
    • Added new request manager for Streams group heartbeats.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/StreamsMembershipManager.java
    • Added new membership manager for Streams groups.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/StreamsRebalanceData.java
    • Added new class to hold Streams rebalance data.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/StreamsRebalanceListener.java
    • Added new listener for Streams rebalance events.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/SubscriptionState.java
    • Added isAssignedFromRe2j method.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/TimedRequestState.java
    • Allowed resetting timeout for timed requests.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/AbstractTopicMetadataEvent.java
    • Indicated if the event requires subscription metadata.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/ApplicationEvent.java
    • Extended application event types.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/ApplicationEventProcessor.java
    • Major refactoring to support Streams rebalance protocol, new close options, and improved event processing.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/CommitEvent.java
    • Allowed tracking when offsets are ready for commit.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/LeaveGroupOnCloseEvent.java
    • Added group membership operation to leave group event.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/PollEvent.java
    • Allowed tracking completion of reconciliation and auto-commit.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/ShareAcknowledgeAsyncEvent.java
    • Updated event to use node-specific acknowledgements and deadline.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/ShareAcknowledgeOnCloseEvent.java
    • Updated event to use node-specific acknowledgements.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/ShareAcknowledgeSyncEvent.java
    • Updated event to use node-specific acknowledgements.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/ShareFetchEvent.java
    • Updated event to use node-specific acknowledgements and control record acknowledgements.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/StopFindCoordinatorOnCloseEvent.java
    • Added new event to stop finding coordinator on close.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/StreamsOnAllTasksLostCallbackCompletedEvent.java
    • Added new event for Streams on all tasks lost callback completed.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/StreamsOnAllTasksLostCallbackNeededEvent.java
    • Added new event for Streams on all tasks lost callback needed.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/StreamsOnTasksAssignedCallbackCompletedEvent.java
    • Added new event for Streams on tasks assigned callback completed.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/StreamsOnTasksAssignedCallbackNeededEvent.java
    • Added new event for Streams on tasks assigned callback needed.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/StreamsOnTasksRevokedCallbackCompletedEvent.java
    • Added new event for Streams on tasks revoked callback completed.
  • clients/src/main/java/org/apache/kafka/clients/consumer/internals/events/StreamsOnTasksRevokedCallbackNeededEvent.java
    • Added new event for Streams on tasks revoked callback needed.
  • clients/src/main/java/org/apache/kafka/clients/producer/Callback.java
    • Marked Callback as functional interface and updated Javadoc.
  • clients/src/main/java/org/apache/kafka/clients/producer/KafkaProducer.java
    • Integrated serializers and partitioner with plugin system, refactored sender creation, and updated Javadoc.
  • clients/src/main/java/org/apache/kafka/clients/producer/MockProducer.java
    • Updated mock producer to use RecordHeaders.
  • clients/src/main/java/org/apache/kafka/clients/producer/Partitioner.java
    • Indicated that partitioners can register metrics.
  • clients/src/main/java/org/apache/kafka/clients/producer/ProducerConfig.java
    • Updated producer configuration documentation and default values.
  • core/src/test/java/kafka/admin/AdminFenceProducersTest.java
    • Moved to clients/clients-integration-tests.
  • core/src/test/java/kafka/admin/ClientTelemetryTest.java
    • Moved to clients/clients-integration-tests.
  • core/src/test/java/kafka/admin/DeleteTopicTest.java
    • Moved to clients/clients-integration-tests.
  • core/src/test/java/kafka/clients/consumer/ConsumerIntegrationTest.java
    • Moved to clients/clients-integration-tests.
  • server-common/src/main/java/org/apache/kafka/server/config/ZooKeeperInternals.java
    • Renamed to clients/src/main/java/org/apache/kafka/clients/admin/TerminateTransactionResult.java and repurposed.
Activity
  • The author attempted to trigger multiple full reviews and summaries, encountering limitations with the automated review tool due to the large number of changed files.
  • Automated review comments provided suggestions for code style (avoiding in-place list modification) and removing debugging print statements in the develocity_reports.py script.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.