* -h,--help print help message and exit.
* -p,--path <arg> path is a colon (:) separated list of directories
* to search for yang modules.
+ * -r, --recursive recursive search of directories specified by -p option
* -v,--verbose shows details about the results of test running.
*
*/
path.setRequired(false);
options.addOption(path);
+ final Option recursiveSearch = new Option("r", "recursive", false,
+ "recursive search of directories specified by -p option.");
+ recursiveSearch.setRequired(false);
+ options.addOption(recursiveSearch);
+
final Option verbose = new Option("v", "verbose", false, "shows details about the results of test running.");
verbose.setRequired(false);
options.addOption(verbose);
final List<String> yangFiles = Arrays.asList(arguments.getArgs());
final HashSet<QName> supportedFeatures = initSupportedFeatures(arguments);
- runSystemTest(yangLibDirs, yangFiles, supportedFeatures);
+ runSystemTest(yangLibDirs, yangFiles, supportedFeatures, arguments.hasOption("recursive"));
}
private static void runSystemTest(final List<String> yangLibDirs, final List<String> yangFiles,
- final HashSet<QName> supportedFeatures) {
+ final HashSet<QName> supportedFeatures, final boolean recursiveSearch) {
LOG.log(Level.INFO, "Yang model dirs: {0} ", yangLibDirs);
LOG.log(Level.INFO, "Yang model files: {0} ", yangFiles);
LOG.log(Level.INFO, "Supported features: {0} ", supportedFeatures);
final Stopwatch stopWatch = Stopwatch.createStarted();
try {
- context = SystemTestUtils.parseYangSources(yangLibDirs, yangFiles, supportedFeatures);
+ context = SystemTestUtils.parseYangSources(yangLibDirs, yangFiles, supportedFeatures, recursiveSearch);
} catch (final Exception e) {
LOG.log(Level.SEVERE, "Failed to create SchemaContext.", e);
System.exit(1);
package org.opendaylight.yangtools.yang.parser.system.test;
+import com.google.common.base.Preconditions;
import java.io.File;
import java.io.FileFilter;
import java.io.FileNotFoundException;
};
static SchemaContext parseYangSources(final List<String> yangLibDirs, final List<String> yangTestFiles,
- final Set<QName> supportedFeatures) throws FileNotFoundException, ReactorException {
+ final Set<QName> supportedFeatures, final boolean recursiveSearch) throws FileNotFoundException, ReactorException {
/*
* Current dir "." should be always present implicitly in the list of
* directories where dependencies are searched for
final List<File> libFiles = new ArrayList<>();
for (final String yangLibDir : yangLibDirs) {
- libFiles.addAll(getYangFiles(yangLibDir));
+ libFiles.addAll(getYangFiles(yangLibDir, recursiveSearch));
}
final List<File> testFiles = new ArrayList<>();
return yangSources;
}
- private static Collection<File> getYangFiles(final String yangSourcesDirectoryPath) throws FileNotFoundException {
+ private static Collection<File> getYangFiles(final String yangSourcesDirectoryPath, final boolean recursiveSearch)
+ throws FileNotFoundException {
final File testSourcesDir = new File(yangSourcesDirectoryPath);
if (testSourcesDir == null || !testSourcesDir.isDirectory()) {
throw new FileNotFoundException(String.format("%s no such directory", yangSourcesDirectoryPath));
}
- return Arrays.asList(testSourcesDir.listFiles(YANG_FILE_FILTER));
+
+ return recursiveSearch ? searchYangFiles(testSourcesDir) : Arrays.asList(testSourcesDir.listFiles(YANG_FILE_FILTER));
+ }
+
+ private static List<File> searchYangFiles(final File dir) {
+ Preconditions.checkNotNull(dir);
+ Preconditions.checkArgument(dir.isDirectory(), "File %s is not a directory", dir.getPath());
+
+ final List<File> yangFiles = new ArrayList<>();
+ for (final File file : dir.listFiles()) {
+ if (file.isDirectory()) {
+ yangFiles.addAll(searchYangFiles(file));
+ } else if (file.isFile() && file.getName().toLowerCase().endsWith(".yang")) {
+ yangFiles.add(file);
+ }
+ }
+
+ return yangFiles;
}
}