From e8dec8175c4d7901d420dc71b508cee8f0cb05d1 Mon Sep 17 00:00:00 2001 From: karajan1001 Date: Sat, 5 Jun 2021 17:22:56 +0800 Subject: [PATCH] dvc ls: not raise PathMissingError on empty dir. fix #5841 --- dvc/repo/ls.py | 26 +++++++++++++++++++------- tests/func/test_ls.py | 13 ++++++++++++- 2 files changed, 31 insertions(+), 8 deletions(-) diff --git a/dvc/repo/ls.py b/dvc/repo/ls.py index c27c4a6d0b..d6479798ff 100644 --- a/dvc/repo/ls.py +++ b/dvc/repo/ls.py @@ -1,10 +1,22 @@ import os from itertools import chain +from typing import TYPE_CHECKING, Optional from dvc.exceptions import PathMissingError +if TYPE_CHECKING: + from dvc.fs.repo import RepoFileSystem -def ls(url, path=None, rev=None, recursive=None, dvc_only=False): + from . import Repo + + +def ls( + url: str, + path: Optional[str] = None, + rev: str = None, + recursive: bool = None, + dvc_only: bool = False, +): """Methods for getting files and outputs for the repo. Args: @@ -31,10 +43,7 @@ def ls(url, path=None, rev=None, recursive=None, dvc_only=False): with Repo.open(url, rev=rev, subrepos=True, uninitialized=True) as repo: path = path or "" - ret = _ls(repo.repo_fs, path, recursive, dvc_only) - - if path and not ret: - raise PathMissingError(path, repo, dvc_only=dvc_only) + ret = _ls(repo, path, recursive, dvc_only) ret_list = [] for path, info in ret.items(): @@ -44,13 +53,16 @@ def ls(url, path=None, rev=None, recursive=None, dvc_only=False): return ret_list -def _ls(fs, path, recursive=None, dvc_only=False): +def _ls( + repo: "Repo", path: str, recursive: bool = None, dvc_only: bool = False +): + fs: "RepoFileSystem" = repo.repo_fs fs_path = fs.from_os_path(path) try: fs_path = fs.info(fs_path)["name"] except FileNotFoundError: - return {} + raise PathMissingError(path, repo, dvc_only=dvc_only) infos = {} for root, dirs, files in fs.walk( diff --git a/tests/func/test_ls.py b/tests/func/test_ls.py index a08c92dd1b..569ecd9506 100644 --- a/tests/func/test_ls.py +++ b/tests/func/test_ls.py @@ -150,9 +150,20 @@ def test_ls_repo_with_path_dir_dvc_only_empty(tmp_dir, dvc, scm): tmp_dir.scm_gen(FS_STRUCTURE, commit="init") tmp_dir.dvc_gen(DVC_STRUCTURE, commit="dvc") tmp_dir.scm_gen({"folder/.keep": "content"}, commit="add .keep") + tmp_dir.scm_gen({"empty_scm_folder/": {}}, commit="add scm empty") + tmp_dir.dvc_gen({"empty_dvc_folder": {}}, commit="empty dvc folder") with pytest.raises(PathMissingError): - Repo.ls(os.fspath(tmp_dir), path="folder", dvc_only=True) + Repo.ls(os.fspath(tmp_dir), path="not_exist_folder") + + assert Repo.ls(os.fspath(tmp_dir), path="empty_scm_folder") == [] + + assert Repo.ls(os.fspath(tmp_dir), path="folder", dvc_only=True) == [] + + assert ( + Repo.ls(os.fspath(tmp_dir), path="empty_dvc_folder", dvc_only=True) + == [] + ) def test_ls_repo_with_path_subdir(tmp_dir, dvc, scm):