diff --git a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminClient.java b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminClient.java
index 48eb1ca1aa54..88dbfd23e7bb 100644
--- a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminClient.java
+++ b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminClient.java
@@ -130,6 +130,21 @@
* AccessApprovalAdminClient.create(accessApprovalAdminSettings);
* }
*
+ * To use REST (HTTP1.1/JSON) transport (instead of gRPC) for sending and receiving requests over
+ * the wire:
+ *
+ *
{@code
+ * // This snippet has been automatically generated for illustrative purposes only.
+ * // It may require modifications to work in your environment.
+ * AccessApprovalAdminSettings accessApprovalAdminSettings =
+ * AccessApprovalAdminSettings.newBuilder()
+ * .setTransportChannelProvider(
+ * AccessApprovalAdminSettings.defaultHttpJsonTransportProviderBuilder().build())
+ * .build();
+ * AccessApprovalAdminClient accessApprovalAdminClient =
+ * AccessApprovalAdminClient.create(accessApprovalAdminSettings);
+ * }
+ *
* Please refer to the GitHub repository's samples for more quickstart code snippets.
*/
@Generated("by gapic-generator-java")
diff --git a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminSettings.java b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminSettings.java
index 64a5c986c79a..8bd2bb08bfb7 100644
--- a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminSettings.java
+++ b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminSettings.java
@@ -23,6 +23,7 @@
import com.google.api.gax.core.GoogleCredentialsProvider;
import com.google.api.gax.core.InstantiatingExecutorProvider;
import com.google.api.gax.grpc.InstantiatingGrpcChannelProvider;
+import com.google.api.gax.httpjson.InstantiatingHttpJsonChannelProvider;
import com.google.api.gax.rpc.ApiClientHeaderProvider;
import com.google.api.gax.rpc.ClientContext;
import com.google.api.gax.rpc.ClientSettings;
@@ -157,11 +158,18 @@ public static GoogleCredentialsProvider.Builder defaultCredentialsProviderBuilde
return AccessApprovalStubSettings.defaultCredentialsProviderBuilder();
}
- /** Returns a builder for the default ChannelProvider for this service. */
+ /** Returns a builder for the default gRPC ChannelProvider for this service. */
public static InstantiatingGrpcChannelProvider.Builder defaultGrpcTransportProviderBuilder() {
return AccessApprovalStubSettings.defaultGrpcTransportProviderBuilder();
}
+ /** Returns a builder for the default REST ChannelProvider for this service. */
+ @BetaApi
+ public static InstantiatingHttpJsonChannelProvider.Builder
+ defaultHttpJsonTransportProviderBuilder() {
+ return AccessApprovalStubSettings.defaultHttpJsonTransportProviderBuilder();
+ }
+
public static TransportChannelProvider defaultTransportChannelProvider() {
return AccessApprovalStubSettings.defaultTransportChannelProvider();
}
@@ -171,11 +179,17 @@ public static ApiClientHeaderProvider.Builder defaultApiClientHeaderProviderBuil
return AccessApprovalStubSettings.defaultApiClientHeaderProviderBuilder();
}
- /** Returns a new builder for this class. */
+ /** Returns a new gRPC builder for this class. */
public static Builder newBuilder() {
return Builder.createDefault();
}
+ /** Returns a new REST builder for this class. */
+ @BetaApi
+ public static Builder newHttpJsonBuilder() {
+ return Builder.createHttpJsonDefault();
+ }
+
/** Returns a new builder for this class. */
public static Builder newBuilder(ClientContext clientContext) {
return new Builder(clientContext);
@@ -213,6 +227,11 @@ private static Builder createDefault() {
return new Builder(AccessApprovalStubSettings.newBuilder());
}
+ @BetaApi
+ private static Builder createHttpJsonDefault() {
+ return new Builder(AccessApprovalStubSettings.newHttpJsonBuilder());
+ }
+
public AccessApprovalStubSettings.Builder getStubSettingsBuilder() {
return ((AccessApprovalStubSettings.Builder) getStubSettings());
}
diff --git a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/AccessApprovalStubSettings.java b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/AccessApprovalStubSettings.java
index 101fabeb5bd6..c88f92a815c1 100644
--- a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/AccessApprovalStubSettings.java
+++ b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/AccessApprovalStubSettings.java
@@ -27,6 +27,9 @@
import com.google.api.gax.grpc.GaxGrpcProperties;
import com.google.api.gax.grpc.GrpcTransportChannel;
import com.google.api.gax.grpc.InstantiatingGrpcChannelProvider;
+import com.google.api.gax.httpjson.GaxHttpJsonProperties;
+import com.google.api.gax.httpjson.HttpJsonTransportChannel;
+import com.google.api.gax.httpjson.InstantiatingHttpJsonChannelProvider;
import com.google.api.gax.retrying.RetrySettings;
import com.google.api.gax.rpc.ApiCallContext;
import com.google.api.gax.rpc.ApiClientHeaderProvider;
@@ -256,6 +259,11 @@ public AccessApprovalStub createStub() throws IOException {
.equals(GrpcTransportChannel.getGrpcTransportName())) {
return GrpcAccessApprovalStub.create(this);
}
+ if (getTransportChannelProvider()
+ .getTransportName()
+ .equals(HttpJsonTransportChannel.getHttpJsonTransportName())) {
+ return HttpJsonAccessApprovalStub.create(this);
+ }
throw new UnsupportedOperationException(
String.format(
"Transport not supported: %s", getTransportChannelProvider().getTransportName()));
@@ -288,18 +296,25 @@ public static GoogleCredentialsProvider.Builder defaultCredentialsProviderBuilde
.setUseJwtAccessWithScope(true);
}
- /** Returns a builder for the default ChannelProvider for this service. */
+ /** Returns a builder for the default gRPC ChannelProvider for this service. */
public static InstantiatingGrpcChannelProvider.Builder defaultGrpcTransportProviderBuilder() {
return InstantiatingGrpcChannelProvider.newBuilder()
.setMaxInboundMessageSize(Integer.MAX_VALUE);
}
+ /** Returns a builder for the default REST ChannelProvider for this service. */
+ @BetaApi
+ public static InstantiatingHttpJsonChannelProvider.Builder
+ defaultHttpJsonTransportProviderBuilder() {
+ return InstantiatingHttpJsonChannelProvider.newBuilder();
+ }
+
public static TransportChannelProvider defaultTransportChannelProvider() {
return defaultGrpcTransportProviderBuilder().build();
}
@BetaApi("The surface for customizing headers is not stable yet and may change in the future.")
- public static ApiClientHeaderProvider.Builder defaultApiClientHeaderProviderBuilder() {
+ public static ApiClientHeaderProvider.Builder defaultGrpcApiClientHeaderProviderBuilder() {
return ApiClientHeaderProvider.newBuilder()
.setGeneratedLibToken(
"gapic", GaxProperties.getLibraryVersion(AccessApprovalStubSettings.class))
@@ -307,11 +322,30 @@ public static ApiClientHeaderProvider.Builder defaultApiClientHeaderProviderBuil
GaxGrpcProperties.getGrpcTokenName(), GaxGrpcProperties.getGrpcVersion());
}
- /** Returns a new builder for this class. */
+ @BetaApi("The surface for customizing headers is not stable yet and may change in the future.")
+ public static ApiClientHeaderProvider.Builder defaultHttpJsonApiClientHeaderProviderBuilder() {
+ return ApiClientHeaderProvider.newBuilder()
+ .setGeneratedLibToken(
+ "gapic", GaxProperties.getLibraryVersion(AccessApprovalStubSettings.class))
+ .setTransportToken(
+ GaxHttpJsonProperties.getHttpJsonTokenName(),
+ GaxHttpJsonProperties.getHttpJsonVersion());
+ }
+
+ public static ApiClientHeaderProvider.Builder defaultApiClientHeaderProviderBuilder() {
+ return AccessApprovalStubSettings.defaultGrpcApiClientHeaderProviderBuilder();
+ }
+
+ /** Returns a new gRPC builder for this class. */
public static Builder newBuilder() {
return Builder.createDefault();
}
+ /** Returns a new REST builder for this class. */
+ public static Builder newHttpJsonBuilder() {
+ return Builder.createHttpJsonDefault();
+ }
+
/** Returns a new builder for this class. */
public static Builder newBuilder(ClientContext clientContext) {
return new Builder(clientContext);
@@ -484,6 +518,19 @@ private static Builder createDefault() {
return initDefaults(builder);
}
+ private static Builder createHttpJsonDefault() {
+ Builder builder = new Builder(((ClientContext) null));
+
+ builder.setTransportChannelProvider(defaultHttpJsonTransportProviderBuilder().build());
+ builder.setCredentialsProvider(defaultCredentialsProviderBuilder().build());
+ builder.setInternalHeaderProvider(defaultHttpJsonApiClientHeaderProviderBuilder().build());
+ builder.setEndpoint(getDefaultEndpoint());
+ builder.setMtlsEndpoint(getDefaultMtlsEndpoint());
+ builder.setSwitchToMtlsEndpointAllowed(true);
+
+ return initDefaults(builder);
+ }
+
private static Builder initDefaults(Builder builder) {
builder
.listApprovalRequestsSettings()
diff --git a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/HttpJsonAccessApprovalCallableFactory.java b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/HttpJsonAccessApprovalCallableFactory.java
new file mode 100644
index 000000000000..e0ab85278cff
--- /dev/null
+++ b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/HttpJsonAccessApprovalCallableFactory.java
@@ -0,0 +1,105 @@
+/*
+ * Copyright 2022 Google LLC
+ *
+ * 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 com.google.cloud.accessapproval.v1.stub;
+
+import com.google.api.core.BetaApi;
+import com.google.api.gax.httpjson.HttpJsonCallSettings;
+import com.google.api.gax.httpjson.HttpJsonCallableFactory;
+import com.google.api.gax.httpjson.HttpJsonOperationSnapshotCallable;
+import com.google.api.gax.httpjson.HttpJsonStubCallableFactory;
+import com.google.api.gax.httpjson.longrunning.stub.OperationsStub;
+import com.google.api.gax.rpc.BatchingCallSettings;
+import com.google.api.gax.rpc.ClientContext;
+import com.google.api.gax.rpc.OperationCallSettings;
+import com.google.api.gax.rpc.OperationCallable;
+import com.google.api.gax.rpc.PagedCallSettings;
+import com.google.api.gax.rpc.ServerStreamingCallSettings;
+import com.google.api.gax.rpc.ServerStreamingCallable;
+import com.google.api.gax.rpc.UnaryCallSettings;
+import com.google.api.gax.rpc.UnaryCallable;
+import com.google.longrunning.Operation;
+import javax.annotation.Generated;
+
+// AUTO-GENERATED DOCUMENTATION AND CLASS.
+/**
+ * REST callable factory implementation for the AccessApproval service API.
+ *
+ *
This class is for advanced usage.
+ */
+@Generated("by gapic-generator-java")
+@BetaApi
+public class HttpJsonAccessApprovalCallableFactory
+ implements HttpJsonStubCallableFactory {
+
+ @Override
+ public UnaryCallable createUnaryCallable(
+ HttpJsonCallSettings httpJsonCallSettings,
+ UnaryCallSettings callSettings,
+ ClientContext clientContext) {
+ return HttpJsonCallableFactory.createUnaryCallable(
+ httpJsonCallSettings, callSettings, clientContext);
+ }
+
+ @Override
+ public
+ UnaryCallable createPagedCallable(
+ HttpJsonCallSettings httpJsonCallSettings,
+ PagedCallSettings callSettings,
+ ClientContext clientContext) {
+ return HttpJsonCallableFactory.createPagedCallable(
+ httpJsonCallSettings, callSettings, clientContext);
+ }
+
+ @Override
+ public UnaryCallable createBatchingCallable(
+ HttpJsonCallSettings httpJsonCallSettings,
+ BatchingCallSettings callSettings,
+ ClientContext clientContext) {
+ return HttpJsonCallableFactory.createBatchingCallable(
+ httpJsonCallSettings, callSettings, clientContext);
+ }
+
+ @BetaApi(
+ "The surface for long-running operations is not stable yet and may change in the future.")
+ @Override
+ public
+ OperationCallable createOperationCallable(
+ HttpJsonCallSettings httpJsonCallSettings,
+ OperationCallSettings callSettings,
+ ClientContext clientContext,
+ OperationsStub operationsStub) {
+ UnaryCallable innerCallable =
+ HttpJsonCallableFactory.createBaseUnaryCallable(
+ httpJsonCallSettings, callSettings.getInitialCallSettings(), clientContext);
+ HttpJsonOperationSnapshotCallable initialCallable =
+ new HttpJsonOperationSnapshotCallable(
+ innerCallable,
+ httpJsonCallSettings.getMethodDescriptor().getOperationSnapshotFactory());
+ return HttpJsonCallableFactory.createOperationCallable(
+ callSettings, clientContext, operationsStub.longRunningClient(), initialCallable);
+ }
+
+ @Override
+ public
+ ServerStreamingCallable createServerStreamingCallable(
+ HttpJsonCallSettings httpJsonCallSettings,
+ ServerStreamingCallSettings callSettings,
+ ClientContext clientContext) {
+ return HttpJsonCallableFactory.createServerStreamingCallable(
+ httpJsonCallSettings, callSettings, clientContext);
+ }
+}
diff --git a/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/HttpJsonAccessApprovalStub.java b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/HttpJsonAccessApprovalStub.java
new file mode 100644
index 000000000000..c1e963a0a36c
--- /dev/null
+++ b/java-accessapproval/google-cloud-accessapproval/src/main/java/com/google/cloud/accessapproval/v1/stub/HttpJsonAccessApprovalStub.java
@@ -0,0 +1,708 @@
+/*
+ * Copyright 2022 Google LLC
+ *
+ * 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 com.google.cloud.accessapproval.v1.stub;
+
+import static com.google.cloud.accessapproval.v1.AccessApprovalAdminClient.ListApprovalRequestsPagedResponse;
+
+import com.google.api.core.BetaApi;
+import com.google.api.core.InternalApi;
+import com.google.api.gax.core.BackgroundResource;
+import com.google.api.gax.core.BackgroundResourceAggregation;
+import com.google.api.gax.httpjson.ApiMethodDescriptor;
+import com.google.api.gax.httpjson.HttpJsonCallSettings;
+import com.google.api.gax.httpjson.HttpJsonStubCallableFactory;
+import com.google.api.gax.httpjson.ProtoMessageRequestFormatter;
+import com.google.api.gax.httpjson.ProtoMessageResponseParser;
+import com.google.api.gax.httpjson.ProtoRestSerializer;
+import com.google.api.gax.rpc.ClientContext;
+import com.google.api.gax.rpc.UnaryCallable;
+import com.google.cloud.accessapproval.v1.AccessApprovalServiceAccount;
+import com.google.cloud.accessapproval.v1.AccessApprovalSettings;
+import com.google.cloud.accessapproval.v1.ApprovalRequest;
+import com.google.cloud.accessapproval.v1.ApproveApprovalRequestMessage;
+import com.google.cloud.accessapproval.v1.DeleteAccessApprovalSettingsMessage;
+import com.google.cloud.accessapproval.v1.DismissApprovalRequestMessage;
+import com.google.cloud.accessapproval.v1.GetAccessApprovalServiceAccountMessage;
+import com.google.cloud.accessapproval.v1.GetAccessApprovalSettingsMessage;
+import com.google.cloud.accessapproval.v1.GetApprovalRequestMessage;
+import com.google.cloud.accessapproval.v1.InvalidateApprovalRequestMessage;
+import com.google.cloud.accessapproval.v1.ListApprovalRequestsMessage;
+import com.google.cloud.accessapproval.v1.ListApprovalRequestsResponse;
+import com.google.cloud.accessapproval.v1.UpdateAccessApprovalSettingsMessage;
+import com.google.protobuf.Empty;
+import com.google.protobuf.TypeRegistry;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+import javax.annotation.Generated;
+
+// AUTO-GENERATED DOCUMENTATION AND CLASS.
+/**
+ * REST stub implementation for the AccessApproval service API.
+ *
+ * This class is for advanced usage and reflects the underlying API directly.
+ */
+@Generated("by gapic-generator-java")
+@BetaApi
+public class HttpJsonAccessApprovalStub extends AccessApprovalStub {
+ private static final TypeRegistry typeRegistry = TypeRegistry.newBuilder().build();
+
+ private static final ApiMethodDescriptor<
+ ListApprovalRequestsMessage, ListApprovalRequestsResponse>
+ listApprovalRequestsMethodDescriptor =
+ ApiMethodDescriptor
+ .newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/ListApprovalRequests")
+ .setHttpMethod("GET")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{parent=projects/*}/approvalRequests",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "parent", request.getParent());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{parent=folders/*}/approvalRequests",
+ "/v1/{parent=organizations/*}/approvalRequests")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putQueryParam(fields, "filter", request.getFilter());
+ serializer.putQueryParam(fields, "pageSize", request.getPageSize());
+ serializer.putQueryParam(fields, "pageToken", request.getPageToken());
+ return fields;
+ })
+ .setRequestBodyExtractor(request -> null)
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(ListApprovalRequestsResponse.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor
+ getApprovalRequestMethodDescriptor =
+ ApiMethodDescriptor.newBuilder()
+ .setFullMethodName("google.cloud.accessapproval.v1.AccessApproval/GetApprovalRequest")
+ .setHttpMethod("GET")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{name=projects/*/approvalRequests/*}",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "name", request.getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{name=folders/*/approvalRequests/*}",
+ "/v1/{name=organizations/*/approvalRequests/*}")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ return fields;
+ })
+ .setRequestBodyExtractor(request -> null)
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(ApprovalRequest.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor
+ approveApprovalRequestMethodDescriptor =
+ ApiMethodDescriptor.newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/ApproveApprovalRequest")
+ .setHttpMethod("POST")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{name=projects/*/approvalRequests/*}:approve",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "name", request.getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{name=folders/*/approvalRequests/*}:approve",
+ "/v1/{name=organizations/*/approvalRequests/*}:approve")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ return fields;
+ })
+ .setRequestBodyExtractor(
+ request ->
+ ProtoRestSerializer.create()
+ .toBody("*", request.toBuilder().clearName().build()))
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(ApprovalRequest.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor
+ dismissApprovalRequestMethodDescriptor =
+ ApiMethodDescriptor.newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/DismissApprovalRequest")
+ .setHttpMethod("POST")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{name=projects/*/approvalRequests/*}:dismiss",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "name", request.getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{name=folders/*/approvalRequests/*}:dismiss",
+ "/v1/{name=organizations/*/approvalRequests/*}:dismiss")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ return fields;
+ })
+ .setRequestBodyExtractor(
+ request ->
+ ProtoRestSerializer.create()
+ .toBody("*", request.toBuilder().clearName().build()))
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(ApprovalRequest.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor
+ invalidateApprovalRequestMethodDescriptor =
+ ApiMethodDescriptor.newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/InvalidateApprovalRequest")
+ .setHttpMethod("POST")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{name=projects/*/approvalRequests/*}:invalidate",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "name", request.getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{name=folders/*/approvalRequests/*}:invalidate",
+ "/v1/{name=organizations/*/approvalRequests/*}:invalidate")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ return fields;
+ })
+ .setRequestBodyExtractor(
+ request ->
+ ProtoRestSerializer.create()
+ .toBody("*", request.toBuilder().clearName().build()))
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(ApprovalRequest.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor
+ getAccessApprovalSettingsMethodDescriptor =
+ ApiMethodDescriptor.newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/GetAccessApprovalSettings")
+ .setHttpMethod("GET")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{name=projects/*/accessApprovalSettings}",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "name", request.getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{name=folders/*/accessApprovalSettings}",
+ "/v1/{name=organizations/*/accessApprovalSettings}")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ return fields;
+ })
+ .setRequestBodyExtractor(request -> null)
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(AccessApprovalSettings.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor<
+ UpdateAccessApprovalSettingsMessage, AccessApprovalSettings>
+ updateAccessApprovalSettingsMethodDescriptor =
+ ApiMethodDescriptor
+ .newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/UpdateAccessApprovalSettings")
+ .setHttpMethod("PATCH")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{settings.name=projects/*/accessApprovalSettings}",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(
+ fields, "settings.name", request.getSettings().getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{settings.name=folders/*/accessApprovalSettings}",
+ "/v1/{settings.name=organizations/*/accessApprovalSettings}")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putQueryParam(fields, "updateMask", request.getUpdateMask());
+ return fields;
+ })
+ .setRequestBodyExtractor(
+ request ->
+ ProtoRestSerializer.create()
+ .toBody("settings", request.getSettings()))
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(AccessApprovalSettings.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor
+ deleteAccessApprovalSettingsMethodDescriptor =
+ ApiMethodDescriptor.newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/DeleteAccessApprovalSettings")
+ .setHttpMethod("DELETE")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{name=projects/*/accessApprovalSettings}",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "name", request.getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{name=folders/*/accessApprovalSettings}",
+ "/v1/{name=organizations/*/accessApprovalSettings}")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ return fields;
+ })
+ .setRequestBodyExtractor(request -> null)
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(Empty.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private static final ApiMethodDescriptor<
+ GetAccessApprovalServiceAccountMessage, AccessApprovalServiceAccount>
+ getAccessApprovalServiceAccountMethodDescriptor =
+ ApiMethodDescriptor
+ .newBuilder()
+ .setFullMethodName(
+ "google.cloud.accessapproval.v1.AccessApproval/GetAccessApprovalServiceAccount")
+ .setHttpMethod("GET")
+ .setType(ApiMethodDescriptor.MethodType.UNARY)
+ .setRequestFormatter(
+ ProtoMessageRequestFormatter.newBuilder()
+ .setPath(
+ "/v1/{name=projects/*/serviceAccount}",
+ request -> {
+ Map fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ serializer.putPathParam(fields, "name", request.getName());
+ return fields;
+ })
+ .setAdditionalPaths(
+ "/v1/{name=folders/*/serviceAccount}",
+ "/v1/{name=organizations/*/serviceAccount}")
+ .setQueryParamsExtractor(
+ request -> {
+ Map> fields = new HashMap<>();
+ ProtoRestSerializer serializer =
+ ProtoRestSerializer.create();
+ return fields;
+ })
+ .setRequestBodyExtractor(request -> null)
+ .build())
+ .setResponseParser(
+ ProtoMessageResponseParser.newBuilder()
+ .setDefaultInstance(AccessApprovalServiceAccount.getDefaultInstance())
+ .setDefaultTypeRegistry(typeRegistry)
+ .build())
+ .build();
+
+ private final UnaryCallable
+ listApprovalRequestsCallable;
+ private final UnaryCallable
+ listApprovalRequestsPagedCallable;
+ private final UnaryCallable
+ getApprovalRequestCallable;
+ private final UnaryCallable
+ approveApprovalRequestCallable;
+ private final UnaryCallable
+ dismissApprovalRequestCallable;
+ private final UnaryCallable
+ invalidateApprovalRequestCallable;
+ private final UnaryCallable
+ getAccessApprovalSettingsCallable;
+ private final UnaryCallable
+ updateAccessApprovalSettingsCallable;
+ private final UnaryCallable
+ deleteAccessApprovalSettingsCallable;
+ private final UnaryCallable
+ getAccessApprovalServiceAccountCallable;
+
+ private final BackgroundResource backgroundResources;
+ private final HttpJsonStubCallableFactory callableFactory;
+
+ public static final HttpJsonAccessApprovalStub create(AccessApprovalStubSettings settings)
+ throws IOException {
+ return new HttpJsonAccessApprovalStub(settings, ClientContext.create(settings));
+ }
+
+ public static final HttpJsonAccessApprovalStub create(ClientContext clientContext)
+ throws IOException {
+ return new HttpJsonAccessApprovalStub(
+ AccessApprovalStubSettings.newHttpJsonBuilder().build(), clientContext);
+ }
+
+ public static final HttpJsonAccessApprovalStub create(
+ ClientContext clientContext, HttpJsonStubCallableFactory callableFactory) throws IOException {
+ return new HttpJsonAccessApprovalStub(
+ AccessApprovalStubSettings.newHttpJsonBuilder().build(), clientContext, callableFactory);
+ }
+
+ /**
+ * Constructs an instance of HttpJsonAccessApprovalStub, using the given settings. This is
+ * protected so that it is easy to make a subclass, but otherwise, the static factory methods
+ * should be preferred.
+ */
+ protected HttpJsonAccessApprovalStub(
+ AccessApprovalStubSettings settings, ClientContext clientContext) throws IOException {
+ this(settings, clientContext, new HttpJsonAccessApprovalCallableFactory());
+ }
+
+ /**
+ * Constructs an instance of HttpJsonAccessApprovalStub, using the given settings. This is
+ * protected so that it is easy to make a subclass, but otherwise, the static factory methods
+ * should be preferred.
+ */
+ protected HttpJsonAccessApprovalStub(
+ AccessApprovalStubSettings settings,
+ ClientContext clientContext,
+ HttpJsonStubCallableFactory callableFactory)
+ throws IOException {
+ this.callableFactory = callableFactory;
+
+ HttpJsonCallSettings
+ listApprovalRequestsTransportSettings =
+ HttpJsonCallSettings
+ .newBuilder()
+ .setMethodDescriptor(listApprovalRequestsMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ getApprovalRequestTransportSettings =
+ HttpJsonCallSettings.newBuilder()
+ .setMethodDescriptor(getApprovalRequestMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ approveApprovalRequestTransportSettings =
+ HttpJsonCallSettings.newBuilder()
+ .setMethodDescriptor(approveApprovalRequestMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ dismissApprovalRequestTransportSettings =
+ HttpJsonCallSettings.newBuilder()
+ .setMethodDescriptor(dismissApprovalRequestMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ invalidateApprovalRequestTransportSettings =
+ HttpJsonCallSettings.newBuilder()
+ .setMethodDescriptor(invalidateApprovalRequestMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ getAccessApprovalSettingsTransportSettings =
+ HttpJsonCallSettings
+ .newBuilder()
+ .setMethodDescriptor(getAccessApprovalSettingsMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ updateAccessApprovalSettingsTransportSettings =
+ HttpJsonCallSettings
+ .newBuilder()
+ .setMethodDescriptor(updateAccessApprovalSettingsMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ deleteAccessApprovalSettingsTransportSettings =
+ HttpJsonCallSettings.newBuilder()
+ .setMethodDescriptor(deleteAccessApprovalSettingsMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+ HttpJsonCallSettings
+ getAccessApprovalServiceAccountTransportSettings =
+ HttpJsonCallSettings
+ .newBuilder()
+ .setMethodDescriptor(getAccessApprovalServiceAccountMethodDescriptor)
+ .setTypeRegistry(typeRegistry)
+ .build();
+
+ this.listApprovalRequestsCallable =
+ callableFactory.createUnaryCallable(
+ listApprovalRequestsTransportSettings,
+ settings.listApprovalRequestsSettings(),
+ clientContext);
+ this.listApprovalRequestsPagedCallable =
+ callableFactory.createPagedCallable(
+ listApprovalRequestsTransportSettings,
+ settings.listApprovalRequestsSettings(),
+ clientContext);
+ this.getApprovalRequestCallable =
+ callableFactory.createUnaryCallable(
+ getApprovalRequestTransportSettings,
+ settings.getApprovalRequestSettings(),
+ clientContext);
+ this.approveApprovalRequestCallable =
+ callableFactory.createUnaryCallable(
+ approveApprovalRequestTransportSettings,
+ settings.approveApprovalRequestSettings(),
+ clientContext);
+ this.dismissApprovalRequestCallable =
+ callableFactory.createUnaryCallable(
+ dismissApprovalRequestTransportSettings,
+ settings.dismissApprovalRequestSettings(),
+ clientContext);
+ this.invalidateApprovalRequestCallable =
+ callableFactory.createUnaryCallable(
+ invalidateApprovalRequestTransportSettings,
+ settings.invalidateApprovalRequestSettings(),
+ clientContext);
+ this.getAccessApprovalSettingsCallable =
+ callableFactory.createUnaryCallable(
+ getAccessApprovalSettingsTransportSettings,
+ settings.getAccessApprovalSettingsSettings(),
+ clientContext);
+ this.updateAccessApprovalSettingsCallable =
+ callableFactory.createUnaryCallable(
+ updateAccessApprovalSettingsTransportSettings,
+ settings.updateAccessApprovalSettingsSettings(),
+ clientContext);
+ this.deleteAccessApprovalSettingsCallable =
+ callableFactory.createUnaryCallable(
+ deleteAccessApprovalSettingsTransportSettings,
+ settings.deleteAccessApprovalSettingsSettings(),
+ clientContext);
+ this.getAccessApprovalServiceAccountCallable =
+ callableFactory.createUnaryCallable(
+ getAccessApprovalServiceAccountTransportSettings,
+ settings.getAccessApprovalServiceAccountSettings(),
+ clientContext);
+
+ this.backgroundResources =
+ new BackgroundResourceAggregation(clientContext.getBackgroundResources());
+ }
+
+ @InternalApi
+ public static List getMethodDescriptors() {
+ List methodDescriptors = new ArrayList<>();
+ methodDescriptors.add(listApprovalRequestsMethodDescriptor);
+ methodDescriptors.add(getApprovalRequestMethodDescriptor);
+ methodDescriptors.add(approveApprovalRequestMethodDescriptor);
+ methodDescriptors.add(dismissApprovalRequestMethodDescriptor);
+ methodDescriptors.add(invalidateApprovalRequestMethodDescriptor);
+ methodDescriptors.add(getAccessApprovalSettingsMethodDescriptor);
+ methodDescriptors.add(updateAccessApprovalSettingsMethodDescriptor);
+ methodDescriptors.add(deleteAccessApprovalSettingsMethodDescriptor);
+ methodDescriptors.add(getAccessApprovalServiceAccountMethodDescriptor);
+ return methodDescriptors;
+ }
+
+ @Override
+ public UnaryCallable
+ listApprovalRequestsCallable() {
+ return listApprovalRequestsCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ listApprovalRequestsPagedCallable() {
+ return listApprovalRequestsPagedCallable;
+ }
+
+ @Override
+ public UnaryCallable getApprovalRequestCallable() {
+ return getApprovalRequestCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ approveApprovalRequestCallable() {
+ return approveApprovalRequestCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ dismissApprovalRequestCallable() {
+ return dismissApprovalRequestCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ invalidateApprovalRequestCallable() {
+ return invalidateApprovalRequestCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ getAccessApprovalSettingsCallable() {
+ return getAccessApprovalSettingsCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ updateAccessApprovalSettingsCallable() {
+ return updateAccessApprovalSettingsCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ deleteAccessApprovalSettingsCallable() {
+ return deleteAccessApprovalSettingsCallable;
+ }
+
+ @Override
+ public UnaryCallable
+ getAccessApprovalServiceAccountCallable() {
+ return getAccessApprovalServiceAccountCallable;
+ }
+
+ @Override
+ public final void close() {
+ try {
+ backgroundResources.close();
+ } catch (RuntimeException e) {
+ throw e;
+ } catch (Exception e) {
+ throw new IllegalStateException("Failed to close resource", e);
+ }
+ }
+
+ @Override
+ public void shutdown() {
+ backgroundResources.shutdown();
+ }
+
+ @Override
+ public boolean isShutdown() {
+ return backgroundResources.isShutdown();
+ }
+
+ @Override
+ public boolean isTerminated() {
+ return backgroundResources.isTerminated();
+ }
+
+ @Override
+ public void shutdownNow() {
+ backgroundResources.shutdownNow();
+ }
+
+ @Override
+ public boolean awaitTermination(long duration, TimeUnit unit) throws InterruptedException {
+ return backgroundResources.awaitTermination(duration, unit);
+ }
+}
diff --git a/java-accessapproval/google-cloud-accessapproval/src/test/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminClientHttpJsonTest.java b/java-accessapproval/google-cloud-accessapproval/src/test/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminClientHttpJsonTest.java
new file mode 100644
index 000000000000..7ffe1d3652cc
--- /dev/null
+++ b/java-accessapproval/google-cloud-accessapproval/src/test/java/com/google/cloud/accessapproval/v1/AccessApprovalAdminClientHttpJsonTest.java
@@ -0,0 +1,874 @@
+/*
+ * Copyright 2022 Google LLC
+ *
+ * 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 com.google.cloud.accessapproval.v1;
+
+import static com.google.cloud.accessapproval.v1.AccessApprovalAdminClient.ListApprovalRequestsPagedResponse;
+
+import com.google.api.gax.core.NoCredentialsProvider;
+import com.google.api.gax.httpjson.GaxHttpJsonProperties;
+import com.google.api.gax.httpjson.testing.MockHttpService;
+import com.google.api.gax.rpc.ApiClientHeaderProvider;
+import com.google.api.gax.rpc.ApiException;
+import com.google.api.gax.rpc.ApiExceptionFactory;
+import com.google.api.gax.rpc.InvalidArgumentException;
+import com.google.api.gax.rpc.StatusCode;
+import com.google.api.gax.rpc.testing.FakeStatusCode;
+import com.google.cloud.accessapproval.v1.stub.HttpJsonAccessApprovalStub;
+import com.google.common.collect.Lists;
+import com.google.protobuf.Empty;
+import com.google.protobuf.FieldMask;
+import com.google.protobuf.Timestamp;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+import javax.annotation.Generated;
+import org.junit.After;
+import org.junit.AfterClass;
+import org.junit.Assert;
+import org.junit.Before;
+import org.junit.BeforeClass;
+import org.junit.Test;
+
+@Generated("by gapic-generator-java")
+public class AccessApprovalAdminClientHttpJsonTest {
+ private static MockHttpService mockService;
+ private static AccessApprovalAdminClient client;
+
+ @BeforeClass
+ public static void startStaticServer() throws IOException {
+ mockService =
+ new MockHttpService(
+ HttpJsonAccessApprovalStub.getMethodDescriptors(),
+ AccessApprovalAdminSettings.getDefaultEndpoint());
+ AccessApprovalAdminSettings settings =
+ AccessApprovalAdminSettings.newHttpJsonBuilder()
+ .setTransportChannelProvider(
+ AccessApprovalAdminSettings.defaultHttpJsonTransportProviderBuilder()
+ .setHttpTransport(mockService)
+ .build())
+ .setCredentialsProvider(NoCredentialsProvider.create())
+ .build();
+ client = AccessApprovalAdminClient.create(settings);
+ }
+
+ @AfterClass
+ public static void stopServer() {
+ client.close();
+ }
+
+ @Before
+ public void setUp() {}
+
+ @After
+ public void tearDown() throws Exception {
+ mockService.reset();
+ }
+
+ @Test
+ public void listApprovalRequestsTest() throws Exception {
+ ApprovalRequest responsesElement = ApprovalRequest.newBuilder().build();
+ ListApprovalRequestsResponse expectedResponse =
+ ListApprovalRequestsResponse.newBuilder()
+ .setNextPageToken("")
+ .addAllApprovalRequests(Arrays.asList(responsesElement))
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ FolderName parent = FolderName.of("[FOLDER]");
+
+ ListApprovalRequestsPagedResponse pagedListResponse = client.listApprovalRequests(parent);
+
+ List resources = Lists.newArrayList(pagedListResponse.iterateAll());
+
+ Assert.assertEquals(1, resources.size());
+ Assert.assertEquals(expectedResponse.getApprovalRequestsList().get(0), resources.get(0));
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void listApprovalRequestsExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ FolderName parent = FolderName.of("[FOLDER]");
+ client.listApprovalRequests(parent);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void listApprovalRequestsTest2() throws Exception {
+ ApprovalRequest responsesElement = ApprovalRequest.newBuilder().build();
+ ListApprovalRequestsResponse expectedResponse =
+ ListApprovalRequestsResponse.newBuilder()
+ .setNextPageToken("")
+ .addAllApprovalRequests(Arrays.asList(responsesElement))
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ OrganizationName parent = OrganizationName.of("[ORGANIZATION]");
+
+ ListApprovalRequestsPagedResponse pagedListResponse = client.listApprovalRequests(parent);
+
+ List resources = Lists.newArrayList(pagedListResponse.iterateAll());
+
+ Assert.assertEquals(1, resources.size());
+ Assert.assertEquals(expectedResponse.getApprovalRequestsList().get(0), resources.get(0));
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void listApprovalRequestsExceptionTest2() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ OrganizationName parent = OrganizationName.of("[ORGANIZATION]");
+ client.listApprovalRequests(parent);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void listApprovalRequestsTest3() throws Exception {
+ ApprovalRequest responsesElement = ApprovalRequest.newBuilder().build();
+ ListApprovalRequestsResponse expectedResponse =
+ ListApprovalRequestsResponse.newBuilder()
+ .setNextPageToken("")
+ .addAllApprovalRequests(Arrays.asList(responsesElement))
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ ProjectName parent = ProjectName.of("[PROJECT]");
+
+ ListApprovalRequestsPagedResponse pagedListResponse = client.listApprovalRequests(parent);
+
+ List resources = Lists.newArrayList(pagedListResponse.iterateAll());
+
+ Assert.assertEquals(1, resources.size());
+ Assert.assertEquals(expectedResponse.getApprovalRequestsList().get(0), resources.get(0));
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void listApprovalRequestsExceptionTest3() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ ProjectName parent = ProjectName.of("[PROJECT]");
+ client.listApprovalRequests(parent);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void listApprovalRequestsTest4() throws Exception {
+ ApprovalRequest responsesElement = ApprovalRequest.newBuilder().build();
+ ListApprovalRequestsResponse expectedResponse =
+ ListApprovalRequestsResponse.newBuilder()
+ .setNextPageToken("")
+ .addAllApprovalRequests(Arrays.asList(responsesElement))
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ String parent = "projects/project-2353";
+
+ ListApprovalRequestsPagedResponse pagedListResponse = client.listApprovalRequests(parent);
+
+ List resources = Lists.newArrayList(pagedListResponse.iterateAll());
+
+ Assert.assertEquals(1, resources.size());
+ Assert.assertEquals(expectedResponse.getApprovalRequestsList().get(0), resources.get(0));
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void listApprovalRequestsExceptionTest4() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ String parent = "projects/project-2353";
+ client.listApprovalRequests(parent);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void getApprovalRequestTest() throws Exception {
+ ApprovalRequest expectedResponse =
+ ApprovalRequest.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .setRequestedResourceName("requestedResourceName-1218563513")
+ .setRequestedResourceProperties(ResourceProperties.newBuilder().build())
+ .setRequestedReason(AccessReason.newBuilder().build())
+ .setRequestedLocations(AccessLocations.newBuilder().build())
+ .setRequestTime(Timestamp.newBuilder().build())
+ .setRequestedExpiration(Timestamp.newBuilder().build())
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ ApprovalRequestName name =
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]");
+
+ ApprovalRequest actualResponse = client.getApprovalRequest(name);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void getApprovalRequestExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ ApprovalRequestName name =
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]");
+ client.getApprovalRequest(name);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void getApprovalRequestTest2() throws Exception {
+ ApprovalRequest expectedResponse =
+ ApprovalRequest.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .setRequestedResourceName("requestedResourceName-1218563513")
+ .setRequestedResourceProperties(ResourceProperties.newBuilder().build())
+ .setRequestedReason(AccessReason.newBuilder().build())
+ .setRequestedLocations(AccessLocations.newBuilder().build())
+ .setRequestTime(Timestamp.newBuilder().build())
+ .setRequestedExpiration(Timestamp.newBuilder().build())
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ String name = "projects/project-6513/approvalRequests/approvalRequest-6513";
+
+ ApprovalRequest actualResponse = client.getApprovalRequest(name);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void getApprovalRequestExceptionTest2() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ String name = "projects/project-6513/approvalRequests/approvalRequest-6513";
+ client.getApprovalRequest(name);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void approveApprovalRequestTest() throws Exception {
+ ApprovalRequest expectedResponse =
+ ApprovalRequest.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .setRequestedResourceName("requestedResourceName-1218563513")
+ .setRequestedResourceProperties(ResourceProperties.newBuilder().build())
+ .setRequestedReason(AccessReason.newBuilder().build())
+ .setRequestedLocations(AccessLocations.newBuilder().build())
+ .setRequestTime(Timestamp.newBuilder().build())
+ .setRequestedExpiration(Timestamp.newBuilder().build())
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ ApproveApprovalRequestMessage request =
+ ApproveApprovalRequestMessage.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .setExpireTime(Timestamp.newBuilder().build())
+ .build();
+
+ ApprovalRequest actualResponse = client.approveApprovalRequest(request);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void approveApprovalRequestExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ ApproveApprovalRequestMessage request =
+ ApproveApprovalRequestMessage.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName(
+ "[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .setExpireTime(Timestamp.newBuilder().build())
+ .build();
+ client.approveApprovalRequest(request);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void dismissApprovalRequestTest() throws Exception {
+ ApprovalRequest expectedResponse =
+ ApprovalRequest.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .setRequestedResourceName("requestedResourceName-1218563513")
+ .setRequestedResourceProperties(ResourceProperties.newBuilder().build())
+ .setRequestedReason(AccessReason.newBuilder().build())
+ .setRequestedLocations(AccessLocations.newBuilder().build())
+ .setRequestTime(Timestamp.newBuilder().build())
+ .setRequestedExpiration(Timestamp.newBuilder().build())
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ DismissApprovalRequestMessage request =
+ DismissApprovalRequestMessage.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .build();
+
+ ApprovalRequest actualResponse = client.dismissApprovalRequest(request);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void dismissApprovalRequestExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ DismissApprovalRequestMessage request =
+ DismissApprovalRequestMessage.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName(
+ "[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .build();
+ client.dismissApprovalRequest(request);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void invalidateApprovalRequestTest() throws Exception {
+ ApprovalRequest expectedResponse =
+ ApprovalRequest.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .setRequestedResourceName("requestedResourceName-1218563513")
+ .setRequestedResourceProperties(ResourceProperties.newBuilder().build())
+ .setRequestedReason(AccessReason.newBuilder().build())
+ .setRequestedLocations(AccessLocations.newBuilder().build())
+ .setRequestTime(Timestamp.newBuilder().build())
+ .setRequestedExpiration(Timestamp.newBuilder().build())
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ InvalidateApprovalRequestMessage request =
+ InvalidateApprovalRequestMessage.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName("[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .build();
+
+ ApprovalRequest actualResponse = client.invalidateApprovalRequest(request);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void invalidateApprovalRequestExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ InvalidateApprovalRequestMessage request =
+ InvalidateApprovalRequestMessage.newBuilder()
+ .setName(
+ ApprovalRequestName.ofProjectApprovalRequestName(
+ "[PROJECT]", "[APPROVAL_REQUEST]")
+ .toString())
+ .build();
+ client.invalidateApprovalRequest(request);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void getAccessApprovalSettingsTest() throws Exception {
+ AccessApprovalSettings expectedResponse =
+ AccessApprovalSettings.newBuilder()
+ .setName(AccessApprovalSettingsName.ofProjectName("[PROJECT]").toString())
+ .addAllNotificationEmails(new ArrayList())
+ .addAllEnrolledServices(new ArrayList())
+ .setEnrolledAncestor(true)
+ .setActiveKeyVersion("activeKeyVersion1352190239")
+ .setAncestorHasActiveKeyVersion(true)
+ .setInvalidKeyVersion(true)
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ AccessApprovalSettingsName name = AccessApprovalSettingsName.ofProjectName("[PROJECT]");
+
+ AccessApprovalSettings actualResponse = client.getAccessApprovalSettings(name);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void getAccessApprovalSettingsExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ AccessApprovalSettingsName name = AccessApprovalSettingsName.ofProjectName("[PROJECT]");
+ client.getAccessApprovalSettings(name);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void getAccessApprovalSettingsTest2() throws Exception {
+ AccessApprovalSettings expectedResponse =
+ AccessApprovalSettings.newBuilder()
+ .setName(AccessApprovalSettingsName.ofProjectName("[PROJECT]").toString())
+ .addAllNotificationEmails(new ArrayList())
+ .addAllEnrolledServices(new ArrayList())
+ .setEnrolledAncestor(true)
+ .setActiveKeyVersion("activeKeyVersion1352190239")
+ .setAncestorHasActiveKeyVersion(true)
+ .setInvalidKeyVersion(true)
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ String name = "projects/project-9033/accessApprovalSettings";
+
+ AccessApprovalSettings actualResponse = client.getAccessApprovalSettings(name);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void getAccessApprovalSettingsExceptionTest2() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ String name = "projects/project-9033/accessApprovalSettings";
+ client.getAccessApprovalSettings(name);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void updateAccessApprovalSettingsTest() throws Exception {
+ AccessApprovalSettings expectedResponse =
+ AccessApprovalSettings.newBuilder()
+ .setName(AccessApprovalSettingsName.ofProjectName("[PROJECT]").toString())
+ .addAllNotificationEmails(new ArrayList())
+ .addAllEnrolledServices(new ArrayList())
+ .setEnrolledAncestor(true)
+ .setActiveKeyVersion("activeKeyVersion1352190239")
+ .setAncestorHasActiveKeyVersion(true)
+ .setInvalidKeyVersion(true)
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ AccessApprovalSettings settings =
+ AccessApprovalSettings.newBuilder()
+ .setName(AccessApprovalSettingsName.ofProjectName("[PROJECT]").toString())
+ .addAllNotificationEmails(new ArrayList())
+ .addAllEnrolledServices(new ArrayList())
+ .setEnrolledAncestor(true)
+ .setActiveKeyVersion("activeKeyVersion1352190239")
+ .setAncestorHasActiveKeyVersion(true)
+ .setInvalidKeyVersion(true)
+ .build();
+ FieldMask updateMask = FieldMask.newBuilder().build();
+
+ AccessApprovalSettings actualResponse =
+ client.updateAccessApprovalSettings(settings, updateMask);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void updateAccessApprovalSettingsExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ AccessApprovalSettings settings =
+ AccessApprovalSettings.newBuilder()
+ .setName(AccessApprovalSettingsName.ofProjectName("[PROJECT]").toString())
+ .addAllNotificationEmails(new ArrayList())
+ .addAllEnrolledServices(new ArrayList())
+ .setEnrolledAncestor(true)
+ .setActiveKeyVersion("activeKeyVersion1352190239")
+ .setAncestorHasActiveKeyVersion(true)
+ .setInvalidKeyVersion(true)
+ .build();
+ FieldMask updateMask = FieldMask.newBuilder().build();
+ client.updateAccessApprovalSettings(settings, updateMask);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void deleteAccessApprovalSettingsTest() throws Exception {
+ Empty expectedResponse = Empty.newBuilder().build();
+ mockService.addResponse(expectedResponse);
+
+ AccessApprovalSettingsName name = AccessApprovalSettingsName.ofProjectName("[PROJECT]");
+
+ client.deleteAccessApprovalSettings(name);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void deleteAccessApprovalSettingsExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ AccessApprovalSettingsName name = AccessApprovalSettingsName.ofProjectName("[PROJECT]");
+ client.deleteAccessApprovalSettings(name);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void deleteAccessApprovalSettingsTest2() throws Exception {
+ Empty expectedResponse = Empty.newBuilder().build();
+ mockService.addResponse(expectedResponse);
+
+ String name = "projects/project-9033/accessApprovalSettings";
+
+ client.deleteAccessApprovalSettings(name);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void deleteAccessApprovalSettingsExceptionTest2() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ String name = "projects/project-9033/accessApprovalSettings";
+ client.deleteAccessApprovalSettings(name);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+
+ @Test
+ public void getAccessApprovalServiceAccountTest() throws Exception {
+ AccessApprovalServiceAccount expectedResponse =
+ AccessApprovalServiceAccount.newBuilder()
+ .setName("name3373707")
+ .setAccountEmail("accountEmail1067197807")
+ .build();
+ mockService.addResponse(expectedResponse);
+
+ String name = "projects/project-9017/serviceAccount";
+
+ AccessApprovalServiceAccount actualResponse = client.getAccessApprovalServiceAccount(name);
+ Assert.assertEquals(expectedResponse, actualResponse);
+
+ List actualRequests = mockService.getRequestPaths();
+ Assert.assertEquals(1, actualRequests.size());
+
+ String apiClientHeaderKey =
+ mockService
+ .getRequestHeaders()
+ .get(ApiClientHeaderProvider.getDefaultApiClientHeaderKey())
+ .iterator()
+ .next();
+ Assert.assertTrue(
+ GaxHttpJsonProperties.getDefaultApiClientHeaderPattern()
+ .matcher(apiClientHeaderKey)
+ .matches());
+ }
+
+ @Test
+ public void getAccessApprovalServiceAccountExceptionTest() throws Exception {
+ ApiException exception =
+ ApiExceptionFactory.createException(
+ new Exception(), FakeStatusCode.of(StatusCode.Code.INVALID_ARGUMENT), false);
+ mockService.addException(exception);
+
+ try {
+ String name = "projects/project-9017/serviceAccount";
+ client.getAccessApprovalServiceAccount(name);
+ Assert.fail("No exception raised");
+ } catch (InvalidArgumentException e) {
+ // Expected exception.
+ }
+ }
+}
diff --git a/java-accessapproval/samples/snippets/generated/com/google/cloud/accessapproval/v1/accessapprovaladminclient/create/SyncCreateSetCredentialsProvider1.java b/java-accessapproval/samples/snippets/generated/com/google/cloud/accessapproval/v1/accessapprovaladminclient/create/SyncCreateSetCredentialsProvider1.java
new file mode 100644
index 000000000000..2d37e0f6512c
--- /dev/null
+++ b/java-accessapproval/samples/snippets/generated/com/google/cloud/accessapproval/v1/accessapprovaladminclient/create/SyncCreateSetCredentialsProvider1.java
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2022 Google LLC
+ *
+ * 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 com.google.cloud.accessapproval.v1.samples;
+
+// [START accessapproval_v1_generated_accessapprovaladminclient_create_setcredentialsprovider1_sync]
+import com.google.cloud.accessapproval.v1.AccessApprovalAdminClient;
+import com.google.cloud.accessapproval.v1.AccessApprovalAdminSettings;
+
+public class SyncCreateSetCredentialsProvider1 {
+
+ public static void main(String[] args) throws Exception {
+ syncCreateSetCredentialsProvider1();
+ }
+
+ public static void syncCreateSetCredentialsProvider1() throws Exception {
+ // This snippet has been automatically generated for illustrative purposes only.
+ // It may require modifications to work in your environment.
+ AccessApprovalAdminSettings accessApprovalAdminSettings =
+ AccessApprovalAdminSettings.newBuilder()
+ .setTransportChannelProvider(
+ AccessApprovalAdminSettings.defaultHttpJsonTransportProviderBuilder().build())
+ .build();
+ AccessApprovalAdminClient accessApprovalAdminClient =
+ AccessApprovalAdminClient.create(accessApprovalAdminSettings);
+ }
+}
+// [END accessapproval_v1_generated_accessapprovaladminclient_create_setcredentialsprovider1_sync]