Annotation Interface EmbeddedKafka
@ExtendWith(EmbeddedKafkaCondition.class)
@Target(TYPE)
@Retention(RUNTIME)
@Documented
@Inherited
@DisabledInAotMode
public @interface EmbeddedKafka
Annotation that can be specified on a test class that runs Spring for Apache Kafka
 based tests.
 Provides the following features over and above the regular Spring TestContext
 Framework:
 
- Registers a EmbeddedKafkaBrokerbean with theEmbeddedKafkaBroker.BEAN_NAMEbean name.
The typical usage of this annotation is like:
 @RunWith(SpringRunner.class)
 @EmbeddedKafka
 public class MyKafkaTests {
    @Autowired
    private EmbeddedKafkaBroker kafkaEmbedded;
    @Value("${spring.embedded.kafka.brokers}")
    private String brokerAddresses;
 }
 - Since:
- 1.3
- See Also:
- 
Optional Element SummaryOptional ElementsModifier and TypeOptional ElementDescriptionintTimeout in seconds for admin operations (e.g.The property name to set with the bootstrap server addresses as well as the default "spring.embedded.kafka.brokers".String[]Properties in form key=value that should be added to the broker config before runs.SpringResourceurl specifying the location of properties that should be added to the broker config.booleanintbooleanUse KRaft instead of Zookeeper; default true.intint[]Set explicit ports on which the kafka brokers will listen.String[]Topics that should be created Topics may contain property place holders, e.g.intintTimeout for internal ZK client connection.intTimeout for internal ZK client session.intSet the port on which the embedded Zookeeper should listen;
- 
Element Details- 
value@AliasFor("count") int value- Returns:
- the number of brokers
 - Default:
- 1
 
- 
count@AliasFor("value") int count- Returns:
- the number of brokers
 - Default:
- 1
 
- 
controlledShutdownboolean controlledShutdown- Returns:
- passed into kafka.utils.TestUtils.createBrokerConfig().
 - Default:
- false
 
- 
portsint[] portsSet explicit ports on which the kafka brokers will listen. Useful when running an embedded broker that you want to access from other processes. A port must be provided for each instance, which means the number of ports must match the value of the count attribute.- Returns:
- ports for brokers.
- Since:
- 2.2.4
 - Default:
- {0}
 
- 
zookeeperPortint zookeeperPortSet the port on which the embedded Zookeeper should listen;- Returns:
- the port.
- Since:
- 2.3
 - Default:
- 0
 
- 
partitionsint partitions- Returns:
- partitions per topic
 - Default:
- 2
 
- 
topicsString[] topicsTopics that should be created Topics may contain property place holders, e.g.topics = "${kafka.topic.one:topicOne}"The topics will be created withpartitions()partitions; to provision other topics with other partition counts call theaddTopics(NewTopic... topics)method on the autowired broker. Place holders will only be resolved when there is a Spring test application context present (such as when using@SpringJunitConfig or @SpringRunner.- Returns:
- the topics to create
 - Default:
- {}
 
- 
brokerPropertiesString[] brokerPropertiesProperties in form key=value that should be added to the broker config before runs. When used in a Spring test context, properties may contain property place holders, e.g.delete.topic.enable=${topic.delete:true}. Place holders will only be resolved when there is a Spring test application context present (such as when using@SpringJunitConfig or @SpringRunner.- Returns:
- the properties to add
- See Also:
 - Default:
- {}
 
- 
brokerPropertiesLocationString brokerPropertiesLocationSpringResourceurl specifying the location of properties that should be added to the broker config. When used in a Spring test context, thebrokerPropertiesLocationurl and the properties themselves may contain place holders that are resolved during initialization. Properties specified bybrokerProperties()will override properties found inbrokerPropertiesLocation. Place holders will only be resolved when there is a Spring test application context present (such as when using@SpringJunitConfig or @SpringRunner.- Returns:
- a Resourceurl specifying the location of properties to add
- See Also:
 - Default:
- ""
 
- 
bootstrapServersPropertyString bootstrapServersPropertyThe property name to set with the bootstrap server addresses as well as the default "spring.embedded.kafka.brokers". Defaults tospring.kafka.bootstrap-serverssince 3.0.10.- Returns:
- the property name.
- Since:
- 2.3
- See Also:
 - Default:
- "spring.kafka.bootstrap-servers"
 
- 
zkConnectionTimeoutint zkConnectionTimeoutTimeout for internal ZK client connection.- Returns:
- default EmbeddedKafkaBroker#DEFAULT_ZK_CONNECTION_TIMEOUT.
- Since:
- 2.4
 - Default:
- 18000
 
- 
zkSessionTimeoutint zkSessionTimeoutTimeout for internal ZK client session.- Returns:
- default EmbeddedKafkaBroker#DEFAULT_ZK_SESSION_TIMEOUT.
- Since:
- 2.4
 - Default:
- 18000
 
- 
adminTimeoutint adminTimeoutTimeout in seconds for admin operations (e.g. topic creation, close).- Returns:
- default EmbeddedKafkaBroker.DEFAULT_ADMIN_TIMEOUT
- Since:
- 2.8.5
 - Default:
- 10
 
- 
kraftboolean kraftUse KRaft instead of Zookeeper; default true.- Returns:
- whether to use KRaft.
- Since:
- 3.6
 - Default:
- true
 
 
-