From d206edd8b89ddd251b24e635227fae2814b0152e Mon Sep 17 00:00:00 2001 From: Michal Kabaj Date: Tue, 13 Mar 2018 12:18:08 +0100 Subject: ChefAdapterImpl Junits -Added new Unit tests for ChefAdapterImpl#trigger method -Refactored ChefAdapterFactory to allow mock injection -Added new create() method to ChefApiClientFactory which does not set any Chef specific headers for the purpose of trigger method -Cleaned up the trigger method - simplified usage, removed useless doFailure method and inlined its logic and unified HttClient usage -> HttpClient is not used directly but through existing ChefApiClient -removed redundant TestChefAdapterImpl tests which have already been rewritten Change-Id: I830d203877224aa2c5e1b0dff39d1171f1f2f0ef Issue-ID: APPC-437 Signed-off-by: Michal Kabaj --- .../chef/chefclient/ChefApiClientFactory.java | 8 +++ .../appc/adapter/chef/impl/ChefAdapterFactory.java | 5 +- .../appc/adapter/chef/impl/ChefAdapterImpl.java | 59 ++++------------------ 3 files changed, 23 insertions(+), 49 deletions(-) (limited to 'appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main') diff --git a/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/chefclient/ChefApiClientFactory.java b/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/chefclient/ChefApiClientFactory.java index 1815266f3..11d820d5d 100644 --- a/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/chefclient/ChefApiClientFactory.java +++ b/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/chefclient/ChefApiClientFactory.java @@ -19,6 +19,7 @@ */ package org.onap.appc.adapter.chef.chefclient; +import com.google.common.collect.ImmutableMap; import org.apache.http.client.HttpClient; import org.apache.http.impl.client.HttpClients; import org.onap.appc.adapter.chef.chefclient.api.ChefApiClient; @@ -37,4 +38,11 @@ public class ChefApiClientFactory { (methodName, requestPath, body) -> chefApiHeaderFactory .create(methodName, requestPath, body, userId, organizations, pemPath)); } + + public ChefApiClient create(String endPoint) { + return new ChefApiClientImpl( + httpClient, + endPoint, + (methodName, requestPath, body) -> ImmutableMap.of()); + } } diff --git a/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterFactory.java b/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterFactory.java index 60c06bad4..ad45577b4 100644 --- a/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterFactory.java +++ b/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterFactory.java @@ -24,7 +24,10 @@ import org.onap.appc.adapter.chef.chefclient.ChefApiClientFactory; public class ChefAdapterFactory { + private ChefApiClientFactory chefApiClientFactory = new ChefApiClientFactory(); + private PrivateKeyChecker privateKeyChecker = new PrivateKeyChecker(); + public ChefAdapter create() { - return new ChefAdapterImpl(new ChefApiClientFactory(), new PrivateKeyChecker()); + return new ChefAdapterImpl(chefApiClientFactory, privateKeyChecker); } } diff --git a/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterImpl.java b/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterImpl.java index 0f4b8c8b3..9853bcff9 100644 --- a/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterImpl.java +++ b/appc-adapters/appc-chef-adapter/appc-chef-adapter-bundle/src/main/java/org/onap/appc/adapter/chef/impl/ChefAdapterImpl.java @@ -23,26 +23,20 @@ */ package org.onap.appc.adapter.chef.impl; +import com.att.eelf.configuration.EELFLogger; +import com.att.eelf.configuration.EELFManager; import java.util.Arrays; import java.util.List; import java.util.Map; import org.apache.commons.lang.StringUtils; -import org.apache.http.HttpEntity; -import org.apache.http.HttpResponse; -import org.apache.http.client.methods.HttpGet; -import org.apache.http.impl.client.CloseableHttpClient; -import org.apache.http.impl.client.HttpClients; -import org.apache.http.util.EntityUtils; import org.json.JSONException; import org.json.JSONObject; import org.onap.appc.adapter.chef.ChefAdapter; -import org.onap.appc.adapter.chef.chefclient.api.ChefApiClient; import org.onap.appc.adapter.chef.chefclient.ChefApiClientFactory; +import org.onap.appc.adapter.chef.chefclient.api.ChefApiClient; import org.onap.appc.adapter.chef.chefclient.api.ChefResponse; import org.onap.ccsdk.sli.core.sli.SvcLogicContext; import org.onap.ccsdk.sli.core.sli.SvcLogicException; -import com.att.eelf.configuration.EELFLogger; -import com.att.eelf.configuration.EELFManager; /** * This class implements the {@link ChefAdapter} interface. This interface defines the behaviors that our service @@ -545,23 +539,20 @@ public class ChefAdapterImpl implements ChefAdapter { * Trigger target vm run chef */ @Override - public void trigger(Map params, SvcLogicContext ctx) { + public void trigger(Map params, SvcLogicContext svcLogicContext) { logger.info("Run trigger method"); String tVmIp = params.get("ip"); - RequestContext rc = new RequestContext(ctx); + RequestContext rc = new RequestContext(svcLogicContext); rc.isAlive(); - try (CloseableHttpClient httpClient = HttpClients.createDefault()) { - HttpGet httpGet = new HttpGet(tVmIp); - HttpResponse response = httpClient.execute(httpGet); - int responseCode = response.getStatusLine().getStatusCode(); - HttpEntity entity = response.getEntity(); - String responseOutput = EntityUtils.toString(entity); - chefClientResult(rc, responseCode, responseOutput); - doSuccess(rc); + try { + ChefResponse chefResponse = chefApiClientFactory.create(tVmIp).get(""); + chefClientResult(rc, chefResponse.getStatusCode(), chefResponse.getBody()); + svcLogicContext.setAttribute("chefAgent.code", "200"); } catch (Exception e) { logger.error("An error occurred when executing trigger method", e); - doFailure(rc, 500, e.toString()); + svcLogicContext.setAttribute("chefAgent.code", "500"); + svcLogicContext.setAttribute("chefAgent.message", e.toString()); } } @@ -663,34 +654,6 @@ public class ChefAdapterImpl implements ChefAdapter { } } - @SuppressWarnings("static-method") - private void doFailure(RequestContext rc, int code, String message) { - SvcLogicContext svcLogic = rc.getSvcLogicContext(); - String msg = (message == null) ? Integer.toString(code) : message; - if (msg.contains("\n")) { - msg = msg.substring(msg.indexOf('\n')); - } - - String status; - try { - status = Integer.toString(code); - } catch (Exception e) { - status = "500"; - logger.error("Parsing status code failed. Setting it to \"500\"", e); - } - svcLogic.setAttribute("chefAgent.code", status); - svcLogic.setAttribute("chefAgent.message", msg); - } - - /** - * @param rc The request context that manages the state and recovery of the request for the life of its processing. - */ - @SuppressWarnings("static-method") - private void doSuccess(RequestContext rc) { - SvcLogicContext svcLogic = rc.getSvcLogicContext(); - svcLogic.setAttribute("chefAgent.code", "200"); - } - @SuppressWarnings("static-method") private void chefServerResult(RequestContext rc, int code, String message) { initSvcLogic(rc, code, message, "server"); -- cgit 1.2.3-korg