[ODTN]Add UnitTest for OPENCONFIG Handler
Change-Id: Ifc07c45abbc2d8d81f7d50f8ba2c8a3188ae377a
diff --git a/apps/odtn/api/src/test/java/org/onosproject/odtn/utils/openconfig/OpenConfigComponentsHandlerTest.java b/apps/odtn/api/src/test/java/org/onosproject/odtn/utils/openconfig/OpenConfigComponentsHandlerTest.java
new file mode 100755
index 0000000..9045c16
--- /dev/null
+++ b/apps/odtn/api/src/test/java/org/onosproject/odtn/utils/openconfig/OpenConfigComponentsHandlerTest.java
@@ -0,0 +1,191 @@
+/*
+ * Copyright 2018-present Open Networking Foundation
+ *
+ * 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.onosproject.odtn.utils.openconfig;
+
+import java.lang.reflect.Field;
+import java.util.ArrayList;
+import java.util.List;
+import org.junit.Assert;
+import org.junit.Before;
+import org.junit.Test;
+import org.onosproject.yang.model.ResourceId;
+import org.onosproject.yang.runtime.AnnotatedNodeInfo;
+
+import org.onosproject.yang.gen.v1.openconfigplatform.rev20180603.openconfigplatform.platformcomponenttop.components.DefaultComponent;
+import org.onosproject.yang.gen.v1.openconfigplatform.rev20180603.openconfigplatform.platformcomponenttop.DefaultComponents;
+
+import static org.junit.Assert.assertEquals;
+
+/**
+ * UnitTest class for OpenConfigComponentsHandler.
+ */
+public class OpenConfigComponentsHandlerTest {
+ // expected ResourceId
+ ResourceId rid;
+
+ /**
+ * Set up method for UnitTest.
+ */
+ @Before
+ public void setUp() {
+ // expected ResourceId set up
+ rid = ResourceId.builder()
+ .addBranchPointSchema("components", "http://openconfig.net/yang/platform")
+ .build();
+ }
+
+ /**
+ * UnitTest method for getModelObject.
+ */
+ @Test
+ public void testGetModelObject() {
+ // test Handler
+ OpenConfigComponentsHandler components = new OpenConfigComponentsHandler();
+
+ // expected ModelObject
+ DefaultComponents modelObject = new DefaultComponents();
+
+ assertEquals("[NG]getModelObject:Return is not an expected ModelObject.\n",
+ modelObject, components.getModelObject());
+ }
+
+ /**
+ * UnitTest method for setResourceId.
+ */
+ @Test
+ public void testSetResourceId() {
+ // call setResourceId
+ OpenConfigComponentsHandler components = new OpenConfigComponentsHandler();
+
+ // get resourceId
+ ResourceId resourceId = null;
+ try {
+ Field field = OpenConfigObjectHandler.class.getDeclaredField("resourceId");
+ field.setAccessible(true);
+ resourceId = (ResourceId) field.get(components);
+ } catch (NoSuchFieldException e) {
+ Assert.fail("[NG]setResourceId:ResourceId does not exist.\n" + e);
+ } catch (IllegalAccessException e) {
+ Assert.fail("[NG]setResourceId:Access to ResourceId is illegal.\n" + e);
+ }
+
+ assertEquals("[NG]setResourceId:Set ResourceId is not an expected one.\n",
+ rid, resourceId);
+ }
+
+ /**
+ * UnitTest method for getResourceId.
+ */
+ @Test
+ public void testGetResourceId() {
+ // test Handler
+ OpenConfigComponentsHandler components = new OpenConfigComponentsHandler();
+
+ assertEquals("[NG]getResourceId:Return is not an expected ResourceId.\n",
+ rid, components.getResourceId());
+ }
+
+ /**
+ * UnitTest method for getResourceIdBuilder.
+ */
+ @Test
+ public void testGetResourceIdBuilder() {
+ // test Handler
+ OpenConfigComponentsHandler components = new OpenConfigComponentsHandler();
+
+ assertEquals("[NG]getResourceIdBuilder:Return is not an expected ResourceIdBuilder.\n",
+ rid, components.getResourceIdBuilder().build());
+ }
+
+ /**
+ * UnitTest method for addAnnotation.
+ */
+ @Test
+ public void testAddAnnotation() {
+ // test Handler
+ OpenConfigComponentsHandler components = new OpenConfigComponentsHandler();
+
+ // call addAnnotation
+ components.addAnnotation("name", "value");
+
+ // get annotatedNodeInfos
+ List<AnnotatedNodeInfo> annotatedNodeInfos = new ArrayList<AnnotatedNodeInfo>();
+ try {
+ Field field = OpenConfigObjectHandler.class.getDeclaredField("annotatedNodeInfos");
+ field.setAccessible(true);
+ annotatedNodeInfos = (List<AnnotatedNodeInfo>) field.get(components);
+ } catch (NoSuchFieldException e) {
+ Assert.fail("[NG]addAnnotation:List of AnnotatedNodeInfo does not exist.\n" + e);
+ } catch (IllegalAccessException e) {
+ Assert.fail("[NG]addAnnotation:Access to list of AnnotatedNodeInfo is illegal.\n" + e);
+ }
+
+ assertEquals("[NG]addAnnotation:List size of AnnotatedNodeInfo is invalid.\n",
+ 1, annotatedNodeInfos.size());
+ assertEquals("[NG]addAnnotation:ResourceId of AnnotatedNodeInfo is not an expected one.\n",
+ rid, annotatedNodeInfos.get(0).resourceId());
+ assertEquals("[NG]addAnnotation:List size of Annotation is invalid.\n",
+ 1, annotatedNodeInfos.get(0).annotations().size());
+ assertEquals("[NG]addAnnotation:Name of Annotation is not an expected one.\n",
+ "name", annotatedNodeInfos.get(0).annotations().get(0).name());
+ assertEquals("[NG]addAnnotation:Value of Annotation is not an expected one.\n",
+ "value", annotatedNodeInfos.get(0).annotations().get(0).value());
+ }
+
+ /**
+ * UnitTest method for getAnnotatedNodeInfoList.
+ */
+ @Test
+ public void testGetAnnotatedNodeInfoList() {
+ // test Handler
+ OpenConfigComponentsHandler components = new OpenConfigComponentsHandler();
+
+ // set list of AnnotatedNodeInfo
+ components.addAnnotation("name", "value");
+
+ assertEquals("[NG]getAnnotatedNodeInfoList:List size of AnnotatedNodeInfo is invalid.\n",
+ 1, components.getAnnotatedNodeInfoList().size());
+ assertEquals("[NG]getAnnotatedNodeInfoList:ResourceId of AnnotatedNodeInfo is not an expected one.\n",
+ rid, components.getAnnotatedNodeInfoList().get(0).resourceId());
+ assertEquals("[NG]getAnnotatedNodeInfoList:List size of Annotation is invalid.\n",
+ 1, components.getAnnotatedNodeInfoList().get(0).annotations().size());
+ assertEquals("[NG]getAnnotatedNodeInfoList:Name of Annotation is not an expected one.\n",
+ "name", components.getAnnotatedNodeInfoList().get(0).annotations().get(0).name());
+ assertEquals("[NG]getAnnotatedNodeInfoList:Value of Annotation is not an expected one.\n",
+ "value", components.getAnnotatedNodeInfoList().get(0).annotations().get(0).value());
+ }
+
+ /**
+ * UnitTest method for addComponent.
+ */
+ @Test
+ public void testAddComponent() {
+ // test Handler
+ OpenConfigComponentsHandler components = new OpenConfigComponentsHandler();
+
+ // call addComponent
+ OpenConfigComponentHandler component = new OpenConfigComponentHandler("name", components);
+
+ // expected ModelObject
+ DefaultComponents modelObject = new DefaultComponents();
+ DefaultComponent comp = new DefaultComponent();
+ comp.name("name");
+ modelObject.addToComponent(comp);
+
+ assertEquals("[NG]addComponent:ModelObject(Component added) is not an expected one.\n",
+ modelObject, components.getModelObject());
+ }
+}