X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fbenchmark-data-store%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fdom%2Fstore%2Fbenchmark%2FBenchmarkModel.java;h=c5f95f9aa56b0ccab6bbfba689921b5ea489bfac;hp=024385b2a9380c13d385dca39204e36818aa649b;hb=f781598707f0810491cb571f835ee49772e00e83;hpb=2844a49212587b08dc777137e9e5f9011fbb3afd diff --git a/opendaylight/md-sal/benchmark-data-store/src/main/java/org/opendaylight/controller/md/sal/dom/store/benchmark/BenchmarkModel.java b/opendaylight/md-sal/benchmark-data-store/src/main/java/org/opendaylight/controller/md/sal/dom/store/benchmark/BenchmarkModel.java index 024385b2a9..c5f95f9aa5 100644 --- a/opendaylight/md-sal/benchmark-data-store/src/main/java/org/opendaylight/controller/md/sal/dom/store/benchmark/BenchmarkModel.java +++ b/opendaylight/md-sal/benchmark-data-store/src/main/java/org/opendaylight/controller/md/sal/dom/store/benchmark/BenchmarkModel.java @@ -9,13 +9,9 @@ package org.opendaylight.controller.md.sal.dom.store.benchmark; import java.io.InputStream; import java.util.Collections; -import java.util.Set; - import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; -import org.opendaylight.yangtools.yang.model.api.Module; import org.opendaylight.yangtools.yang.model.api.SchemaContext; -import org.opendaylight.yangtools.yang.parser.impl.YangParserImpl; /** * Benchmark Model class loads the odl-datastore-test.yang model from resources. @@ -36,20 +32,23 @@ public final class BenchmarkModel { private static final String DATASTORE_TEST_YANG = "/odl-datastore-test.yang"; public static final YangInstanceIdentifier TEST_PATH = YangInstanceIdentifier.of(TEST_QNAME); - public static final YangInstanceIdentifier OUTER_LIST_PATH = YangInstanceIdentifier.builder(TEST_PATH).node(OUTER_LIST_QNAME).build(); - - public static final InputStream getDatastoreBenchmarkInputStream() { - return getInputStream(DATASTORE_TEST_YANG); - } + public static final YangInstanceIdentifier OUTER_LIST_PATH = + YangInstanceIdentifier.builder(TEST_PATH).node(OUTER_LIST_QNAME).build(); - private static InputStream getInputStream(final String resourceName) { - return BenchmarkModel.class.getResourceAsStream(resourceName); + private static InputStream getInputStream() { + return BenchmarkModel.class.getResourceAsStream(DATASTORE_TEST_YANG); } public static SchemaContext createTestContext() { - YangParserImpl parser = new YangParserImpl(); - Set modules = parser.parseYangModelsFromStreams(Collections.singletonList( - getDatastoreBenchmarkInputStream())); - return parser.resolveSchemaContext(modules); + final CrossSourceStatementReactor.BuildAction reactor = YangInferencePipeline.RFC6020_REACTOR.newBuild(); + final SchemaContext schemaContext; + final List streams = Collections.singletonList(getInputStream()); + + try { + schemaContext = reactor.buildEffective(streams); + } catch (ReactorException e) { + throw new RuntimeException("Unable to build schema context from " + streams, e); + } + return schemaContext; } }