*/
package org.opendaylight.yangtools.sal.binding.generator.impl;
-import static org.junit.Assert.*;
-import static org.opendaylight.yangtools.sal.binding.generator.impl.SupportTestUtil.*;
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertNotNull;
+import static org.opendaylight.yangtools.sal.binding.generator.impl.SupportTestUtil.containsInterface;
+import static org.opendaylight.yangtools.sal.binding.generator.impl.SupportTestUtil.containsMethods;
-import java.io.File;
-import java.util.ArrayList;
+import java.io.IOException;
import java.util.List;
-import java.util.Set;
-import org.junit.BeforeClass;
import org.junit.Test;
import org.opendaylight.yangtools.sal.binding.generator.api.BindingGenerator;
import org.opendaylight.yangtools.sal.binding.model.api.GeneratedTransferObject;
import org.opendaylight.yangtools.sal.binding.model.api.GeneratedType;
import org.opendaylight.yangtools.sal.binding.model.api.Type;
-import org.opendaylight.yangtools.yang.model.api.Module;
import org.opendaylight.yangtools.yang.model.api.SchemaContext;
-import org.opendaylight.yangtools.yang.model.parser.api.YangModelParser;
+import org.opendaylight.yangtools.yang.model.parser.api.YangContextParser;
import org.opendaylight.yangtools.yang.parser.impl.YangParserImpl;
-public class ChoiceCaseGenTypesTest {
+public class ChoiceCaseGenTypesTest extends AbstractTypesTest {
- private final static List<File> yangModels = new ArrayList<>();
- private final static String yangModelsFolder = AugmentedTypeTest.class.getResource("/choice-case-type-test-models")
- .getPath();
-
- @BeforeClass
- public static void loadTestResources() {
- final File augFolder = new File(yangModelsFolder);
- for (final File fileEntry : augFolder.listFiles()) {
- if (fileEntry.isFile()) {
- yangModels.add(fileEntry);
- }
- }
+ public ChoiceCaseGenTypesTest() {
+ super(ChoiceCaseGenTypesTest.class.getResource("/choice-case-type-test-models"));
}
- private static GeneratedType checkGeneratedType(List<Type> genTypes, String genTypeName, String packageName,
- int occurences) {
+ private GeneratedType checkGeneratedType(final List<Type> genTypes, final String genTypeName, final String packageName, final int occurences) {
GeneratedType searchedGenType = null;
int searchedGenTypeCounter = 0;
for (Type type : genTypes) {
}
- private static GeneratedType checkGeneratedType(List<Type> genTypes, String genTypeName, String packageName) {
+ private GeneratedType checkGeneratedType(final List<Type> genTypes, final String genTypeName, final String packageName) {
return checkGeneratedType(genTypes, genTypeName, packageName, 1);
}
@Test
- public void choiceCaseResolvingTypeTest() {
- final YangModelParser parser = new YangParserImpl();
- final Set<Module> modules = parser.parseYangModels(yangModels);
- final SchemaContext context = parser.resolveSchemaContext(modules);
+ public void choiceCaseResolvingTypeTest() throws IOException {
+ final YangContextParser parser = new YangParserImpl();
+ final SchemaContext context = parser.parseFiles(testModels);
assertNotNull("context is null", context);
- final BindingGenerator bindingGen = new BindingGeneratorImpl();
+ final BindingGenerator bindingGen = new BindingGeneratorImpl(true);
final List<Type> genTypes = bindingGen.generateTypes(context);
assertNotNull("genTypes is null", genTypes);
assertFalse("genTypes is empty", genTypes.isEmpty());
// test for file choice-monitoring
- String pcgPref = "org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.choice.monitoring.rev201371.netconf.state.datastores.datastore.locks";
+ String pcgPref = "org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.choice.monitoring.rev130701.netconf.state.datastores.datastore.locks";
GeneratedType genType = null;
checkGeneratedType(genTypes, "LockType", pcgPref); // choice
genType = checkGeneratedType(genTypes, "GlobalLock", pcgPref + ".lock.type"); // case
- containsSignatures(genType, new MethodSignaturePattern("getGlobalLock", "GlobalLock"));
+ containsMethods(genType, new NameTypePattern("getGlobalLock", "GlobalLock"));
containsInterface("LockType", genType);
genType = checkGeneratedType(genTypes, "PartialLock", pcgPref + ".lock.type"); // case
- containsSignatures(genType, new MethodSignaturePattern("getPartialLock", "List<PartialLock>"));
+ containsMethods(genType, new NameTypePattern("getPartialLock", "List<PartialLock>"));
containsInterface("LockType", genType);
genType = checkGeneratedType(genTypes, "Fingerprint", pcgPref + ".lock.type"); // case
- containsSignatures(genType, new MethodSignaturePattern("getAlgorithmAndHash", "AlgorithmAndHash"));
+ containsMethods(genType, new NameTypePattern("getAlgorithmAndHash", "AlgorithmAndHash"));
containsInterface("LockType", genType);
genType = checkGeneratedType(genTypes, "AlgorithmAndHash", pcgPref + ".lock.type.fingerprint"); // choice
genType = checkGeneratedType(genTypes, "Md5", pcgPref + ".lock.type.fingerprint.algorithm.and.hash"); // case
- containsSignatures(genType, new MethodSignaturePattern("getMd5", "TlsFingerprintType"));
+ containsMethods(genType, new NameTypePattern("getMd5", "TlsFingerprintType"));
containsInterface("AlgorithmAndHash", genType);
genType = checkGeneratedType(genTypes, "Sha1", pcgPref + ".lock.type.fingerprint.algorithm.and.hash"); // case
- containsSignatures(genType, new MethodSignaturePattern("getSha1", "TlsFingerprintType"));
+ containsMethods(genType, new NameTypePattern("getSha1", "TlsFingerprintType"));
containsInterface("AlgorithmAndHash", genType);
genType = checkGeneratedType(genTypes, "Sha224", pcgPref + ".lock.type.fingerprint.algorithm.and.hash"); // case
- containsSignatures(genType, new MethodSignaturePattern("getSha224", "TlsFingerprintType"));
+ containsMethods(genType, new NameTypePattern("getSha224", "TlsFingerprintType"));
containsInterface("AlgorithmAndHash", genType);
genType = checkGeneratedType(genTypes, "Sha256", pcgPref + ".lock.type.fingerprint.algorithm.and.hash"); // case
- containsSignatures(genType, new MethodSignaturePattern("getSha256", "TlsFingerprintType"));
+ containsMethods(genType, new NameTypePattern("getSha256", "TlsFingerprintType"));
containsInterface("AlgorithmAndHash", genType);
genType = checkGeneratedType(genTypes, "Sha384", pcgPref + ".lock.type.fingerprint.algorithm.and.hash"); // case
- containsSignatures(genType, new MethodSignaturePattern("getSha384", "TlsFingerprintType"));
+ containsMethods(genType, new NameTypePattern("getSha384", "TlsFingerprintType"));
containsInterface("AlgorithmAndHash", genType);
genType = checkGeneratedType(genTypes, "Sha512", pcgPref + ".lock.type.fingerprint.algorithm.and.hash"); // case
- containsSignatures(genType, new MethodSignaturePattern("getSha512", "TlsFingerprintType"));
+ containsMethods(genType, new NameTypePattern("getSha512", "TlsFingerprintType"));
containsInterface("AlgorithmAndHash", genType);
// test for file augment-monitoring
// augment
// "/nm:netconf-state/nm:datastores/nm:datastore/nm:locks/nm:lock-type"
- pcgPref = "org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.augment.monitoring.rev201371";
+ pcgPref = "org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.augment.monitoring.rev130701";
genType = null;
genType = checkGeneratedType(genTypes, "AutonomousLock", pcgPref
+ ".netconf.state.datastores.datastore.locks.lock.type"); // choice
- containsSignatures(genType, new MethodSignaturePattern("getAutonomousDef", "AutonomousDef"));
+ containsMethods(genType, new NameTypePattern("getAutonomousDef", "AutonomousDef"));
containsInterface("LockType", genType);
genType = checkGeneratedType(genTypes, "AnonymousLock", pcgPref
+ ".netconf.state.datastores.datastore.locks.lock.type"); // choice
- containsSignatures(genType, new MethodSignaturePattern("getLockTime", "Long"));
+ containsMethods(genType, new NameTypePattern("getLockTime", "Long"));
containsInterface("LockType", genType);
genType = checkGeneratedType(genTypes, "LeafAugCase", pcgPref
+ ".netconf.state.datastores.datastore.locks.lock.type"); // choice
- containsSignatures(genType, new MethodSignaturePattern("getLeafAugCase", "String"));
+ containsMethods(genType, new NameTypePattern("getLeafAugCase", "String"));
containsInterface("LockType", genType);
// augment
// "/nm:netconf-state/nm:datastores/nm:datastore/nm:locks/nm:lock-type/nm:partial-lock"
// {
genType = checkGeneratedType(genTypes, "PartialLock1", pcgPref); // case
- containsSignatures(genType, new MethodSignaturePattern("getAugCaseByChoice", "AugCaseByChoice"));
+ containsMethods(genType, new NameTypePattern("getAugCaseByChoice", "AugCaseByChoice"));
containsInterface("Augmentation<PartialLock>", genType);
genType = checkGeneratedType(genTypes, "AugCaseByChoice", pcgPref
genType = checkGeneratedType(genTypes, "Foo", pcgPref
+ ".netconf.state.datastores.datastore.locks.lock.type.partial.lock.aug._case.by.choice"); // case
- containsSignatures(genType, new MethodSignaturePattern("getFoo", "String"));
+ containsMethods(genType, new NameTypePattern("getFoo", "String"));
containsInterface("AugCaseByChoice", genType);
genType = checkGeneratedType(genTypes, "Bar", pcgPref
+ ".netconf.state.datastores.datastore.locks.lock.type.partial.lock.aug._case.by.choice"); // case
- containsSignatures(genType, new MethodSignaturePattern("getBar", "Boolean"));
+ containsMethods(genType, new NameTypePattern("isBar", "Boolean"));
containsInterface("AugCaseByChoice", genType);
// augment "/nm:netconf-state/nm:datastores/nm:datastore" {
genType = checkGeneratedType(genTypes, "Datastore1", pcgPref);
- containsSignatures(genType, new MethodSignaturePattern("getStorageFormat", "StorageFormat"));
+ containsMethods(genType, new NameTypePattern("getStorageFormat", "StorageFormat"));
containsInterface("Augmentation<Datastore>", genType);
genType = checkGeneratedType(genTypes, "StorageFormat", pcgPref + ".netconf.state.datastores.datastore"); // choice
genType = checkGeneratedType(genTypes, "UnknownFiles", pcgPref
+ ".netconf.state.datastores.datastore.storage.format"); // case
- containsSignatures(genType, new MethodSignaturePattern("getFiles", "List<Files>"));
+ containsMethods(genType, new NameTypePattern("getFiles", "List<Files>"));
containsInterface("StorageFormat", genType);
genType = checkGeneratedType(genTypes, "Xml", pcgPref + ".netconf.state.datastores.datastore.storage.format"); // case
- containsSignatures(genType, new MethodSignaturePattern("getXmlDef", "XmlDef"));
+ containsMethods(genType, new NameTypePattern("getXmlDef", "XmlDef"));
containsInterface("StorageFormat", genType);
genType = checkGeneratedType(genTypes, "Yang", pcgPref + ".netconf.state.datastores.datastore.storage.format"); // case
- containsSignatures(genType, new MethodSignaturePattern("getYangFileName", "String"));
+ containsMethods(genType, new NameTypePattern("getYangFileName", "String"));
containsInterface("StorageFormat", genType);
}