From 3f1f8de8efb9019e613927697acce40f41dc8d16 Mon Sep 17 00:00:00 2001 From: HuabingZhao Date: Mon, 9 Oct 2017 19:20:42 +0800 Subject: Unit test for MSB JAVA SDK Issue-Id: MSB-86 Change-Id: I1a3458e5a75121ceb895c1aa832007609762dae5 Signed-off-by: HuabingZhao --- .../msb/sdk/discovery/util/HttpClientUtilTest.java | 72 ++++++++++++++++++++++ .../sdk/discovery/util/JacksonJsonUtilTest.java | 49 +++++++++++++++ .../msb/sdk/discovery/util/RegExpTestUtilTest.java | 71 +++++++++++++++++++++ 3 files changed, 192 insertions(+) create mode 100644 src/test/java/org/onap/msb/sdk/discovery/util/HttpClientUtilTest.java create mode 100644 src/test/java/org/onap/msb/sdk/discovery/util/JacksonJsonUtilTest.java create mode 100644 src/test/java/org/onap/msb/sdk/discovery/util/RegExpTestUtilTest.java (limited to 'src/test/java/org/onap/msb/sdk/discovery/util') diff --git a/src/test/java/org/onap/msb/sdk/discovery/util/HttpClientUtilTest.java b/src/test/java/org/onap/msb/sdk/discovery/util/HttpClientUtilTest.java new file mode 100644 index 0000000..b06b50c --- /dev/null +++ b/src/test/java/org/onap/msb/sdk/discovery/util/HttpClientUtilTest.java @@ -0,0 +1,72 @@ +/** + * Copyright 2016-2017 ZTE, Inc. and others. + * + * 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 + * + * 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. + */ + +package org.onap.msb.sdk.discovery.util; + +import org.junit.Assert; +import org.junit.Test; +import org.onap.msb.sdk.discovery.common.RouteException; + + + +public class HttpClientUtilTest { + + private String testIp = "http://127.0.0.1:8500"; + private String errorIp = "http://127.0.0.3:8500"; + + @Test + public void test_httpGet_fail() { + try { + Assert.assertNull(HttpClientUtil.httpGet(errorIp)); + } catch (Exception e) { + Assert.assertTrue(e instanceof RouteException); + } + } + + @Test + public void test_httpdelete() { + try { + HttpClientUtil.delete(testIp, "service"); + + } catch (Exception e) { + Assert.assertTrue(e instanceof RouteException); + } + } + + @Test + public void test_httpPostWithJSON() { + String url = testIp + "/v1/catalog/service"; + String json = "[{\"Node\":\"server\",\"Address\":\"127.0.0.1\",\"TaggedAddresses\":{\"lan\":\"127.0.0.1\",\"wan\":\"127.0.0.1\"},\"ServiceID\":\"_CJ-SNMP_10.74.216.65_12005\",\"ServiceName\":\"CJ-SNMP\",\"ServiceAddress\":\"10.74.216.65\",\"ServicePort\":12005,\"ServiceEnableTagOverride\":false,\"CreateIndex\":1813280,\"ModifyIndex\":1815062}]"; + + try { + HttpClientUtil.httpPostWithJSON(url, json); + Assert.assertEquals("Consul Agent", HttpClientUtil.httpGet(testIp)); + } catch (Exception e) { + Assert.assertTrue(e instanceof RouteException); + } + } + + @Test + public void test_httpPutWithJSON() { + String url = testIp + "/v1/catalog/service"; + String json = "[{\"Node\":\"server\",\"Address\":\"127.0.0.1\",\"TaggedAddresses\":{\"lan\":\"127.0.0.1\",\"wan\":\"127.0.0.1\"},\"ServiceID\":\"_CJ-SNMP_10.74.216.65_12005\",\"ServiceName\":\"CJ-SNMP\",\"ServiceAddress\":\"10.74.216.65\",\"ServicePort\":12005,\"ServiceEnableTagOverride\":false,\"CreateIndex\":1813280,\"ModifyIndex\":1815062}]"; + + try { + HttpClientUtil.httpPutWithJSON(url, json); + Assert.assertEquals("Consul Agent", HttpClientUtil.httpGet(testIp)); + } catch (Exception e) { + Assert.assertTrue(e instanceof RouteException); + } + } +} diff --git a/src/test/java/org/onap/msb/sdk/discovery/util/JacksonJsonUtilTest.java b/src/test/java/org/onap/msb/sdk/discovery/util/JacksonJsonUtilTest.java new file mode 100644 index 0000000..90f2fd5 --- /dev/null +++ b/src/test/java/org/onap/msb/sdk/discovery/util/JacksonJsonUtilTest.java @@ -0,0 +1,49 @@ +/** + * Copyright 2016-2017 ZTE, Inc. and others. + * + * 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 + * + * 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. + */ + +package org.onap.msb.sdk.discovery.util; + +import com.fasterxml.jackson.core.type.TypeReference; +import java.util.List; +import java.util.Map; + +import org.junit.Assert; +import org.junit.Test; +import org.onap.msb.sdk.discovery.entity.NodeAddress; + + +public class JacksonJsonUtilTest { + @Test + public void testBeanToJson() { + try { + NodeAddress address = new NodeAddress("127.0.0.1", "80"); + String json = JacksonJsonUtil.beanToJson(address); + Assert.assertEquals("{\"ip\":\"127.0.0.1\",\"port\":\"80\"}", json); + } catch (Exception e) { + Assert.fail("Exception" + e.getMessage()); + } + } + + @Test + public void testJsonToBean() { + try { + String json = "{\"ip\":\"127.0.0.1\",\"port\":\"80\"}"; + NodeAddress address = (NodeAddress) JacksonJsonUtil.jsonToBean(json, NodeAddress.class); + Assert.assertEquals("127.0.0.1", address.getIp()); + Assert.assertEquals("80", address.getPort()); + } catch (Exception e) { + Assert.fail("Exception" + e.getMessage()); + } + } +} diff --git a/src/test/java/org/onap/msb/sdk/discovery/util/RegExpTestUtilTest.java b/src/test/java/org/onap/msb/sdk/discovery/util/RegExpTestUtilTest.java new file mode 100644 index 0000000..1a6ff1f --- /dev/null +++ b/src/test/java/org/onap/msb/sdk/discovery/util/RegExpTestUtilTest.java @@ -0,0 +1,71 @@ +/** + * Copyright 2016-2017 ZTE, Inc. and others. + * + * 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 + * + * 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. + */ + +package org.onap.msb.sdk.discovery.util; + +import org.junit.Assert; +import org.junit.Test; + + + +public class RegExpTestUtilTest { + + @Test + public void testhostRegExpTest() { + Assert.assertTrue(RegExpTestUtil.hostRegExpTest("127.0.0.1:8080")); + + Assert.assertFalse(RegExpTestUtil.hostRegExpTest("0.0.0.1:89")); + } + + @Test + public void testipRegExpTest() { + + Assert.assertTrue(RegExpTestUtil.ipRegExpTest("10.74.151.26")); + + Assert.assertFalse(RegExpTestUtil.ipRegExpTest("0.74.0.26")); + } + + @Test + public void testportRegExpTest() { + Assert.assertTrue(RegExpTestUtil.portRegExpTest("8989")); + Assert.assertFalse(RegExpTestUtil.portRegExpTest("99999")); + } + + @Test + public void testversionRegExpTest() { + + Assert.assertTrue(RegExpTestUtil.versionRegExpTest("v1")); + + Assert.assertFalse(RegExpTestUtil.versionRegExpTest("vv2")); + } + + @Test + public void testurlRegExpTest() { + + Assert.assertTrue(RegExpTestUtil.urlRegExpTest("/test/v1")); + + Assert.assertTrue(RegExpTestUtil.urlRegExpTest("/")); + + Assert.assertFalse(RegExpTestUtil.urlRegExpTest("test/#?qwe")); + } + + @Test + public void testserviceNameRegExpTest() { + + Assert.assertTrue(RegExpTestUtil.serviceNameRegExpTest("servive_1")); + + + Assert.assertFalse(RegExpTestUtil.serviceNameRegExpTest("servive%_1")); + } +} -- cgit 1.2.3-korg