diff --git a/README.md b/README.md index 2953d722..f19c0a43 100644 --- a/README.md +++ b/README.md @@ -320,7 +320,7 @@ optional arguments: set the directory where decoder outputs will be stored -ne, --no-emoji set to use plain text instead of emojis -tsd TEST_SUITES_DIR, --test-suites-dir TEST_SUITES_DIR - set the directory where test suite will be read from + set directory where test suite will be read from, multiple directories are supported with OS path separator (:) subcommands: {list,l,run,r,download,d,reference,f} diff --git a/fluster/fluster.py b/fluster/fluster.py index 6457f18d..2a60607d 100644 --- a/fluster/fluster.py +++ b/fluster/fluster.py @@ -19,7 +19,7 @@ import os import os.path from functools import lru_cache -from typing import List, Dict, Any, Tuple, Optional +from typing import List, Dict, Any, Tuple, Optional, Iterator import sys from enum import Enum from shutil import rmtree @@ -161,9 +161,14 @@ def __init__( f" * output_dir: {self.output_dir}" ) + def _walk_test_suite_dir(self) -> Iterator[Tuple[str, List[str], List[str]]]: + for test_suite_dir in self.test_suites_dir.split(os.pathsep): + for root, dirnames, files in os.walk(test_suite_dir): + yield (root, dirnames, files) + @lru_cache(maxsize=128) def _load_test_suites(self) -> None: - for root, _, files in os.walk(self.test_suites_dir): + for root, _, files in self._walk_test_suite_dir(): for file in files: if os.path.splitext(file)[1] == ".json": try: diff --git a/fluster/main.py b/fluster/main.py index bbad903f..b8343180 100644 --- a/fluster/main.py +++ b/fluster/main.py @@ -161,7 +161,10 @@ def _create_parser(self) -> argparse.ArgumentParser: parser.add_argument( "-tsd", "--test-suites-dir", - help="set the directory where test suite will be read from", + help=( + "set directory where test suite will be read from, " + f"multiple directories are supported with OS path separator ({os.pathsep})" + ), default=self.test_suites_dir, ) subparsers = parser.add_subparsers(title="subcommands")