2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2020 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.onap.policy.controlloop.actor.test;
23 import static org.mockito.ArgumentMatchers.any;
24 import static org.mockito.Mockito.when;
27 import java.util.concurrent.CompletableFuture;
28 import javax.ws.rs.client.AsyncInvoker;
29 import javax.ws.rs.client.Entity;
30 import javax.ws.rs.client.Invocation.Builder;
31 import javax.ws.rs.client.InvocationCallback;
32 import javax.ws.rs.client.WebTarget;
33 import javax.ws.rs.core.MediaType;
34 import javax.ws.rs.core.Response;
35 import org.mockito.ArgumentCaptor;
36 import org.mockito.Captor;
37 import org.mockito.Mock;
38 import org.mockito.stubbing.Answer;
39 import org.onap.policy.common.endpoints.http.client.HttpClient;
40 import org.onap.policy.common.endpoints.http.client.HttpClientFactory;
41 import org.onap.policy.controlloop.actorserviceprovider.parameters.HttpConfig;
44 * Superclass for various HttpOperation tests.
46 * @param <Q> request type
48 public class BasicHttpOperation<Q> extends BasicOperation {
49 protected static final String MY_CLIENT = "my-client";
50 protected static final String BASE_URI = "/base-uri";
51 protected static final String PATH = "/my-path";
54 protected ArgumentCaptor<InvocationCallback<Response>> callbackCaptor;
56 protected ArgumentCaptor<Entity<Q>> requestCaptor;
58 protected ArgumentCaptor<Map<String, Object>> headerCaptor;
61 protected HttpConfig config;
63 protected WebTarget webTarget;
65 protected Builder webBuilder;
67 protected AsyncInvoker webAsync;
69 protected HttpClient client;
71 protected HttpClientFactory factory;
73 protected Response rawResponse;
77 * Constructs the object using a default actor and operation name.
79 public BasicHttpOperation() {
84 * Constructs the object.
86 * @param actor actor name
87 * @param operation operation name
89 public BasicHttpOperation(String actor, String operation) {
90 super(actor, operation);
94 * Initializes mocks and sets up.
97 public void setUpBasic() {
100 when(factory.get(MY_CLIENT)).thenReturn(client);
102 when(rawResponse.getStatus()).thenReturn(200);
104 when(webBuilder.async()).thenReturn(webAsync);
105 when(webBuilder.accept(any(MediaType.class))).thenReturn(webBuilder);
106 when(webBuilder.accept(any(String.class))).thenReturn(webBuilder);
108 when(webTarget.request()).thenReturn(webBuilder);
109 when(webTarget.path(any())).thenReturn(webTarget);
110 when(webTarget.queryParam(any(), any())).thenReturn(webTarget);
112 when(client.getWebTarget()).thenReturn(webTarget);
114 when(client.getBaseUrl()).thenReturn(BASE_URI);
120 * Initializes a configuration.
122 protected void initConfig() {
123 when(config.getClient()).thenReturn(client);
124 when(config.getPath()).thenReturn(PATH);
128 * Provides a response to an asynchronous HttpClient call.
130 * @param response response to be provided to the call
131 * @return a function that provides the response to the call
133 protected Answer<CompletableFuture<Response>> provideResponse(Response response) {
134 return provideResponse(response, 0);
138 * Provides a response to an asynchronous HttpClient call.
140 * @param response response to be provided to the call
141 * @param index index of the callback within the arguments
142 * @return a function that provides the response to the call
144 protected Answer<CompletableFuture<Response>> provideResponse(Response response, int index) {
146 InvocationCallback<Response> cb = args.getArgument(index);
147 cb.completed(response);
148 return CompletableFuture.completedFuture(response);