|
26 | 26 | import static org.testng.Assert.assertFalse;
|
27 | 27 | import static org.testng.Assert.assertEquals;
|
28 | 28 | import static org.testng.Assert.assertTrue;
|
| 29 | +import static org.testng.Assert.fail; |
29 | 30 |
|
30 | 31 | import com.google.common.collect.Lists;
|
31 | 32 | import java.util.ArrayList;
|
| 33 | +import java.util.Arrays; |
32 | 34 | import java.util.Collections;
|
33 | 35 | import java.util.HashMap;
|
34 | 36 | import java.util.List;
|
|
42 | 44 | import java.util.stream.Collectors;
|
43 | 45 | import java.util.stream.IntStream;
|
44 | 46 | import lombok.Cleanup;
|
| 47 | +import org.apache.pulsar.broker.BrokerTestUtil; |
45 | 48 | import org.apache.pulsar.client.admin.PulsarAdminException;
|
46 | 49 | import org.apache.pulsar.client.impl.ClientBuilderImpl;
|
47 | 50 | import org.apache.pulsar.client.impl.ConsumerImpl;
|
|
50 | 53 | import org.apache.pulsar.client.impl.PulsarClientImpl;
|
51 | 54 | import org.apache.pulsar.client.impl.conf.ClientConfigurationData;
|
52 | 55 | import org.apache.pulsar.common.naming.TopicName;
|
| 56 | +import org.apache.pulsar.common.util.FutureUtil; |
53 | 57 | import org.awaitility.Awaitility;
|
54 | 58 | import org.mockito.AdditionalAnswers;
|
55 | 59 | import org.mockito.Mockito;
|
@@ -372,6 +376,29 @@ public void testMultipleIOThreads() throws PulsarAdminException, PulsarClientExc
|
372 | 376 | assertTrue(consumer.isConnected());
|
373 | 377 | }
|
374 | 378 |
|
| 379 | + @Test |
| 380 | + public void testSameTopics() throws Exception { |
| 381 | + final String topic1 = BrokerTestUtil.newUniqueName("public/default/tp"); |
| 382 | + final String topic2 = "persistent://" + topic1; |
| 383 | + admin.topics().createNonPartitionedTopic(topic2); |
| 384 | + // Create consumer with two same topics. |
| 385 | + try { |
| 386 | + pulsarClient.newConsumer(Schema.INT32).topics(Arrays.asList(topic1, topic2)) |
| 387 | + .subscriptionName("s1").subscribe(); |
| 388 | + fail("Do not allow use two same topics."); |
| 389 | + } catch (Exception e) { |
| 390 | + if (e instanceof PulsarClientException && e.getCause() != null) { |
| 391 | + e = (Exception) e.getCause(); |
| 392 | + } |
| 393 | + Throwable unwrapEx = FutureUtil.unwrapCompletionException(e); |
| 394 | + assertTrue(unwrapEx instanceof IllegalArgumentException); |
| 395 | + assertTrue(e.getMessage().contains( "Subscription topics include duplicate items" |
| 396 | + + " or invalid names")); |
| 397 | + } |
| 398 | + // cleanup. |
| 399 | + admin.topics().delete(topic2); |
| 400 | + } |
| 401 | + |
375 | 402 | @Test(timeOut = 30000)
|
376 | 403 | public void testSubscriptionNotFound() throws PulsarAdminException, PulsarClientException {
|
377 | 404 | final var topic1 = newTopicName();
|
|
0 commit comments