b.janani
Committed by Gerrit Code Review

UT for YANG translator utils

Change-Id: I1da6f7d6201f880c27885659e5e52edc3fccbdd6
1 +/*
2 + * Copyright 2016 Open Networking Laboratory
3 + *
4 + * Licensed under the Apache License, Version 2.0 (the "License");
5 + * you may not use this file except in compliance with the License.
6 + * You may obtain a copy of the License at
7 + *
8 + * http://www.apache.org/licenses/LICENSE-2.0
9 + *
10 + * Unless required by applicable law or agreed to in writing, software
11 + * distributed under the License is distributed on an "AS IS" BASIS,
12 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 + * See the License for the specific language governing permissions and
14 + * limitations under the License.
15 + */
16 +
17 +package org.onosproject.yangutils.translator.tojava.utils;
18 +
19 +import org.junit.Test;
20 +import org.onosproject.yangutils.translator.GeneratedFileType;
21 +import org.onosproject.yangutils.translator.tojava.GeneratedMethodTypes;
22 +import org.onosproject.yangutils.translator.tojava.TraversalType;
23 +import org.onosproject.yangutils.utils.UtilConstants;
24 +
25 +import java.lang.reflect.Constructor;
26 +import java.lang.reflect.InvocationTargetException;
27 +import static org.junit.Assert.assertNotNull;
28 +import static org.hamcrest.core.Is.is;
29 +import static org.junit.Assert.assertThat;
30 +
31 +/**
32 + * Unit tests for class definition generator for generated files.
33 + */
34 +public final class ClassDefinitionGeneratorTest {
35 +
36 + /**
37 + * Unit test for private constructor.
38 + *
39 + * @throws SecurityException if any security violation is observed.
40 + * @throws NoSuchMethodException if when the method is not found.
41 + * @throws IllegalArgumentException if there is illegal argument found.
42 + * @throws InstantiationException if instantiation is provoked for the private constructor.
43 + * @throws IllegalAccessException if instance is provoked or a method is provoked.
44 + * @throws InvocationTargetException when an exception occurs by the method or constructor.
45 + */
46 + @Test
47 + public void callPrivateConstructors() throws SecurityException, NoSuchMethodException,
48 + IllegalArgumentException, InstantiationException, IllegalAccessException, InvocationTargetException {
49 + Class<?>[] classesToConstruct = {ClassDefinitionGenerator.class };
50 + for (Class<?> clazz : classesToConstruct) {
51 + Constructor<?> constructor = clazz.getDeclaredConstructor();
52 + constructor.setAccessible(true);
53 + assertNotNull(constructor.newInstance());
54 + }
55 + }
56 +
57 + /**
58 + * Unit test for builder class definition.
59 + */
60 + @Test
61 + public void generateBuilderClassDefinitionTest() {
62 +
63 + String builderClassDefinition = ClassDefinitionGenerator
64 + .generateClassDefinition(GeneratedFileType.BUILDER_CLASS, "BuilderClass");
65 + assertThat(true, is(builderClassDefinition.contains(UtilConstants.BUILDER)));
66 + assertThat(true, is(builderClassDefinition.contains(UtilConstants.CLASS)));
67 + }
68 +
69 + /**
70 + * Unit test for builder interface definition.
71 + */
72 + @Test
73 + public void generateBuilderInterfaceDefinitionTest() {
74 +
75 + String builderInterfaceDefinition = ClassDefinitionGenerator
76 + .generateClassDefinition(GeneratedFileType.BUILDER_INTERFACE, "BuilderInterfaceClass");
77 + assertThat(true, is(builderInterfaceDefinition.contains(UtilConstants.BUILDER)));
78 + }
79 +
80 + /**
81 + * Unit test for impl class definition.
82 + */
83 + @Test
84 + public void generateImplDefinitionTest() {
85 +
86 + String implDefinition = ClassDefinitionGenerator.generateClassDefinition(GeneratedFileType.IMPL, "ImplClass");
87 + assertThat(true, is(implDefinition.contains(UtilConstants.IMPL)));
88 + }
89 +
90 + /**
91 + * Unit test for interface definition.
92 + */
93 + @Test
94 + public void generateinterfaceDefinitionTest() {
95 +
96 + String interfaceDefinition = ClassDefinitionGenerator.generateClassDefinition(GeneratedFileType.INTERFACE,
97 + "InterfaceClass");
98 + assertThat(true, is(interfaceDefinition.contains(UtilConstants.INTERFACE)));
99 + }
100 +
101 + /**
102 + * Unit test for invalid generated type.
103 + */
104 + @Test
105 + public void generateInvalidDefinitionTest() {
106 +
107 + String invalidDefinition = ClassDefinitionGenerator.generateClassDefinition(GeneratedFileType.ALL, "invalid");
108 + assertThat(true, is(invalidDefinition == null));
109 + }
110 +
111 + /**
112 + * Unit test for enum data types.
113 + */
114 + @Test
115 + public void enumDataTypesTest() {
116 +
117 + TraversalType.valueOf(TraversalType.CHILD.toString());
118 + GeneratedMethodTypes.valueOf(GeneratedMethodTypes.CONSTRUCTOR.toString());
119 + }
120 +}
1 +/*
2 + * Copyright 2016 Open Networking Laboratory
3 + *
4 + * Licensed under the Apache License, Version 2.0 (the "License");
5 + * you may not use this file except in compliance with the License.
6 + * You may obtain a copy of the License at
7 + *
8 + * http://www.apache.org/licenses/LICENSE-2.0
9 + *
10 + * Unless required by applicable law or agreed to in writing, software
11 + * distributed under the License is distributed on an "AS IS" BASIS,
12 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 + * See the License for the specific language governing permissions and
14 + * limitations under the License.
15 + */
16 +
17 +package org.onosproject.yangutils.translator.tojava.utils;
18 +
19 +import org.junit.Test;
20 +import static org.junit.Assert.assertNotNull;
21 +import static org.hamcrest.core.Is.is;
22 +import static org.junit.Assert.assertThat;
23 +import java.lang.reflect.Constructor;
24 +import java.lang.reflect.InvocationTargetException;
25 +
26 +/**
27 + * Unit tests for java identifier syntax.
28 + */
29 +public final class JavaIdentifierSyntaxTest {
30 +
31 + /**
32 + * Unit test for private constructor.
33 + *
34 + * @throws SecurityException if any security violation is observed.
35 + * @throws NoSuchMethodException if when the method is not found.
36 + * @throws IllegalArgumentException if there is illegal argument found.
37 + * @throws InstantiationException if instantiation is provoked for the private constructor.
38 + * @throws IllegalAccessException if instance is provoked or a method is provoked.
39 + * @throws InvocationTargetException when an exception occurs by the method or constructor.
40 + */
41 + public void callPrivateConstructors() throws SecurityException, NoSuchMethodException, IllegalArgumentException,
42 + InstantiationException, IllegalAccessException, InvocationTargetException {
43 + Class<?>[] classesToConstruct = {JavaIdentifierSyntax.class };
44 + for (Class<?> clazz : classesToConstruct) {
45 + Constructor<?> constructor = clazz.getDeclaredConstructor();
46 + constructor.setAccessible(true);
47 + assertNotNull(constructor.newInstance());
48 + }
49 + }
50 +
51 + /**
52 + * Unit test for testing the package path generation from a parent package.
53 + */
54 + @Test
55 + public void getPackageFromParentTest() {
56 + String pkgFromParent = JavaIdentifierSyntax.getPackageFromParent("test5.test6.test7", "test1:test2:test3");
57 + assertThat(pkgFromParent.equals("test5.test6.test7.test1.test2.test3"), is(true));
58 + }
59 +
60 + /**
61 + * Unit test for root package generation with revision complexity.
62 + */
63 + @Test
64 + public void getRootPackageTest() {
65 +
66 + String rootPackage = JavaIdentifierSyntax.getRootPackage((byte) 0, "test1:test2:test3", "5-1-2000");
67 + assertThat(rootPackage.equals("org.onosproject.yang.gen.v0.test1.test2.test3.rev05012000"), is(true));
68 + }
69 +
70 + /**
71 + * Unit test for root package generation without revision complexity.
72 + */
73 + @Test
74 + public void getRootPackageWithRevTest() {
75 +
76 + String rootPkgWithRev = JavaIdentifierSyntax.getRootPackage((byte) 0, "test1:test2:test3", "25-01-1992");
77 + assertThat(rootPkgWithRev.equals("org.onosproject.yang.gen.v0.test1.test2.test3.rev25011992"), is(true));
78 + }
79 +
80 + /**
81 + * Unit test for capitalizing the incoming string.
82 + */
83 + @Test
84 + public void getCapitalCaseTest() {
85 +
86 + String capitalCase = JavaIdentifierSyntax.getCaptialCase("test_this");
87 + assertThat(capitalCase.equals("Test_this"), is(true));
88 + }
89 +
90 + /**
91 + * Unit test for getting the camel case for the received string.
92 + */
93 + @Test
94 + public void getCamelCaseTest() {
95 + String camelCase = JavaIdentifierSyntax.getCamelCase("test-camel-case-identifier");
96 + assertThat(camelCase.equals("testCamelCaseIdentifier"), is(true));
97 + }
98 +}
1 +/*
2 + * Copyright 2016 Open Networking Laboratory
3 + *
4 + * Licensed under the Apache License, Version 2.0 (the "License");
5 + * you may not use this file except in compliance with the License.
6 + * You may obtain a copy of the License at
7 + *
8 + * http://www.apache.org/licenses/LICENSE-2.0
9 + *
10 + * Unless required by applicable law or agreed to in writing, software
11 + * distributed under the License is distributed on an "AS IS" BASIS,
12 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 + * See the License for the specific language governing permissions and
14 + * limitations under the License.
15 + */
16 +
17 +package org.onosproject.yangutils.translator.tojava.utils;
18 +
19 +import org.junit.Test;
20 +import static org.hamcrest.core.Is.is;
21 +import static org.hamcrest.Matchers.nullValue;
22 +import static org.junit.Assert.assertThat;
23 +import static org.junit.Assert.assertNotNull;
24 +import org.onosproject.yangutils.datamodel.YangDataTypes;
25 +import org.onosproject.yangutils.datamodel.YangType;
26 +import org.onosproject.yangutils.translator.GeneratedFileType;
27 +import org.onosproject.yangutils.translator.tojava.AttributeInfo;
28 +import org.onosproject.yangutils.translator.tojava.GeneratedMethodTypes;
29 +
30 +import java.lang.reflect.Constructor;
31 +import java.lang.reflect.InvocationTargetException;
32 +import java.util.ArrayList;
33 +import java.util.List;
34 +
35 +/**
36 + * Unit tests for generated methods from the file type.
37 + */
38 +public final class MethodsGeneratorTest {
39 +
40 + public static AttributeInfo testAttr = new AttributeInfo();
41 + public static YangType<?> attrType = new YangType<>();
42 +
43 + /**
44 + * Unit test for private constructor.
45 + *
46 + * @throws SecurityException if any security violation is observed.
47 + * @throws NoSuchMethodException if when the method is not found.
48 + * @throws IllegalArgumentException if there is illegal argument found.
49 + * @throws InstantiationException if instantiation is provoked for the private constructor.
50 + * @throws IllegalAccessException if instance is provoked or a method is provoked.
51 + * @throws InvocationTargetException when an exception occurs by the method or constructor.
52 + */
53 + @Test
54 + public void callPrivateConstructors() throws SecurityException, NoSuchMethodException, IllegalArgumentException,
55 + InstantiationException, IllegalAccessException, InvocationTargetException {
56 +
57 + Class<?>[] classesToConstruct = {MethodsGenerator.class };
58 + for (Class<?> clazz : classesToConstruct) {
59 + Constructor<?> constructor = clazz.getDeclaredConstructor();
60 + constructor.setAccessible(true);
61 + assertNotNull(constructor.newInstance());
62 + }
63 + }
64 +
65 + /**
66 + * Unit test for checking the generated builder class method.
67 + */
68 + @Test
69 + public void getMethodBuilderClassTest() {
70 +
71 + attrType.setDataTypeName("integer");
72 + attrType.getDataTypeName();
73 + attrType.setDataType(YangDataTypes.INT8);
74 + attrType.getDataType();
75 + testAttr.setAttributeName("attributeBuilderClassTest");
76 + testAttr.setAttributeType(attrType);
77 + String builderClassMethod = MethodsGenerator.getMethodString(testAttr, GeneratedFileType.BUILDER_CLASS);
78 + assertThat(builderClassMethod.contains("public Byte getAttributeBuilderClassTest() {"), is(true));
79 + assertThat(builderClassMethod.contains(
80 + "public testnameof setAttributeBuilderClassTest(Byte attributeBuilderClassTest) {"), is(true));
81 + }
82 +
83 + /**
84 + * Unit test for checking the generated builder interface method.
85 + */
86 + @Test
87 + public void getMethodBuilderInterfaceTest() {
88 +
89 + attrType.setDataTypeName("integer16");
90 + attrType.getDataTypeName();
91 + attrType.setDataType(YangDataTypes.INT16);
92 + attrType.getDataType();
93 + testAttr.setAttributeName("attributeBuilderInterfaceTest");
94 + testAttr.setAttributeType(attrType);
95 + String builderInterfaceMethod = MethodsGenerator.getMethodString(testAttr, GeneratedFileType.BUILDER_INTERFACE);
96 + assertThat(builderInterfaceMethod.contains("Returns the attribute attributeBuilderInterfaceTest.")
97 + && builderInterfaceMethod.contains("Short getAttributeBuilderInterfaceTest();")
98 + && builderInterfaceMethod.contains("Returns the builder object of attributeBuilderInterfaceTest.")
99 + && builderInterfaceMethod
100 + .contains("Builder setAttributeBuilderInterfaceTest(Short attributeBuilderInterfaceTest);"),
101 + is(true));
102 + }
103 +
104 + /**
105 + * Unit test for checking the generated impl method.
106 + */
107 + @Test
108 + public void getMethodImplTest() {
109 +
110 + attrType.setDataTypeName("integer16");
111 + attrType.getDataTypeName();
112 + attrType.setDataType(YangDataTypes.INT16);
113 + attrType.getDataType();
114 + testAttr.setAttributeName("attributeImplTest");
115 + testAttr.setAttributeType(attrType);
116 + String implMethod = MethodsGenerator.getMethodString(testAttr, GeneratedFileType.IMPL);
117 + assertThat(implMethod.contains("public Short getAttributeImplTest() {")
118 + && implMethod.contains("return attributeImplTest;"), is(true));
119 + }
120 +
121 + /**
122 + * Unit test for checking the generated interface method.
123 + */
124 + @Test
125 + public void getMethodInterfaceTest() {
126 +
127 + attrType.setDataTypeName("binary");
128 + attrType.getDataTypeName();
129 + attrType.setDataType(YangDataTypes.INT32);
130 + attrType.getDataType();
131 + testAttr.setAttributeName("attributeInterfaceTest");
132 + testAttr.setAttributeType(attrType);
133 + String interfaceMethod = MethodsGenerator.getMethodString(testAttr, GeneratedFileType.INTERFACE);
134 + assertThat(interfaceMethod.contains("Returns the attribute attributeInterfaceTest.")
135 + && interfaceMethod.contains("@return attributeInterfaceTest")
136 + && interfaceMethod.contains("Int getAttributeInterfaceTest();"), is(true));
137 + }
138 +
139 + /**
140 + * Unit test for checking the response for an invalid input.
141 + */
142 + @Test
143 + public void getMethodInvalidTest() {
144 +
145 + attrType.setDataTypeName("decimal64");
146 + attrType.getDataTypeName();
147 + attrType.setDataType(YangDataTypes.DECIMAL64);
148 + attrType.getDataType();
149 + testAttr.setAttributeName("attributeInvalidTest");
150 + testAttr.setAttributeType(attrType);
151 + String invalidMethod = MethodsGenerator.getMethodString(testAttr, GeneratedFileType.ALL);
152 + assertThat(invalidMethod, is(nullValue()));
153 + }
154 +
155 + /**
156 + * Unit test for checking the generated construct method info.
157 + */
158 + @Test
159 + public void constructMethodInfoTest() {
160 +
161 + attrType.setDataTypeName("decimal64");
162 + attrType.getDataTypeName();
163 + attrType.setDataType(YangDataTypes.DECIMAL64);
164 + attrType.getDataType();
165 + MethodsGenerator.setBuilderClassName("testnameof");
166 + String builderClassName = MethodsGenerator.getBuilderClassName();
167 + assertThat(builderClassName.equals("testnameof"), is(true));
168 + String implTypenullMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.IMPL, "testname",
169 + GeneratedMethodTypes.GETTER, null);
170 + assertThat(implTypenullMethod.contains("public Testname getTestname() {")
171 + && implTypenullMethod.contains("return testname;"), is(true));
172 + String implTypeGetterMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.IMPL, "testname",
173 + GeneratedMethodTypes.GETTER, attrType);
174 + assertThat(implTypeGetterMethod.contains("public Decimal64 getTestname()")
175 + && implTypeGetterMethod.contains("return testname;"), is(true));
176 + String implTypeConstructorMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.IMPL, "testname",
177 + GeneratedMethodTypes.CONSTRUCTOR, attrType);
178 + assertThat(implTypeConstructorMethod.contains("public testnameImpl(testnameBuilder testnameObject) {")
179 + && implTypeConstructorMethod.contains("}"), is(true));
180 + String implTypeDefaultConstructorMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.IMPL,
181 + "testname", GeneratedMethodTypes.DEFAULT_CONSTRUCTOR, attrType);
182 + assertThat(implTypeDefaultConstructorMethod.contains("public testnameImpl() {")
183 + && implTypeDefaultConstructorMethod.contains("}"), is(true));
184 + String implTypeSetterMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.IMPL, "testname",
185 + GeneratedMethodTypes.SETTER, attrType);
186 + assertThat(implTypeSetterMethod, is(nullValue()));
187 + String builderInterfaceTypeSetterMethod = MethodsGenerator.constructMethodInfo(
188 + GeneratedFileType.BUILDER_INTERFACE, "testname2", GeneratedMethodTypes.SETTER, attrType);
189 + assertThat(builderInterfaceTypeSetterMethod.contains("Builder setTestname2(Decimal64 testname2);"), is(true));
190 + String builderInterfaceTypeGetterMethod = MethodsGenerator.constructMethodInfo(
191 + GeneratedFileType.BUILDER_INTERFACE, "testname2", GeneratedMethodTypes.GETTER, attrType);
192 + assertThat(builderInterfaceTypeGetterMethod.contains("Decimal64 getTestname2();"), is(true));
193 + String builderInterfaceTypeBuildMethod = MethodsGenerator.constructMethodInfo(
194 + GeneratedFileType.BUILDER_INTERFACE, "testname2", GeneratedMethodTypes.BUILD, attrType);
195 + assertThat(builderInterfaceTypeBuildMethod.contains("testname2 build();"), is(true));
196 + String builderInterfaceTypeConstructorMethod = MethodsGenerator.constructMethodInfo(
197 + GeneratedFileType.BUILDER_INTERFACE, "testname2", GeneratedMethodTypes.CONSTRUCTOR, attrType);
198 + assertThat(builderInterfaceTypeConstructorMethod, is(nullValue()));
199 + String builderClassTypeBuildMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.BUILDER_CLASS,
200 + "testname2", GeneratedMethodTypes.BUILD, attrType);
201 + assertThat(builderClassTypeBuildMethod.contains("public testname2 build() {")
202 + && builderClassTypeBuildMethod.contains("return new testname2Impl(this);"), is(true));
203 + String builderClassTypeGetterMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.BUILDER_CLASS,
204 + "testname2", GeneratedMethodTypes.GETTER, attrType);
205 + assertThat(builderClassTypeGetterMethod.contains("public Decimal64 getTestname2() {")
206 + && builderClassTypeGetterMethod.contains("return testname2;"), is(true));
207 + String builderClassTypeSetterMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.BUILDER_CLASS,
208 + "testname2", GeneratedMethodTypes.SETTER, attrType);
209 + assertThat(builderClassTypeSetterMethod.contains("public testnameof setTestname2(Decimal64 testname2) {")
210 + && builderClassTypeSetterMethod.contains("this.testname2 = testname2;"), is(true));
211 + String builderClassTypeDefaultConstructorMethod = MethodsGenerator.constructMethodInfo(
212 + GeneratedFileType.BUILDER_CLASS, "testname2", GeneratedMethodTypes.DEFAULT_CONSTRUCTOR, attrType);
213 + assertThat(builderClassTypeDefaultConstructorMethod.contains("public testname2Builder() {"), is(true));
214 + String builderClassTypeConstructorMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.BUILDER_CLASS,
215 + "testname2", GeneratedMethodTypes.CONSTRUCTOR, attrType);
216 + assertThat(builderClassTypeConstructorMethod, is(nullValue()));
217 + String invalidMethod = MethodsGenerator.constructMethodInfo(GeneratedFileType.ALL, "testname2",
218 + GeneratedMethodTypes.CONSTRUCTOR, attrType);
219 + assertThat(invalidMethod, is(nullValue()));
220 + }
221 +
222 + /**
223 + * Unit test for checking the method constructor.
224 + */
225 + @Test
226 + public void getMethodConstructorTest() {
227 +
228 + MethodsGenerator.parseBuilderInterfaceBuildMethodString("testname7");
229 + attrType.setDataTypeName("binary");
230 + attrType.getDataTypeName();
231 + attrType.setDataType(YangDataTypes.BINARY);
232 + attrType.getDataType();
233 + testAttr.setAttributeName("attributeTest");
234 + testAttr.setAttributeType(attrType);
235 + List<AttributeInfo> settingAttributes = new ArrayList<AttributeInfo>();
236 + settingAttributes.add(testAttr);
237 + MethodsGenerator.setAttrInfo(settingAttributes);
238 + String methodConstructor = MethodsGenerator.constructMethodInfo(GeneratedFileType.IMPL, "testname",
239 + GeneratedMethodTypes.CONSTRUCTOR, attrType);
240 + assertThat(
241 + methodConstructor.contains("public testnameImpl(testnameBuilder testnameObject) {")
242 + && methodConstructor.contains("this.attributeTest = testnameObject.getAttributeTest();"),
243 + is(true));
244 + }
245 +
246 + /**
247 + * Unit test for checking the values received from constructor, default constructor and build string formation.
248 + */
249 + @Test
250 + public void getValuesTest() {
251 + String stringConstructor = MethodsGenerator.getConstructorString("testname");
252 + assertThat(
253 + stringConstructor.contains("Construct the object of testnameImpl.")
254 + && stringConstructor.contains("@param testnameObject builder object of testname")
255 + && stringConstructor.contains("public testnameImpl(testnameBuilder testnameObject) {"),
256 + is(true));
257 + String stringDefaultConstructor = MethodsGenerator.getDefaultConstructorString(GeneratedFileType.BUILDER_CLASS,
258 + "testname");
259 + assertThat(stringDefaultConstructor.contains("Default Constructor.")
260 + && stringDefaultConstructor.contains("public testnameBuilder() {")
261 + && stringDefaultConstructor.contains("}"), is(true));
262 + String stringBuild = MethodsGenerator.getBuildString("testname");
263 + assertThat(
264 + stringBuild.contains("public testname build() {")
265 + && stringBuild.contains("return new testnameImpl(this);") && stringBuild.contains("}"),
266 + is(true));
267 + }
268 +}
...\ No newline at end of file ...\ No newline at end of file