From 558eb8fc1392428dbabc4d6016713bff99d6425f Mon Sep 17 00:00:00 2001 From: Hima Elisetty Date: Wed, 7 Feb 2018 17:12:02 -0500 Subject: Added Junits Issue-ID: PORTAL-136, PORTAL-188 Includes FW mode central changes Change-Id: Iba6c0d48ed768e32d1fe4700d0044eb7f3fdc482 Signed-off-by: Hima Elisetty --- .../controller/ElasticSearchControllerTest.java | 145 +++++++++++++++++++++ 1 file changed, 145 insertions(+) create mode 100644 ecomp-sdk/epsdk-app-common/src/test/java/org/onap/portalapp/controller/ElasticSearchControllerTest.java (limited to 'ecomp-sdk/epsdk-app-common/src/test/java/org/onap/portalapp/controller/ElasticSearchControllerTest.java') diff --git a/ecomp-sdk/epsdk-app-common/src/test/java/org/onap/portalapp/controller/ElasticSearchControllerTest.java b/ecomp-sdk/epsdk-app-common/src/test/java/org/onap/portalapp/controller/ElasticSearchControllerTest.java new file mode 100644 index 00000000..7a0d47cd --- /dev/null +++ b/ecomp-sdk/epsdk-app-common/src/test/java/org/onap/portalapp/controller/ElasticSearchControllerTest.java @@ -0,0 +1,145 @@ +/* + * ============LICENSE_START========================================== + * ONAP Portal SDK + * =================================================================== + * Copyright © 2017 AT&T Intellectual Property. All rights reserved. + * =================================================================== + * + * Unless otherwise specified, all software contained herein is licensed + * under the Apache License, Version 2.0 (the "License"); + * you may not use this software except in compliance with the License. + * You may obtain a copy of the License at + * + * http://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. + * + * Unless otherwise specified, all documentation contained herein is licensed + * under the Creative Commons License, Attribution 4.0 Intl. (the "License"); + * you may not use this documentation except in compliance with the License. + * You may obtain a copy of the License at + * + * https://creativecommons.org/licenses/by/4.0/ + * + * Unless required by applicable law or agreed to in writing, documentation + * 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. + * + * ============LICENSE_END============================================ + * + * ECOMP is a trademark and service mark of AT&T Intellectual Property. + */ +package org.onap.portalapp.controller; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +import java.io.IOException; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; + +import org.junit.Before; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.mockito.InjectMocks; +import org.mockito.Matchers; +import org.mockito.Mock; +import org.mockito.Mockito; +import org.mockito.MockitoAnnotations; +import org.onap.portalapp.controller.sample.ElasticSearchController; +import org.onap.portalapp.framework.MockitoTestSuite; +import org.onap.portalapp.model.Result; +import org.powermock.api.mockito.PowerMockito; +import org.powermock.core.classloader.annotations.PrepareForTest; +import org.powermock.modules.junit4.PowerMockRunner; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.servlet.ModelAndView; + +import com.google.gson.Gson; + +import io.searchbox.core.SearchResult; + +import io.searchbox.client.JestClient; +import io.searchbox.client.JestClientFactory; +import io.searchbox.client.config.HttpClientConfig; +import io.searchbox.client.http.JestHttpClient; + + +@RunWith(PowerMockRunner.class) +@PrepareForTest({ JestClientFactory.class, JestClient.class }) +public class ElasticSearchControllerTest { + + @InjectMocks + ElasticSearchController elasticSearchController = new ElasticSearchController(); + + @Before + public void setup() { + MockitoAnnotations.initMocks(this); + } + @Mock + JestClientFactory factory; + @Mock + JestClient client ; + + MockitoTestSuite mockitoTestSuite = new MockitoTestSuite(); + HttpServletRequest mockedRequest = mockitoTestSuite.getMockedRequest(); + HttpServletResponse mockedResponse = mockitoTestSuite.getMockedResponse(); + + @Test + public void searchTest() + { + ModelAndView expectedResult = elasticSearchController.search(); + assertEquals(expectedResult.getViewName(), "es_search_demo"); + } + + @Test + public void suggestTest() + { + ModelAndView expectedResult = elasticSearchController.suggest(); + assertEquals(expectedResult.getViewName(), "es_suggest_demo"); + } + +// @Test +// public void doSuggestTest() throws IOException +// { +// PowerMockito.mockStatic(JestClient.class); +// PowerMockito.mockStatic(JestClientFactory.class); +// SearchResult result = new SearchResult(new Gson()); +// Mockito.when(factory.getObject()).thenReturn(client); +// Mockito.when(client.execute(Matchers.anyObject())).thenReturn(result); +//// Mockito.doNothing().when(factory).setHttpClientConfig(new HttpClientConfig +//// .Builder(Matchers.anyString()) +//// .multiThreaded(Matchers.anyBoolean()) +//// .build()); +// +// JestClientFactory factory = Mockito.spy(new JestClientFactory()); +// HttpClientConfig httpClientConfig = Mockito.spy(new HttpClientConfig.Builder("http://localhost:9200") +// .discoveryEnabled(true) +// .build()); +// factory.setHttpClientConfig(httpClientConfig); +// JestHttpClient jestClient = (JestHttpClient) factory.getObject(); +// +// elasticSearchController.doSearch("{\"data\":\"1\",\"size\":\"1\"}"); +// } + + @Test + public void sendResultTest() + { + ResponseEntity result = elasticSearchController.sendResult(null); + assertEquals(result.getStatusCode(), HttpStatus.OK); + } + + @Test + public void isRestFultest() + { + assertTrue(elasticSearchController.isRESTfulCall()); + } +} -- cgit 1.2.3-korg