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=d2d3b51048182ea6feaa8ec565f4378df72ed3e3;hp=024385b2a9380c13d385dca39204e36818aa649b;hb=a7fa4e6badc5d5d3f402bedb72edebbf5c12bd2b;hpb=4019c9fd2ad99628dd790acc1ad4c104f48b6428 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..d2d3b51048 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 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved. + * Copyright (c) 2013, 2017 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, @@ -9,13 +9,12 @@ package org.opendaylight.controller.md.sal.dom.store.benchmark; import java.io.InputStream; import java.util.Collections; -import java.util.Set; - +import java.util.List; 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; +import org.opendaylight.yangtools.yang.parser.spi.meta.ReactorException; +import org.opendaylight.yangtools.yang.test.util.YangParserTestUtils; /** * Benchmark Model class loads the odl-datastore-test.yang model from resources. @@ -23,7 +22,7 @@ import org.opendaylight.yangtools.yang.parser.impl.YangParserImpl; * This class serves as facilitator class which holds several references to initialized yang model as static final * members. * - * @author Lukas Sedlak + * @author Lukas Sedlak */ public final class BenchmarkModel { @@ -34,22 +33,26 @@ public final class BenchmarkModel { public static final QName ID_QNAME = QName.create(TEST_QNAME, "id"); public static final QName NAME_QNAME = QName.create(TEST_QNAME, "name"); 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 YangInstanceIdentifier OUTER_LIST_PATH = + YangInstanceIdentifier.builder(TEST_PATH).node(OUTER_LIST_QNAME).build(); - public static final InputStream getDatastoreBenchmarkInputStream() { - return getInputStream(DATASTORE_TEST_YANG); + private BenchmarkModel() { } - 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 SchemaContext schemaContext; + final List streams = Collections.singletonList(getInputStream()); + + try { + schemaContext = YangParserTestUtils.parseYangStreams(streams); + } catch (ReactorException e) { + throw new RuntimeException("Unable to build schema context from " + streams, e); + } + return schemaContext; } }