|
21 | 21 | import static org.junit.Assert.assertNull; |
22 | 22 | import static org.junit.Assert.assertTrue; |
23 | 23 |
|
| 24 | +import com.google.api.gax.core.RpcFutureCallback; |
| 25 | +import com.google.api.gax.core.SettableRpcFuture; |
24 | 26 | import com.google.cloud.Identity; |
25 | 27 | import com.google.cloud.Page; |
26 | 28 | import com.google.cloud.Policy; |
|
33 | 35 | import com.google.cloud.pubsub.deprecated.SubscriptionInfo; |
34 | 36 | import com.google.cloud.pubsub.deprecated.Topic; |
35 | 37 | import com.google.cloud.pubsub.deprecated.TopicInfo; |
| 38 | +import com.google.cloud.pubsub.spi.v1.Publisher; |
| 39 | +import com.google.cloud.pubsub.spi.v1.PublisherClient; |
| 40 | +import com.google.cloud.pubsub.spi.v1.SubscriberClient; |
36 | 41 | import com.google.common.collect.Iterators; |
37 | 42 | import com.google.common.collect.Sets; |
| 43 | +import com.google.common.util.concurrent.MoreExecutors; |
| 44 | +import com.google.pubsub.v1.PubsubMessage; |
| 45 | +import com.google.pubsub.v1.PushConfig; |
| 46 | +import com.google.pubsub.v1.SubscriptionName; |
| 47 | +import com.google.pubsub.v1.TopicName; |
38 | 48 | import java.util.HashSet; |
39 | 49 | import java.util.Iterator; |
40 | 50 | import java.util.List; |
41 | 51 | import java.util.Set; |
42 | 52 | import java.util.UUID; |
| 53 | +import java.util.concurrent.ArrayBlockingQueue; |
| 54 | +import java.util.concurrent.BlockingQueue; |
43 | 55 | import java.util.concurrent.ExecutionException; |
| 56 | +import java.util.concurrent.TimeUnit; |
44 | 57 | import org.junit.AfterClass; |
45 | 58 | import org.junit.BeforeClass; |
46 | 59 | import org.junit.Rule; |
@@ -264,4 +277,79 @@ public void testTopicPolicyAsync() throws ExecutionException, InterruptedExcepti |
264 | 277 | topic.delete(); |
265 | 278 | subscription.delete(); |
266 | 279 | } |
| 280 | + |
| 281 | + @Test |
| 282 | + public void testPublisherSubscriber() throws Exception { |
| 283 | + TopicName topicName = |
| 284 | + TopicName.create(pubsub.getOptions().getProjectId(), formatForTest("test-topic")); |
| 285 | + SubscriptionName subscriptionName = |
| 286 | + SubscriptionName.create( |
| 287 | + pubsub.getOptions().getProjectId(), formatForTest("test-subscription")); |
| 288 | + try (PublisherClient publisherClient = PublisherClient.create(); |
| 289 | + SubscriberClient subscriberClient = SubscriberClient.create()) { |
| 290 | + publisherClient.createTopic(topicName); |
| 291 | + subscriberClient.createSubscription( |
| 292 | + subscriptionName, topicName, PushConfig.getDefaultInstance(), 0); |
| 293 | + |
| 294 | + testPublisherSubscriberHelper(topicName, subscriptionName); |
| 295 | + |
| 296 | + subscriberClient.deleteSubscription(subscriptionName); |
| 297 | + publisherClient.deleteTopic(topicName); |
| 298 | + } |
| 299 | + } |
| 300 | + |
| 301 | + private void testPublisherSubscriberHelper( |
| 302 | + TopicName topicName, SubscriptionName subscriptionName) throws Exception { |
| 303 | + String messageToPublish = "my-message"; |
| 304 | + |
| 305 | + Publisher publisher = null; |
| 306 | + try { |
| 307 | + publisher = Publisher.newBuilder(topicName).build(); |
| 308 | + PublisherSnippets snippets = new PublisherSnippets(publisher); |
| 309 | + final SettableRpcFuture<Void> done = new SettableRpcFuture<>(); |
| 310 | + snippets |
| 311 | + .publish(messageToPublish) |
| 312 | + .addCallback( |
| 313 | + new RpcFutureCallback<String>() { |
| 314 | + public void onSuccess(String messageId) { |
| 315 | + done.set(null); |
| 316 | + } |
| 317 | + |
| 318 | + public void onFailure(Throwable t) { |
| 319 | + done.setException(t); |
| 320 | + } |
| 321 | + }); |
| 322 | + done.get(); |
| 323 | + } finally { |
| 324 | + if (publisher != null) { |
| 325 | + publisher.shutdown(); |
| 326 | + } |
| 327 | + } |
| 328 | + |
| 329 | + final BlockingQueue<PubsubMessage> queue = new ArrayBlockingQueue<>(1); |
| 330 | + final SettableRpcFuture<Void> done = new SettableRpcFuture<>(); |
| 331 | + final SettableRpcFuture<PubsubMessage> received = new SettableRpcFuture<>(); |
| 332 | + SubscriberSnippets snippets = |
| 333 | + new SubscriberSnippets( |
| 334 | + subscriptionName, |
| 335 | + new MessageReceiverSnippets(queue).messageReceiver(), |
| 336 | + done, |
| 337 | + MoreExecutors.directExecutor()); |
| 338 | + new Thread(new Runnable() { |
| 339 | + @Override |
| 340 | + public void run() { |
| 341 | + try { |
| 342 | + received.set(queue.poll(10, TimeUnit.MINUTES)); |
| 343 | + } catch (InterruptedException e) { |
| 344 | + received.set(null); |
| 345 | + } |
| 346 | + done.set(null); // signal the subscriber to clean up |
| 347 | + } |
| 348 | + }).start(); |
| 349 | + snippets.startAndWait(); // blocks until done is set |
| 350 | + |
| 351 | + PubsubMessage message = received.get(); |
| 352 | + assertNotNull(message); |
| 353 | + assertEquals(message.getData().toStringUtf8(), messageToPublish); |
| 354 | + } |
267 | 355 | } |
0 commit comments