This commit updates URLs to prefer the https protocol. Redirects are not followed to avoid accidentally expanding intentionally shortened URLs (i.e. if using a URL shortener). # Fixed URLs ## Fixed Success These URLs were switched to an https URL with a 2xx status. While the status was successful, your review is still recommended. * [ ] http://www.apache.org/licenses/ with 1 occurrences migrated to: https://www.apache.org/licenses/ ([https](https://www.apache.org/licenses/) result 200). * [ ] http://www.apache.org/licenses/LICENSE-2.0 with 62 occurrences migrated to: https://www.apache.org/licenses/LICENSE-2.0 ([https](https://www.apache.org/licenses/LICENSE-2.0) result 200).
113 lines
5.2 KiB
Java
113 lines
5.2 KiB
Java
/*
|
|
* Copyright 2015-2016 the original author or authors.
|
|
*
|
|
* Licensed 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
|
|
*
|
|
* https://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 multibinder;
|
|
|
|
import org.hamcrest.CoreMatchers;
|
|
import org.hamcrest.Matchers;
|
|
import org.junit.Assert;
|
|
import org.junit.BeforeClass;
|
|
import org.junit.ClassRule;
|
|
import org.junit.Test;
|
|
import org.junit.runner.RunWith;
|
|
import org.springframework.beans.DirectFieldAccessor;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.boot.test.context.SpringBootTest;
|
|
import org.springframework.cloud.stream.binder.Binder;
|
|
import org.springframework.cloud.stream.binder.BinderFactory;
|
|
import org.springframework.cloud.stream.binder.ExtendedConsumerProperties;
|
|
import org.springframework.cloud.stream.binder.ExtendedProducerProperties;
|
|
import org.springframework.cloud.stream.binder.kafka.KafkaMessageChannelBinder;
|
|
import org.springframework.cloud.stream.binder.kafka.properties.KafkaBinderConfigurationProperties;
|
|
import org.springframework.cloud.stream.binder.kafka.properties.KafkaConsumerProperties;
|
|
import org.springframework.cloud.stream.binder.kafka.properties.KafkaProducerProperties;
|
|
import org.springframework.integration.channel.DirectChannel;
|
|
import org.springframework.integration.channel.QueueChannel;
|
|
import org.springframework.kafka.test.rule.KafkaEmbedded;
|
|
import org.springframework.messaging.Message;
|
|
import org.springframework.messaging.MessageChannel;
|
|
import org.springframework.messaging.support.MessageBuilder;
|
|
import org.springframework.test.annotation.DirtiesContext;
|
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
import org.springframework.test.context.web.WebAppConfiguration;
|
|
|
|
import java.util.UUID;
|
|
|
|
import static org.hamcrest.Matchers.arrayWithSize;
|
|
import static org.hamcrest.Matchers.equalTo;
|
|
|
|
@RunWith(SpringJUnit4ClassRunner.class)
|
|
@SpringBootTest(classes = MultibinderApplication.class)
|
|
@WebAppConfiguration
|
|
@DirtiesContext
|
|
public class TwoKafkaBindersApplicationTest {
|
|
|
|
@ClassRule
|
|
public static KafkaEmbedded kafkaTestSupport1 = new KafkaEmbedded(1);
|
|
|
|
@ClassRule
|
|
public static KafkaEmbedded kafkaTestSupport2 = new KafkaEmbedded(1);
|
|
|
|
|
|
@BeforeClass
|
|
public static void setupEnvironment() {
|
|
System.setProperty("kafkaBroker1", kafkaTestSupport1.getBrokersAsString());
|
|
System.setProperty("zk1", kafkaTestSupport1.getZookeeperConnectionString());
|
|
System.setProperty("kafkaBroker2", kafkaTestSupport2.getBrokersAsString());
|
|
System.setProperty("zk2", kafkaTestSupport2.getZookeeperConnectionString());
|
|
}
|
|
|
|
@Autowired
|
|
private BinderFactory binderFactory;
|
|
|
|
@Test
|
|
public void contextLoads() {
|
|
Binder<MessageChannel, ?, ?> binder1 = binderFactory.getBinder("kafka1", MessageChannel.class);
|
|
KafkaMessageChannelBinder kafka1 = (KafkaMessageChannelBinder) binder1;
|
|
DirectFieldAccessor directFieldAccessor1 = new DirectFieldAccessor(kafka1);
|
|
KafkaBinderConfigurationProperties configuration1 =
|
|
(KafkaBinderConfigurationProperties) directFieldAccessor1.getPropertyValue("configurationProperties");
|
|
Assert.assertThat(configuration1.getBrokers(), arrayWithSize(1));
|
|
Assert.assertThat(configuration1.getBrokers()[0], equalTo(kafkaTestSupport1.getBrokersAsString()));
|
|
|
|
Binder<MessageChannel, ?, ?> binder2 = binderFactory.getBinder("kafka2", MessageChannel.class);
|
|
KafkaMessageChannelBinder kafka2 = (KafkaMessageChannelBinder) binder2;
|
|
DirectFieldAccessor directFieldAccessor2 = new DirectFieldAccessor(kafka2);
|
|
KafkaBinderConfigurationProperties configuration2 =
|
|
(KafkaBinderConfigurationProperties) directFieldAccessor2.getPropertyValue("configurationProperties");
|
|
Assert.assertThat(configuration2.getBrokers(), arrayWithSize(1));
|
|
Assert.assertThat(configuration2.getBrokers()[0], equalTo(kafkaTestSupport2.getBrokersAsString()));
|
|
}
|
|
|
|
@Test
|
|
public void messagingWorks() {
|
|
DirectChannel dataProducer = new DirectChannel();
|
|
((KafkaMessageChannelBinder) binderFactory.getBinder("kafka1", MessageChannel.class))
|
|
.bindProducer("dataIn", dataProducer, new ExtendedProducerProperties<>(new KafkaProducerProperties()));
|
|
|
|
QueueChannel dataConsumer = new QueueChannel();
|
|
((KafkaMessageChannelBinder) binderFactory.getBinder("kafka2", MessageChannel.class)).bindConsumer("dataOut", UUID.randomUUID().toString(),
|
|
dataConsumer, new ExtendedConsumerProperties<>(new KafkaConsumerProperties()));
|
|
|
|
String testPayload = "testFoo" + UUID.randomUUID().toString();
|
|
dataProducer.send(MessageBuilder.withPayload(testPayload).build());
|
|
Message<?> receive = dataConsumer.receive(60_000);
|
|
Assert.assertThat(receive, Matchers.notNullValue());
|
|
Assert.assertThat(receive.getPayload(), CoreMatchers.equalTo(testPayload));
|
|
}
|
|
|
|
}
|