import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
+import com.google.common.collect.Lists;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
+import java.math.BigInteger;
import java.net.URI;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.Set;
-
-import org.junit.Ignore;
import org.junit.Test;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.model.api.AnyXmlSchemaNode;
import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode;
import org.opendaylight.yangtools.yang.model.api.UsesNode;
import org.opendaylight.yangtools.yang.model.api.type.RangeConstraint;
-import org.opendaylight.yangtools.yang.model.parser.api.YangModelParser;
+import org.opendaylight.yangtools.yang.model.parser.api.YangContextParser;
import org.opendaylight.yangtools.yang.model.util.ExtendedType;
-import com.google.common.collect.Lists;
-
public class YangParserWithContextTest {
private final DateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
private final YangParserImpl parser = new YangParserImpl();
List<RangeConstraint> ranges = dscpExt.getRangeConstraints();
assertEquals(1, ranges.size());
RangeConstraint range = ranges.get(0);
- assertEquals(0L, range.getMin());
- assertEquals(63L, range.getMax());
+ assertEquals(BigInteger.ZERO, range.getMin());
+ assertEquals(BigInteger.valueOf(63), range.getMax());
}
@Test
SchemaContext context;
File yangFile = new File(getClass().getResource("/types/custom-types-test@2012-4-4.yang").toURI());
File dependenciesDir = new File(getClass().getResource("/ietf").toURI());
- YangModelParser parser = new YangParserImpl();
- context = parser.resolveSchemaContext(parser.parseYangModels(yangFile, dependenciesDir));
+ YangContextParser parser = new YangParserImpl();
+ context = parser.parseFile(yangFile, dependenciesDir);
Module module;
try (InputStream stream = new FileInputStream(new File(getClass().getResource("/context-test/test3.yang")
SchemaContext context;
File yangFile = new File(getClass().getResource("/types/custom-types-test@2012-4-4.yang").toURI());
File dependenciesDir = new File(getClass().getResource("/ietf").toURI());
- YangModelParser parser = new YangParserImpl();
- context = parser.resolveSchemaContext(parser.parseYangModels(yangFile, dependenciesDir));
+ YangContextParser parser = new YangParserImpl();
+ context = parser.parseFile(yangFile, dependenciesDir);
Module module;
try (InputStream stream = new FileInputStream(new File(getClass().getResource("/context-test/test3.yang")
assertNotNull(un.getExtensionDefinition());
}
- @Ignore
@Test
public void testAugment() throws Exception {
// load first module
- SchemaContext context;
String resource = "/context-augment-test/test4.yang";
-
- try (InputStream stream = new FileInputStream(new File(getClass().getResource(resource).toURI()))) {
- context = parser.resolveSchemaContext(TestUtils.loadModules(Lists.newArrayList(stream)));
- }
+ SchemaContext context = parser.parseFiles(Collections.singleton(new File(getClass().getResource(resource)
+ .toURI())));
// load another modules and parse them against already existing context
- Set<Module> modules;
- try (InputStream stream1 = new FileInputStream(new File(getClass().getResource(
- "/context-augment-test/test1.yang").toURI()));
- InputStream stream2 = new FileInputStream(new File(getClass().getResource(
- "/context-augment-test/test2.yang").toURI()));
- InputStream stream3 = new FileInputStream(new File(getClass().getResource(
- "/context-augment-test/test3.yang").toURI()))) {
- List<InputStream> input = Lists.newArrayList(stream1, stream2, stream3);
- modules = TestUtils.loadModulesWithContext(input, context);
- }
+ File test1 = new File(getClass().getResource("/context-augment-test/test1.yang").toURI());
+ File test2 = new File(getClass().getResource("/context-augment-test/test2.yang").toURI());
+ File test3 = new File(getClass().getResource("/context-augment-test/test3.yang").toURI());
+ Set<Module> modules = parser.parseFiles(Arrays.asList(test1, test2, test3), context).getModules();
assertNotNull(modules);
- Module t3 = TestUtils.findModule(modules, "test4");
- ContainerSchemaNode interfaces = (ContainerSchemaNode) t3.getDataChildByName("interfaces");
+ Module t4 = TestUtils.findModule(modules, "test4");
+ ContainerSchemaNode interfaces = (ContainerSchemaNode) t4.getDataChildByName("interfaces");
ListSchemaNode ifEntry = (ListSchemaNode) interfaces.getDataChildByName("ifEntry");
// test augmentation process