import java.io.File;
import java.io.FileFilter;
import java.io.FileNotFoundException;
+import java.io.IOException;
import java.net.URISyntaxException;
import java.net.URL;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Set;
-import java.util.function.Predicate;
import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.common.YangConstants;
import org.opendaylight.yangtools.yang.model.api.DataNodeContainer;
import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
import org.opendaylight.yangtools.yang.model.api.Module;
import org.opendaylight.yangtools.yang.model.api.ModuleImport;
import org.opendaylight.yangtools.yang.model.api.SchemaContext;
-import org.opendaylight.yangtools.yang.model.repo.api.IfFeaturePredicates;
+import org.opendaylight.yangtools.yang.model.parser.api.YangSyntaxErrorException;
import org.opendaylight.yangtools.yang.model.repo.api.StatementParserMode;
+import org.opendaylight.yangtools.yang.model.repo.api.YangTextSchemaSource;
+import org.opendaylight.yangtools.yang.parser.rfc6020.repo.YangStatementStreamSource;
import org.opendaylight.yangtools.yang.parser.spi.meta.ReactorException;
import org.opendaylight.yangtools.yang.parser.spi.source.SourceException;
import org.opendaylight.yangtools.yang.parser.spi.source.StatementStreamSource;
import org.opendaylight.yangtools.yang.parser.stmt.reactor.CrossSourceStatementReactor;
import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.YangInferencePipeline;
-import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.YangStatementSourceImpl;
import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.YinStatementSourceImpl;
import org.opendaylight.yangtools.yang.parser.util.NamedFileInputStream;
import org.slf4j.Logger;
public class StmtTestUtils {
- final public static FileFilter YANG_FILE_FILTER = file -> {
- final String name = file.getName().toLowerCase();
- return name.endsWith(".yang") && file.isFile();
- };
+ public static final FileFilter YANG_FILE_FILTER =
+ file -> file.getName().endsWith(YangConstants.RFC6020_YANG_FILE_EXTENSION) && file.isFile();
- final public static FileFilter YIN_FILE_FILTER = file -> {
- final String name = file.getName().toLowerCase();
- return name.endsWith(".xml") && file.isFile();
- };
+ public static final FileFilter YIN_FILE_FILTER =
+ file -> file.getName().endsWith(YangConstants.RFC6020_YIN_FILE_EXTENSION) && file.isFile();
private static final Logger LOG = LoggerFactory.getLogger(StmtTestUtils.class);
return result;
}
- public static void addSources(final CrossSourceStatementReactor.BuildAction reactor, final YangStatementSourceImpl... sources) {
- for (final YangStatementSourceImpl source : sources) {
- reactor.addSource(source);
+ public static StatementStreamSource sourceForResource(final String resourceName) {
+ try {
+ return YangStatementStreamSource.create(YangTextSchemaSource.forResource(resourceName));
+ } catch (IOException | YangSyntaxErrorException e) {
+ throw new IllegalArgumentException("Failed to create source", e);
}
}
public static SchemaContext parseYangSources(final StatementStreamSource... sources) throws SourceException,
ReactorException {
- return parseYangSources(StatementParserMode.DEFAULT_MODE, IfFeaturePredicates.ALL_FEATURES, sources);
+ return parseYangSources(StatementParserMode.DEFAULT_MODE, null, sources);
}
- public static SchemaContext parseYangSources(final StatementParserMode statementParserMode, final Predicate<QName> ifFeaturePredicate, final StatementStreamSource... sources)
+ public static SchemaContext parseYangSources(final StatementParserMode statementParserMode,
+ final Set<QName> supportedFeatures, final StatementStreamSource... sources)
throws SourceException, ReactorException {
+ return parseYangSources(statementParserMode, supportedFeatures, Arrays.asList(sources));
+ }
- final CrossSourceStatementReactor.BuildAction reactor = YangInferencePipeline.RFC6020_REACTOR.newBuild(statementParserMode, ifFeaturePredicate);
+ public static SchemaContext parseYangSources(final StatementParserMode statementParserMode,
+ final Set<QName> supportedFeatures, final Collection<? extends StatementStreamSource> sources)
+ throws SourceException, ReactorException {
+ final CrossSourceStatementReactor.BuildAction reactor = YangInferencePipeline.RFC6020_REACTOR.newBuild(
+ statementParserMode);
reactor.addSources(sources);
+ if (supportedFeatures != null) {
+ reactor.setSupportedFeatures(supportedFeatures);
+ }
return reactor.buildEffective();
}
public static SchemaContext parseYangSources(final File... files) throws SourceException, ReactorException,
- FileNotFoundException {
- return parseYangSources(StatementParserMode.DEFAULT_MODE, IfFeaturePredicates.ALL_FEATURES, files);
+ IOException, YangSyntaxErrorException {
+ return parseYangSources(StatementParserMode.DEFAULT_MODE, null, files);
}
- public static SchemaContext parseYangSources(final StatementParserMode statementParserMode, final Predicate<QName> ifFeaturePredicate, final File... files) throws SourceException,
- ReactorException, FileNotFoundException {
-
- final StatementStreamSource[] sources = new StatementStreamSource[files.length];
+ public static SchemaContext parseYangSources(final StatementParserMode statementParserMode,
+ final Set<QName> supportedFeatures, final File... files) throws SourceException,
+ ReactorException, IOException, YangSyntaxErrorException {
- for (int i = 0; i < files.length; i++) {
- sources[i] = new YangStatementSourceImpl(new NamedFileInputStream(files[i], files[i].getPath()));
+ final Collection<YangStatementStreamSource> sources = new ArrayList<>(files.length);
+ for (File file : files) {
+ sources.add(YangStatementStreamSource.create(YangTextSchemaSource.forFile(file)));
}
- return parseYangSources(statementParserMode, ifFeaturePredicate, sources);
+ return parseYangSources(statementParserMode, supportedFeatures, sources);
}
public static SchemaContext parseYangSources(final Collection<File> files) throws SourceException, ReactorException,
- FileNotFoundException {
+ IOException, YangSyntaxErrorException {
return parseYangSources(files, StatementParserMode.DEFAULT_MODE);
}
public static SchemaContext parseYangSources(final Collection<File> files, final StatementParserMode statementParserMode)
- throws SourceException, ReactorException, FileNotFoundException {
- return parseYangSources(statementParserMode, IfFeaturePredicates.ALL_FEATURES, files.toArray(new File[files.size()]));
+ throws SourceException, ReactorException, IOException, YangSyntaxErrorException {
+ return parseYangSources(statementParserMode, null, files.toArray(new File[files.size()]));
}
public static SchemaContext parseYangSources(final String yangSourcesDirectoryPath) throws SourceException,
- ReactorException, FileNotFoundException, URISyntaxException {
+ ReactorException, URISyntaxException, IOException, YangSyntaxErrorException {
return parseYangSources(yangSourcesDirectoryPath, StatementParserMode.DEFAULT_MODE);
}
public static SchemaContext parseYangSource(final String yangSourcePath) throws SourceException, ReactorException,
- FileNotFoundException, URISyntaxException {
- return parseYangSource(yangSourcePath, StatementParserMode.DEFAULT_MODE, IfFeaturePredicates.ALL_FEATURES);
+ URISyntaxException, IOException, YangSyntaxErrorException {
+ return parseYangSource(yangSourcePath, StatementParserMode.DEFAULT_MODE, null);
}
- public static SchemaContext parseYangSource(final String yangSourcePath, final Predicate<QName> ifFeaturesPredicate)
- throws SourceException, FileNotFoundException, ReactorException, URISyntaxException {
- return parseYangSource(yangSourcePath, StatementParserMode.DEFAULT_MODE, ifFeaturesPredicate);
+ public static SchemaContext parseYangSource(final String yangSourcePath, final Set<QName> supportedFeatures)
+ throws SourceException, ReactorException, URISyntaxException, IOException, YangSyntaxErrorException {
+ return parseYangSource(yangSourcePath, StatementParserMode.DEFAULT_MODE, supportedFeatures);
}
public static SchemaContext parseYangSource(final String yangSourcePath,
- final StatementParserMode statementParserMode, final Predicate<QName> ifFeaturePredicate)
- throws SourceException, ReactorException, FileNotFoundException, URISyntaxException {
+ final StatementParserMode statementParserMode, final Set<QName> supportedFeatures)
+ throws SourceException, ReactorException, URISyntaxException, IOException, YangSyntaxErrorException {
final URL source = StmtTestUtils.class.getResource(yangSourcePath);
final File sourceFile = new File(source.toURI());
- return parseYangSources(statementParserMode, ifFeaturePredicate, sourceFile);
+ return parseYangSources(statementParserMode, supportedFeatures, sourceFile);
}
- public static SchemaContext parseYangSources(final String yangSourcesDirectoryPath, final StatementParserMode statementParserMode)
- throws SourceException, ReactorException, FileNotFoundException, URISyntaxException {
+ public static SchemaContext parseYangSources(final String yangSourcesDirectoryPath,
+ final StatementParserMode statementParserMode) throws SourceException, ReactorException,
+ URISyntaxException, IOException, YangSyntaxErrorException {
+ return parseYangSources(yangSourcesDirectoryPath, null, statementParserMode);
+ }
+
+ public static SchemaContext parseYangSources(final String yangSourcesDirectoryPath,
+ final Set<QName> supportedFeatures, final StatementParserMode statementParserMode) throws SourceException,
+ ReactorException, URISyntaxException, IOException, YangSyntaxErrorException {
final URL resourceDir = StmtTestUtils.class.getResource(yangSourcesDirectoryPath);
final File testSourcesDir = new File(resourceDir.toURI());
- return parseYangSources(statementParserMode, IfFeaturePredicates.ALL_FEATURES, testSourcesDir.listFiles(YANG_FILE_FILTER));
+ return parseYangSources(statementParserMode, supportedFeatures, testSourcesDir.listFiles(YANG_FILE_FILTER));
}
public static SchemaContext parseYinSources(final String yinSourcesDirectoryPath, final StatementParserMode statementParserMode)
return parseYinSources(statementParserMode, testSourcesDir.listFiles(YIN_FILE_FILTER));
}
- public static SchemaContext parseYinSources(final StatementParserMode statementParserMode, final File... files) throws SourceException,
- ReactorException, FileNotFoundException {
+ public static SchemaContext parseYinSources(final StatementParserMode statementParserMode, final File... files)
+ throws SourceException, ReactorException, FileNotFoundException {
final StatementStreamSource[] sources = new StatementStreamSource[files.length];
requestedModuleImport.getRevision());
return importedModule;
}
+
+ public static SchemaContext parseYangSources(final String yangFilesDirectoryPath, final String yangLibsDirectoryPath)
+ throws URISyntaxException, ReactorException, IOException, YangSyntaxErrorException {
+ return parseYangSources(yangFilesDirectoryPath, yangLibsDirectoryPath, null);
+ }
+
+ public static SchemaContext parseYangSources(final String yangFilesDirectoryPath,
+ final String yangLibsDirectoryPath, final Set<QName> supportedFeatures) throws URISyntaxException,
+ ReactorException, IOException, YangSyntaxErrorException {
+ final File yangsDir = new File(StmtTestUtils.class.getResource(yangFilesDirectoryPath).toURI());
+ final File libsDir = new File(StmtTestUtils.class.getResource(yangLibsDirectoryPath).toURI());
+
+ return parseYangSources(yangsDir.listFiles(YANG_FILE_FILTER), libsDir.listFiles(YANG_FILE_FILTER),
+ supportedFeatures);
+ }
+
+ private static SchemaContext parseYangSources(final File[] yangFiles, final File[] libFiles,
+ final Set<QName> supportedFeatures) throws ReactorException, IOException, YangSyntaxErrorException {
+ final StatementStreamSource[] yangSources = new StatementStreamSource[yangFiles.length];
+ for (int i = 0; i < yangFiles.length; i++) {
+ yangSources[i] = YangStatementStreamSource.create(YangTextSchemaSource.forFile(yangFiles[i]));
+ }
+
+ final StatementStreamSource[] libSources = new StatementStreamSource[libFiles.length];
+ for (int i = 0; i < libFiles.length; i++) {
+ libSources[i] = YangStatementStreamSource.create(YangTextSchemaSource.forFile(libFiles[i]));
+ }
+
+ return parseYangSources(yangSources, libSources, supportedFeatures);
+ }
+
+ private static SchemaContext parseYangSources(final StatementStreamSource[] yangSources,
+ final StatementStreamSource[] libSources, final Set<QName> supportedFeatures) throws ReactorException {
+
+ final CrossSourceStatementReactor.BuildAction reactor = YangInferencePipeline.RFC6020_REACTOR.newBuild();
+ reactor.addSources(yangSources);
+ reactor.addLibSources(libSources);
+ if (supportedFeatures != null) {
+ reactor.setSupportedFeatures(supportedFeatures);
+ }
+
+ return reactor.buildEffective();
+ }
}