1 package org.onap.vid.api;
3 import static java.util.Collections.singletonList;
4 import static net.javacrumbs.jsonunit.JsonMatchers.jsonEquals;
5 import static net.javacrumbs.jsonunit.core.Option.IGNORING_ARRAY_ORDER;
6 import static org.apache.commons.text.StringEscapeUtils.unescapeJson;
7 import static org.hamcrest.MatcherAssert.assertThat;
8 import static org.hamcrest.Matchers.isEmptyOrNullString;
9 import static org.hamcrest.Matchers.not;
11 //import com.automation.common.report_portal_integration.listeners.ReportPortalListener;
12 import com.fasterxml.jackson.core.JsonProcessingException;
13 import com.fasterxml.jackson.databind.ObjectMapper;
14 import com.fasterxml.jackson.databind.SerializationFeature;
15 import java.io.IOException;
16 import java.io.InputStream;
19 import java.util.List;
20 import java.util.Properties;
21 import java.util.Random;
22 import java.util.TimeZone;
23 import javax.ws.rs.client.Client;
24 import javax.ws.rs.client.ClientBuilder;
25 import org.apache.commons.io.IOUtils;
26 import org.apache.logging.log4j.LogManager;
27 import org.apache.logging.log4j.Logger;
28 import org.glassfish.jersey.client.ClientProperties;
29 import org.glassfish.jersey.uri.internal.JerseyUriBuilder;
30 import org.onap.sdc.ci.tests.datatypes.UserCredentials;
31 import org.springframework.http.client.ClientHttpRequestInterceptor;
32 import org.springframework.http.client.ClientHttpResponse;
33 import org.springframework.web.client.DefaultResponseErrorHandler;
34 import org.springframework.web.client.HttpStatusCodeException;
35 import org.springframework.web.client.RestTemplate;
36 import org.testng.annotations.BeforeClass;
37 import org.testng.annotations.Listeners;
38 import vid.automation.reportportal.ReportPortalListenerDelegator;
39 import vid.automation.test.infra.FeaturesTogglingConfiguration;
40 import vid.automation.test.services.UsersService;
41 import vid.automation.test.utils.CookieAndJsonHttpHeadersInterceptor;
43 @Listeners(ReportPortalListenerDelegator.class)
44 public class BaseApiTest {
45 protected static final Logger LOGGER = LogManager.getLogger(BaseApiTest.class);
47 @SuppressWarnings("WeakerAccess")
49 @SuppressWarnings("WeakerAccess")
50 protected ObjectMapper objectMapper = new ObjectMapper();
51 @SuppressWarnings("WeakerAccess")
52 protected Client client;
53 protected Random random;
54 protected final RestTemplate restTemplate = new RestTemplate();
56 protected final UsersService usersService = new UsersService();
57 protected final RestTemplate restTemplateErrorAgnostic = new RestTemplate();
62 objectMapper.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false);
63 client = ClientBuilder.newClient();
64 client.property(ClientProperties.SUPPRESS_HTTP_COMPLIANCE_VALIDATION, true);
65 random = new Random(System.currentTimeMillis());
66 FeaturesTogglingConfiguration.initializeFeatureManager();
69 private URI getUri() {
70 String host = System.getProperty("VID_HOST", "127.0.0.1");
71 int port = Integer.valueOf(System.getProperty("VID_PORT", "8080"));
72 return new JerseyUriBuilder().host(host).port(port).scheme("http").path("vid").build();
76 login(getUserCredentials());
79 public void login(UserCredentials userCredentials) {
80 final List<ClientHttpRequestInterceptor> interceptors = loginWithChosenRESTClient(userCredentials, restTemplate);
81 restTemplateErrorAgnostic.setInterceptors(interceptors);
82 restTemplateErrorAgnostic.setErrorHandler(new DefaultResponseErrorHandler() {
84 public boolean hasError(ClientHttpResponse response) {
90 public List<ClientHttpRequestInterceptor> loginWithChosenRESTClient(UserCredentials userCredentials,RestTemplate givenRestTemplate) {
91 final List<ClientHttpRequestInterceptor> interceptors = singletonList(new CookieAndJsonHttpHeadersInterceptor(getUri(), userCredentials));
92 givenRestTemplate.setInterceptors(interceptors);
93 givenRestTemplate.setErrorHandler(new DefaultResponseErrorHandler() {
95 public void handleError(ClientHttpResponse response) throws IOException {
97 super.handleError(response);
98 } catch (HttpStatusCodeException e) {
99 LOGGER.error("HTTP {}: {}", e.getStatusCode(), e.getResponseBodyAsString(), e);
108 //set time zone to UTC so clock will go closely with VID app
110 public void setDefaultTimeZoneToUTC() {
111 System.setProperty("user.timezone", "UTC");
112 TimeZone.setDefault(TimeZone.getTimeZone("UTC")); //since TimeZone cache previous user.timezone
115 public UserCredentials getUserCredentials() {
116 final Properties configProp = new Properties();
118 InputStream input = ClassLoader.getSystemResourceAsStream("test_config.properties");
119 configProp.load(input);
120 } catch (IOException e) {
121 throw new RuntimeException(e);
124 String loginId = configProp.getProperty("test.loginId", "i'm illegal");
125 String loginPassword = configProp.getProperty("test.loginPassword", "i'm illegal");
126 return new UserCredentials(loginId, loginPassword, null, null, null);
132 protected String getCleanJsonString(String jsonString) {
133 // remove leading/trailing double-quotes and unescape
134 String res = unescapeJson(jsonString.replaceAll("^\"|\"$", ""));
135 LOGGER.debug("getCleanJsonString: " + jsonString + " ==> " + res);
139 protected String getCleanJsonString(Object object) throws JsonProcessingException {
140 if (object instanceof String) {
141 return getCleanJsonString((String) object);
143 return new com.fasterxml.jackson.databind.ObjectMapper().writeValueAsString(object);
147 protected String buildUri(String path) {
148 return uri + "/" + path;
151 public static String getResourceAsString(String resourcePath) {
152 // load expected result
153 final URL resource = BaseApiTest.class.getClassLoader().getResource(resourcePath);
154 if (resource == null) throw new RuntimeException("resource file not found: " + resourcePath);
156 return IOUtils.toString(resource, "UTF-8");
157 } catch (IOException e) {
158 throw new RuntimeException(e);
162 protected void assertJsonEquals(String actual, String expected) {
164 assertThat(actual, not(isEmptyOrNullString()));
166 assertThat(actual, jsonEquals(expected)
167 .when(IGNORING_ARRAY_ORDER)