/**
- * Copyright 2018-2020 ZTE Corporation.
- *
+ * Copyright 2018-2021 ZTE Corporation.
+ * <p>
* 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
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
+ * <p>
+ * http://www.apache.org/licenses/LICENSE-2.0
+ * <p>
* 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.
*/
package org.onap.holmes.common.utils;
-import com.google.gson.Gson;
-import com.google.gson.GsonBuilder;
-import com.google.gson.JsonDeserializer;
-import com.google.gson.JsonObject;
+import com.google.gson.*;
import com.google.gson.reflect.TypeToken;
import org.apache.commons.lang3.StringUtils;
+import java.util.Date;
import java.util.List;
import java.util.Map;
return 0;
}
})
+ .registerTypeAdapter(Date.class, (JsonDeserializer<Date>) (jsonElement, type, jsonDeserializationContext) -> {
+ try {
+ return jsonElement == null ? null : new Date(jsonElement.getAsLong());
+ } catch (NumberFormatException e) {
+ return null;
+ }
+ })
+ .registerTypeAdapter(Date.class, (JsonSerializer<Date>) (date, type, jsonSerializationContext)
+ -> date == null ? null : new JsonPrimitive(date.getTime()))
.create();
}
}
List<Map<String, T>> list = null;
if (gson != null) {
list = gson.fromJson(gsonString,
- TypeToken.getParameterized(List.class,
- TypeToken.getParameterized(Map.class, String.class, cls).getType()
- ).getType()
+ TypeToken.getParameterized(List.class,
+ TypeToken.getParameterized(Map.class, String.class, cls).getType()
+ ).getType()
);
}
return list;
public class CommonUtilsTest {
@Test
- public void isHttpsEnabled_normal_true() throws Exception {
+ public void isHttpsEnabled_normal_true() {
System.setProperty("ENABLE_ENCRYPT", "true");
assertThat(CommonUtils.isHttpsEnabled(), is(true));
}
@Test
- public void isHttpsEnabled_normal_false() throws Exception {
+ public void isHttpsEnabled_normal_false() {
System.setProperty("ENABLE_ENCRYPT", "false");
assertThat(CommonUtils.isHttpsEnabled(), is(false));
}
@Test
- public void isHttpsEnabled_invalid_input() throws Exception {
+ public void isHttpsEnabled_invalid_input() {
System.setProperty("ENABLE_ENCRYPT", "whatever");
assertThat(CommonUtils.isHttpsEnabled(), is(false));
}
@Test
- public void getEnv() throws Exception {
+ public void getEnv() {
System.setProperty("TEST", "COMMON_UTILS");
assertThat(CommonUtils.getEnv("TEST"), equalTo("COMMON_UTILS"));
}
@Test
- public void isValidIpAddress_with_port() throws Exception {
+ public void isValidIpAddress_with_port() {
boolean res = CommonUtils.isIpAddress("10.75.13.21:90");
assertThat(res, is(true));
}
@Test
- public void isValidIpAddress_without_port() throws Exception {
+ public void isValidIpAddress_without_port() {
boolean res = CommonUtils.isIpAddress("10.75.13.21");
assertThat(res, is(true));
}
@Test
- public void isValidIpAddress_with_port_with_http_prefix() throws Exception {
+ public void isValidIpAddress_with_port_with_http_prefix() {
boolean res = CommonUtils.isIpAddress("http://10.75.13.21:90");
assertThat(res, is(true));
}
@Test
- public void isValidIpAddress_without_port_with_https_prefix() throws Exception {
+ public void isValidIpAddress_without_port_with_https_prefix() {
boolean res = CommonUtils.isIpAddress("https://10.75.13.21");
assertThat(res, is(true));
}
@Test
- public void isValidIpAddress_invalid_ip_without_port() throws Exception {
+ public void isValidIpAddress_invalid_ip_without_port() {
boolean res = CommonUtils.isIpAddress("holmes-rule-mgmt");
assertThat(res, is(false));
}
@Test
- public void isValidIpAddress_invalid_ip_with_port() throws Exception {
+ public void isValidIpAddress_invalid_ip_with_port() {
boolean res = CommonUtils.isIpAddress("holmes-rule-mgmt:443");
assertThat(res, is(false));
}
@Test
- public void isValidIpAddress_invalid_ip_without_port_with_http_prefix() throws Exception {
+ public void isValidIpAddress_invalid_ip_without_port_with_http_prefix() {
boolean res = CommonUtils.isIpAddress("http://holmes-rule-mgmt");
assertThat(res, is(false));
}
@Test
- public void isValidIpAddress_invalid_ip_with_port_with_https_prefix() throws Exception {
+ public void isValidIpAddress_invalid_ip_with_port_with_https_prefix() {
boolean res = CommonUtils.isIpAddress("https://holmes-rule-mgmt:443");
assertThat(res, is(false));
}
package org.onap.holmes.common.utils;
-import com.google.gson.Gson;
-import com.google.gson.JsonParser;
+import com.google.gson.*;
import org.junit.Test;
import java.util.Arrays;
+import java.util.Date;
import java.util.List;
import java.util.Map;
public class GsonUtilTest {
- private final TestBean bean1 = new TestBean("onap1", 10, 10f, 10d);
- private final TestBean bean2 = new TestBean("onap2", 20, 20f, 20d);
- private final Gson gson = new Gson();
+ private final TestBean bean1;
+ private final TestBean bean2;
+ private final Gson gson = buildGson();
+ private Date date;
+
+ public GsonUtilTest() {
+ date = new Date();
+ bean1 = new TestBean("onap1", 10, 10f, 10d, date);
+ bean2 = new TestBean("onap2", 20, 20f, 20d, date);
+ }
@Test
public void beanToJson() {
assertThat(expected.getInteger(), equalTo(actual.getInteger()));
assertThat(expected.getaDouble(), equalTo(actual.getaDouble()));
assertThat(expected.getaFloat(), equalTo(actual.getaFloat()));
+ assertThat(expected.getaDate(), equalTo(actual.getaDate()));
}
@Test
@Test
public void jsonToListMaps() {
+ long timestamp = date.getTime();
List<Map<String, TestBean>> actual = GsonUtil.jsonToListMaps(
- "[{\"onap1\":{\"string\":\"onap1\",\"integer\":10,\"aFloat\":10.0,\"aDouble\":10.0}},"
- + "{\"onap2\":{\"string\":\"onap2\",\"integer\":20,\"aFloat\":20.0,\"aDouble\":20.0}}]", TestBean.class);
+ String.format("[{\"onap1\":{\"string\":\"onap1\",\"integer\":10,\"aFloat\":10.0,\"aDouble\":10.0,\"aDate\": %d}},", timestamp)
+ + String.format("{\"onap2\":{\"string\":\"onap2\",\"integer\":20,\"aFloat\":20.0,\"aDouble\":20.0,\"aDate\": \"%s\"}}]", timestamp), TestBean.class);
- assertThat(actual.get(0).get("onap1"), equalTo(new TestBean("onap1", 10, 10f, 10d)));
- assertThat(actual.get(1).get("onap2"), equalTo(new TestBean("onap2", 20, 20f, 20d)));
+ assertThat(actual.get(0).get("onap1"), equalTo(new TestBean("onap1", 10, 10f, 10d, date)));
+ assertThat(actual.get(1).get("onap2"), equalTo(new TestBean("onap2", 20, 20f, 20d, date)));
}
@Test
public void jsonToMap() {
Map<String, TestBean> actual = GsonUtil
- .jsonToMap("{\"onap1\":{\"string\":\"onap1\",\"integer\":10,\"aFloat\":10.0,\"aDouble\":10.0}}", TestBean.class);
- assertThat(actual.get("onap1"), equalTo(new TestBean("onap1", 10, 10f, 10d)));
+ .jsonToMap(String.format("{\"onap1\":{\"string\":\"onap1\",\"integer\":10,\"aFloat\":10.0,\"aDouble\":10.0,\"aDate\":%d}}",date.getTime()), TestBean.class);
+ assertThat(actual.get("onap1"), equalTo(new TestBean("onap1", 10, 10f, 10d, date)));
}
@Test
assertThat(10,
is(GsonUtil.getAsInt(JsonParser.parseString(GsonUtil.beanToJson(bean1)).getAsJsonObject(),"integer")));
}
+
+ private Gson buildGson() {
+ return new GsonBuilder()
+ .registerTypeAdapter(Integer.class, (JsonDeserializer<Integer>) (json, typeOfT, context) -> {
+ try {
+ return json.getAsInt();
+ } catch (NumberFormatException e) {
+ return 0;
+ }
+ })
+ .registerTypeAdapter(Date.class, (JsonDeserializer<Date>) (jsonElement, type, jsonDeserializationContext) -> {
+ try {
+ return jsonElement == null ? null : new Date(jsonElement.getAsLong());
+ } catch (NumberFormatException e) {
+ return null;
+ }
+ })
+ .registerTypeAdapter(Date.class, (JsonSerializer<Date>) (date, type, jsonSerializationContext)
+ -> date == null ? null : new JsonPrimitive(date.getTime()))
+ .create();
+ }
}
class TestBean {
private int integer;
private float aFloat;
private double aDouble;
+ private Date aDate;
- public TestBean(String string, int integer, float aFloat, double aDouble) {
+ public TestBean(String string, int integer, float aFloat, double aDouble, Date aDate) {
this.string = string;
this.integer = integer;
this.aFloat = aFloat;
this.aDouble = aDouble;
+ this.aDate = aDate;
}
public String getString() {
return aDouble;
}
+ public Date getaDate(){ return aDate;}
+
@Override
public boolean equals(Object o) {
if (o == null || ! (o instanceof TestBean)) {
return string.equals(((TestBean) o).string)
&& integer == ((TestBean) o).integer
&& aDouble == ((TestBean) o).aDouble
- && aFloat == ((TestBean) o).aFloat;
+ && aFloat == ((TestBean) o).aFloat
+ && ((aDate == null && ((TestBean)o).aDate == null) || aDate.equals(((TestBean)o).aDate));
}
@Override