From ca4696564bd2145e6a8fa70962122d4de8d3e406 Mon Sep 17 00:00:00 2001 From: Marco Ziccardi Date: Wed, 11 May 2016 12:19:19 +0200 Subject: [PATCH] Add options() method and project name to LocalPubsubHelper --- .../pubsub/testing/LocalPubsubHelper.java | 31 +++++++++++++++---- 1 file changed, 25 insertions(+), 6 deletions(-) diff --git a/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/testing/LocalPubsubHelper.java b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/testing/LocalPubsubHelper.java index afdba1c135ed..5a6cf6574211 100644 --- a/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/testing/LocalPubsubHelper.java +++ b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/testing/LocalPubsubHelper.java @@ -19,10 +19,9 @@ import com.google.api.gax.testing.DownloadableEmulatorRunner; import com.google.api.gax.testing.GCloudEmulatorRunner; import com.google.api.gax.testing.LocalServiceHelper; - -import io.grpc.ManagedChannel; -import io.grpc.netty.NegotiationType; -import io.grpc.netty.NettyChannelBuilder; +import com.google.cloud.AuthCredentials; +import com.google.cloud.RetryParams; +import com.google.cloud.pubsub.PubSubOptions; import java.io.IOException; import java.net.MalformedURLException; @@ -30,6 +29,11 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.List; +import java.util.UUID; + +import io.grpc.ManagedChannel; +import io.grpc.netty.NegotiationType; +import io.grpc.netty.NettyChannelBuilder; /** * A class that runs a Pubsub emulator instance for use in tests. @@ -38,11 +42,13 @@ public class LocalPubsubHelper { private final int port; private final LocalServiceHelper serviceHelper; + private final String projectId; // Local server settings private static final int DEFAULT_PORT = 8080; private static final String DEFAULT_HOST = "localhost"; private static final URL EMULATOR_URL; + private static final String PROJECT_ID_PREFIX = "test-project-"; // GCloud emulator settings private static final String GCLOUD_CMD_TEXT = "gcloud beta emulators pubsub start"; @@ -77,8 +83,8 @@ public LocalPubsubHelper() { DownloadableEmulatorRunner downloadRunner = new DownloadableEmulatorRunner(Arrays.asList(BIN_NAME, BIN_CMD_PORT_FLAG + port), EMULATOR_URL, MD5_CHECKSUM); - serviceHelper = - new LocalServiceHelper(Arrays.asList(gcloudRunner, downloadRunner), port); + serviceHelper = new LocalServiceHelper(Arrays.asList(gcloudRunner, downloadRunner), port); + projectId = PROJECT_ID_PREFIX + UUID.randomUUID().toString(); } /** @@ -121,4 +127,17 @@ public ManagedChannel createChannel() { .negotiationType(NegotiationType.PLAINTEXT) .build(); } + + /** + * Returns a {@link PubSubOptions} instance that sets the host to use the PubSub emulator on + * localhost. + */ + public PubSubOptions options() { + return PubSubOptions.builder() + .projectId(projectId) + .host("localhost:" + port) + .authCredentials(AuthCredentials.noAuth()) + .retryParams(RetryParams.noRetries()) + .build(); + } }