X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=parser%2Fyang-parser-impl%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fparser%2Frepo%2FAbstractSchemaRepositoryTest.java;h=ed353a759943e2b846de88af4bc21c3f515ff43a;hb=973a7bd5be04bd9a63f4b7f6305cb25b5532cae9;hp=16db94dd6d98a36b3b085dd69979fa1ff2048cc1;hpb=6dd19d2f87b3391b95d8087a3ff025c5414fd4e9;p=yangtools.git diff --git a/parser/yang-parser-impl/src/test/java/org/opendaylight/yangtools/yang/parser/repo/AbstractSchemaRepositoryTest.java b/parser/yang-parser-impl/src/test/java/org/opendaylight/yangtools/yang/parser/repo/AbstractSchemaRepositoryTest.java index 16db94dd6d..ed353a7599 100644 --- a/parser/yang-parser-impl/src/test/java/org/opendaylight/yangtools/yang/parser/repo/AbstractSchemaRepositoryTest.java +++ b/parser/yang-parser-impl/src/test/java/org/opendaylight/yangtools/yang/parser/repo/AbstractSchemaRepositoryTest.java @@ -7,11 +7,16 @@ */ package org.opendaylight.yangtools.yang.parser.repo; +import static org.junit.Assert.assertThrows; + import com.google.common.collect.SetMultimap; +import com.google.common.util.concurrent.Futures; import com.google.common.util.concurrent.ListenableFuture; import java.io.IOException; import java.util.Arrays; +import java.util.concurrent.ExecutionException; import java.util.stream.Collectors; +import org.eclipse.jdt.annotation.NonNull; import org.opendaylight.yangtools.yang.common.QNameModule; import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext; import org.opendaylight.yangtools.yang.model.repo.api.SchemaContextFactoryConfiguration; @@ -19,9 +24,26 @@ import org.opendaylight.yangtools.yang.model.repo.api.YangTextSchemaSource; import org.opendaylight.yangtools.yang.parser.api.YangSyntaxErrorException; import org.opendaylight.yangtools.yang.parser.rfc7950.ir.IRSchemaSource; import org.opendaylight.yangtools.yang.parser.rfc7950.repo.TextToIRTransformer; +import org.opentest4j.AssertionFailedError; public abstract class AbstractSchemaRepositoryTest { - static ListenableFuture createSchemaContext( + static @NonNull EffectiveModelContext assertModelContext( + final SetMultimap modulesWithSupportedDeviations, final String... resources) { + final var future = createModelContext(modulesWithSupportedDeviations, resources); + try { + return Futures.getDone(future); + } catch (ExecutionException e) { + throw new AssertionFailedError("Failed to create context", e); + } + } + + static @NonNull ExecutionException assertExecutionException( + final SetMultimap modulesWithSupportedDeviations, final String... resources) { + final var future = createModelContext(modulesWithSupportedDeviations, resources); + return assertThrows(ExecutionException.class, () -> Futures.getDone(future)); + } + + static ListenableFuture createModelContext( final SetMultimap modulesWithSupportedDeviations, final String... resources) { final var sharedSchemaRepository = new SharedSchemaRepository(); final var requiredSources = Arrays.stream(resources)