Skip to content

Latest commit

 

History

History
163 lines (128 loc) · 6.47 KB

091-add-connect-to-test-container.md

File metadata and controls

163 lines (128 loc) · 6.47 KB

Support running Kafka Connect in test-container

The Strimzi test-container library allows running Kafka clusters in containers. This is useful for integration and system tests that require a cluster.

This proposes adding support for running Kafka Connect clusters.

Motivation

With test-container and test-clients, it's possible to build test environments for all Apache Kafka components but Kafka Connect.

Being able to easily start Kafka Connect clusters would be useful for testing client-side components, such as metrics-reporter and strimzi-kafka-oauth, with Kafka Connect.

Proposal

Create one new public class in the io.strimzi.test.container package of test-container called StrimziConnectCluster to represent a Kafka Connect cluster.

StrimziConnectCluster API

/**
 * A Kafka Connect cluster using the latest image from quay.io/strimzi/kafka with the given version.
 * Kafka Connect is started in distributed mode. Users must use the exposed REST API to start, stop and manage connectors.
 */
public class StrimziConnectCluster {

    /**
     * Get the workers of this Kafka Connect cluster.
     *
     * @return collection of GenericContainer containers
     */
    public Collection<GenericContainer> getWorkers() { }

    /**
     * Start the Kafka Connect cluster. 
     * This starts all the workers and waits for them to all be healthy and ready to be used.
     */
    public void start() { }

    /**
     * Stop the Kafka Connect cluster.
     */
    public void stop() { }

    /**
     * Return the REST API endpoint of one of the available workers.
     *
     * @return the REST API endpoint
     */
    public String getRestEndpoint() { }

    /**
     * Builder class for {@code StrimziConnectCluster}.
     * <p>
     * Use this builder to create instances of {@code StrimziConnectCluster}.
     * You must at least call {@link #withKafkaCluster(StrimziKafkaCluster)}, and 
     * {@link #withGroupId(String)} before calling {@link #build()}.
     * </p>
     */
    public static class StrimziConnectClusterBuilder {

        /**
         * Set the Kafka cluster the Kafka Connect cluster will use to.
         *
         * @param kafkaCluster the {@link StrimziKafkaCluster} instance
         * @return the current instance of {@code StrimziConnectClusterBuilder} for method chaining
         */
        public StrimziConnectClusterBuilder withKafkaCluster(StrimziKafkaCluster kafkaCluster) { }

        /**
         * Set the number of Kafka Connect workers in the cluster.
         * If not called, the cluster has a single worker.
         *
         * @param workersNum the number of Kafka Connect workers
         * @return the current instance of {@code StrimziConnectClusterBuilder} for method chaining
         */
        public StrimziConnectClusterBuilder withNumberOfWorkers(int workersNum) { }

        /**
         * Add additional Kafka Connect configuration parameters.
         * These configurations are applied to all workers in the cluster.
         *
         * @param additionalConnectConfiguration a map of additional Kafka Connect configuration options
         * @return the current instance of {@code StrimziConnectClusterBuilder} for method chaining
         */
        public StrimziConnectClusterBuilder withAdditionalConnectConfiguration(Map<String, String> additionalConnectConfiguration) { }

        /**
         * Specify the Kafka version to be used for the Connect workers in the cluster.
         * If not called, the latest Kafka version available from {@link KafkaVersionService} will be used.
         *
         * @param kafkaVersion the desired Kafka version for the Connect cluster
         * @return the current instance of {@code StrimziConnectClusterBuilder} for method chaining
         */
        public StrimziConnectClusterBuilder withKafkaVersion(String kafkaVersion) { }

        /**
         * Disable the FileStreams connectors.
         * If not called, the FileSteams connectors are added to plugin.path.
         *
         * @return the current instance of {@code StrimziConnectClusterBuilder} for method chaining
         */
        public StrimziConnectClusterBuilder withoutFileConnectors() { }

        /**
         * Specify the group.id of the Connect cluster.
         *
         * @param groupId the group id
         * @return the current instance of {@code StrimziConnectClusterBuilder} for method chaining
         */
        public StrimziConnectClusterBuilder withGroupId(String groupId) { }

        /**
         * Build and return a {@code StrimziConnectCluster} instance based on the provided configurations.
         *
         * @return a new instance of {@code StrimziConnectCluster}
         */
        public StrimziConnectCluster build() { }
    }
}

StrimziKafkaCluster

At the moment the bootstrap servers returned by StrimziKafkaCluster.getBootstrapServers() are meant to be used by applications running the host and they can't be used by other containers. To address this issue, this also proposes adding a new method to StrimziKafkaCluster:

/**
 * Get the bootstrap servers that containers on the same network should use to connect.
 *
 * @return a comma separated list of Kafka bootstrap servers
 */
public String getNetworkBootstrapServers() { }

This method will call getNetworkBootstrapServers() on each broker (StrimziKafkaContainer) in the cluster and concatenate the results (comma separated).

StrimziKafkaContainer

At the moment the bootstrap servers returned by StrimziKafkaContainer.getBootstrapServers() are meant to be used by applications running the host and they can't be used by other containers. To address this issue, this also proposes adding a new method to StrimziKafkaContainer:

/**
 * Get the bootstrap servers that containers on the same network should use to connect.
 *
 * @return a comma separated list of Kafka bootstrap servers
 */
public String getNetworkBootstrapServers() { }

Affected projects

This proposal affects the Strimzi test-container project only. The plan is to use this new feature in metrics-reporter.

Backwards compatibility

There is no impact on backwards compatibility.

Rejected alternatives

There are currently no rejected alternatives.