/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.camel.component.kafka; import java.util.HashMap; import java.util.Map; import java.util.Properties; import org.apache.camel.CamelContext; import org.apache.kafka.clients.CommonClientConfigs; import org.apache.kafka.clients.producer.ProducerConfig; import org.apache.kafka.common.config.SaslConfigs; import org.apache.kafka.common.config.SslConfigs; import org.junit.Test; import org.mockito.Mockito; import static org.junit.Assert.assertEquals; public class KafkaComponentTest { private CamelContext context = Mockito.mock(CamelContext.class); @Test public void testPropertiesSet() throws Exception { String uri = "kafka:mytopic?brokers=broker1:12345,broker2:12566&partitioner=com.class.Party"; KafkaEndpoint endpoint = (KafkaEndpoint) new KafkaComponent(context).createEndpoint(uri); assertEquals("broker1:12345,broker2:12566", endpoint.getConfiguration().getBrokers()); assertEquals("mytopic", endpoint.getConfiguration().getTopic()); assertEquals("com.class.Party", endpoint.getConfiguration().getPartitioner()); } @Test public void testBrokersOnComponent() throws Exception { KafkaComponent kafka = new KafkaComponent(context); kafka.setBrokers("broker1:12345,broker2:12566"); String uri = "kafka:mytopic?partitioner=com.class.Party"; KafkaEndpoint endpoint = (KafkaEndpoint) kafka.createEndpoint(uri); assertEquals("broker1:12345,broker2:12566", endpoint.getConfiguration().getBrokers()); assertEquals("broker1:12345,broker2:12566", endpoint.getComponent().getBrokers()); assertEquals("mytopic", endpoint.getConfiguration().getTopic()); assertEquals("com.class.Party", endpoint.getConfiguration().getPartitioner()); } @Test public void testAllProducerConfigProperty() throws Exception { Map<String, Object> params = new HashMap<String, Object>(); setProducerProperty(params); String uri = "kafka:mytopic?brokers=dev1:12345,dev2:12566"; String remaining = "mytopic"; KafkaEndpoint endpoint = new KafkaComponent(context).createEndpoint(uri, remaining, params); assertEquals("mytopic", endpoint.getConfiguration().getTopic()); assertEquals("1", endpoint.getConfiguration().getRequestRequiredAcks()); assertEquals(new Integer(1), endpoint.getConfiguration().getBufferMemorySize()); assertEquals(new Integer(10), endpoint.getConfiguration().getProducerBatchSize()); assertEquals(new Integer(12), endpoint.getConfiguration().getConnectionMaxIdleMs()); assertEquals(new Integer(1), endpoint.getConfiguration().getMaxBlockMs()); assertEquals(new Integer(1), endpoint.getConfiguration().getBufferMemorySize()); assertEquals("testing", endpoint.getConfiguration().getClientId()); assertEquals("none", endpoint.getConfiguration().getCompressionCodec()); assertEquals(new Integer(1), endpoint.getConfiguration().getLingerMs()); assertEquals(new Integer(100), endpoint.getConfiguration().getMaxRequestSize()); assertEquals(100, endpoint.getConfiguration().getRequestTimeoutMs().intValue()); assertEquals(new Integer(1029), endpoint.getConfiguration().getMetadataMaxAgeMs()); assertEquals(new Integer(23), endpoint.getConfiguration().getReceiveBufferBytes()); assertEquals(new Integer(234), endpoint.getConfiguration().getReconnectBackoffMs()); assertEquals(new Integer(0), endpoint.getConfiguration().getRetries()); assertEquals(3782, endpoint.getConfiguration().getRetryBackoffMs().intValue()); assertEquals(765, endpoint.getConfiguration().getSendBufferBytes().intValue()); assertEquals(new Integer(1), endpoint.getConfiguration().getMaxInFlightRequest()); assertEquals("org.apache.camel.reporters.TestReport,org.apache.camel.reporters.SampleReport", endpoint.getConfiguration().getMetricReporters()); assertEquals(new Integer(3), endpoint.getConfiguration().getNoOfMetricsSample()); assertEquals(new Integer(12344), endpoint.getConfiguration().getMetricsSampleWindowMs()); assertEquals(KafkaConstants.KAFKA_DEFAULT_SERIALIZER, endpoint.getConfiguration().getSerializerClass()); assertEquals(KafkaConstants.KAFKA_DEFAULT_SERIALIZER, endpoint.getConfiguration().getKeySerializerClass()); assertEquals("testing", endpoint.getConfiguration().getSslKeyPassword()); assertEquals("/abc", endpoint.getConfiguration().getSslKeystoreLocation()); assertEquals("testing", endpoint.getConfiguration().getSslKeystorePassword()); assertEquals("/abc", endpoint.getConfiguration().getSslTruststoreLocation()); assertEquals("testing", endpoint.getConfiguration().getSslTruststorePassword()); assertEquals("test", endpoint.getConfiguration().getSaslKerberosServiceName()); assertEquals("PLAINTEXT", endpoint.getConfiguration().getSecurityProtocol()); assertEquals("TLSv1.2", endpoint.getConfiguration().getSslEnabledProtocols()); assertEquals("JKS", endpoint.getConfiguration().getSslKeystoreType()); assertEquals("TLS", endpoint.getConfiguration().getSslProtocol()); assertEquals("test", endpoint.getConfiguration().getSslProvider()); assertEquals("JKS", endpoint.getConfiguration().getSslTruststoreType()); assertEquals("/usr/bin/kinit", endpoint.getConfiguration().getKerberosInitCmd()); assertEquals(new Integer(60000), endpoint.getConfiguration().getKerberosBeforeReloginMinTime()); assertEquals(new Double(0.05), endpoint.getConfiguration().getKerberosRenewJitter()); assertEquals(new Double(0.8), endpoint.getConfiguration().getKerberosRenewWindowFactor()); assertEquals("MAC", endpoint.getConfiguration().getSslCipherSuites()); assertEquals("test", endpoint.getConfiguration().getSslEndpointAlgorithm()); assertEquals("SunX509", endpoint.getConfiguration().getSslKeymanagerAlgorithm()); assertEquals("PKIX", endpoint.getConfiguration().getSslTrustmanagerAlgorithm()); } @Test public void testAllProducerKeys() throws Exception { Map<String, Object> params = new HashMap<String, Object>(); String uri = "kafka:mytopic?brokers=dev1:12345,dev2:12566"; String remaining = "mytopic"; KafkaEndpoint endpoint = new KafkaComponent(context).createEndpoint(uri, remaining, params); assertEquals(endpoint.getConfiguration().createProducerProperties().keySet(), getProducerKeys().keySet()); } private Properties getProducerKeys() { Properties props = new Properties(); props.put(ProducerConfig.ACKS_CONFIG, "1"); props.put(ProducerConfig.BUFFER_MEMORY_CONFIG, "33554432"); props.put(ProducerConfig.COMPRESSION_TYPE_CONFIG, "none"); props.put(ProducerConfig.RETRIES_CONFIG, "0"); props.put(ProducerConfig.BATCH_SIZE_CONFIG, "16384"); props.put(ProducerConfig.CONNECTIONS_MAX_IDLE_MS_CONFIG, "540000"); props.put(ProducerConfig.LINGER_MS_CONFIG, "0"); props.put(ProducerConfig.MAX_BLOCK_MS_CONFIG, "60000"); props.put(ProducerConfig.MAX_REQUEST_SIZE_CONFIG, "1048576"); props.put(ProducerConfig.PARTITIONER_CLASS_CONFIG, KafkaConstants.KAFKA_DEFAULT_PARTITIONER); props.put(ProducerConfig.RECEIVE_BUFFER_CONFIG, "32768"); props.put(ProducerConfig.REQUEST_TIMEOUT_MS_CONFIG, "30000"); props.put(ProducerConfig.SEND_BUFFER_CONFIG, "131072"); props.put(ProducerConfig.MAX_IN_FLIGHT_REQUESTS_PER_CONNECTION, "5"); props.put(ProducerConfig.METADATA_MAX_AGE_CONFIG, "300000"); props.put(ProducerConfig.METRICS_NUM_SAMPLES_CONFIG, "2"); props.put(ProducerConfig.METRICS_SAMPLE_WINDOW_MS_CONFIG, "30000"); props.put(ProducerConfig.RECONNECT_BACKOFF_MS_CONFIG, "50"); props.put(ProducerConfig.RETRY_BACKOFF_MS_CONFIG, "100"); props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, KafkaConstants.KAFKA_DEFAULT_SERIALIZER); props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, KafkaConstants.KAFKA_DEFAULT_SERIALIZER); props.put(CommonClientConfigs.SECURITY_PROTOCOL_CONFIG, "PLAINTEXT"); props.put(SslConfigs.SSL_ENABLED_PROTOCOLS_CONFIG, "TLSv1.2, TLSv1.1, TLSv1"); props.put(SslConfigs.SSL_KEYSTORE_TYPE_CONFIG, "JKS"); props.put(SslConfigs.SSL_PROTOCOL_CONFIG, "TLS"); props.put(SslConfigs.SSL_TRUSTSTORE_TYPE_CONFIG, "JKS"); props.put(SaslConfigs.SASL_KERBEROS_KINIT_CMD, "/usr/bin/kinit"); props.put(SaslConfigs.SASL_KERBEROS_MIN_TIME_BEFORE_RELOGIN, "60000"); props.put(SaslConfigs.SASL_KERBEROS_TICKET_RENEW_JITTER, "0.05"); props.put(SaslConfigs.SASL_KERBEROS_TICKET_RENEW_WINDOW_FACTOR, "0.8"); props.put(SaslConfigs.SASL_MECHANISM, "PLAIN"); props.put(SslConfigs.SSL_KEYMANAGER_ALGORITHM_CONFIG, "SunX509"); props.put(SslConfigs.SSL_TRUSTMANAGER_ALGORITHM_CONFIG, "PKIX"); return props; } private void setProducerProperty(Map<String, Object> params) { params.put("requestRequiredAcks", "1"); params.put("bufferMemorySize", 1); params.put("compressionCodec", "none"); params.put("retries", 0); params.put("producerBatchSize", 10); params.put("connectionMaxIdleMs", 12); params.put("lingerMs", 1); params.put("maxBlockMs", 1); params.put("maxRequestSize", 100); params.put("receiveBufferBytes", 23); params.put("requestTimeoutMs", 100); params.put("sendBufferBytes", 765); params.put("timeoutMs", 2045); params.put("blockOnBufferFull", false); params.put("maxInFlightRequest", 1); params.put("metadataFetchTimeoutMs", 9043); params.put("metadataMaxAgeMs", 1029); params.put("reconnectBackoffMs", 234); params.put("retryBackoffMs", 3782); params.put("noOfMetricsSample", 3); params.put("metricReporters", "org.apache.camel.reporters.TestReport,org.apache.camel.reporters.SampleReport"); params.put("metricsSampleWindowMs", 12344); params.put("clientId", "testing"); params.put("sslKeyPassword", "testing"); params.put("sslKeystoreLocation", "/abc"); params.put("sslKeystorePassword", "testing"); params.put("sslTruststoreLocation", "/abc"); params.put("sslTruststorePassword", "testing"); params.put("saslKerberosServiceName", "test"); params.put("saslMechanism", "PLAIN"); params.put("securityProtocol", "PLAINTEXT"); params.put("sslEnabledProtocols", "TLSv1.2"); params.put("sslKeystoreType", "JKS"); params.put("sslProtocol", "TLS"); params.put("sslProvider", "test"); params.put("sslTruststoreType", "JKS"); params.put("kerberosInitCmd", "/usr/bin/kinit"); params.put("kerberosBeforeReloginMinTime", 60000); params.put("kerberosRenewJitter", 0.05); params.put("kerberosRenewWindowFactor", 0.8); params.put("sslCipherSuites", "MAC"); params.put("sslEndpointAlgorithm", "test"); params.put("sslKeymanagerAlgorithm", "SunX509"); params.put("sslTrustmanagerAlgorithm", "PKIX"); } }