Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

list: fails if a DVC-tracked directory is empty but present #6106

Closed
shcheklein opened this issue Jun 3, 2021 · 10 comments
Closed

list: fails if a DVC-tracked directory is empty but present #6106

shcheklein opened this issue Jun 3, 2021 · 10 comments
Assignees
Labels
A: status Related to the dvc diff/list/status bug Did we break something? p1-important Important, aka current backlog of things to do product: VSCode Integration with VSCode extension

Comments

@shcheklein
Copy link
Member

Bug Report

Description

(.env) √ Projects/get-started-experiments % dvc list . data/fashion-mnist/prepared
ERROR: failed to list '.' - The path 'data/fashion-mnist/prepared' does not exist in the target repository
'/Users/ivan/Projects/get-started-experiments' neither as a DVC output nor as a Git-tracked file.

even though, this path does exist, and it is being tracked by DVC:

schema: '2.0'
stages:
  prepare:
    cmd: python3 src/prepare.py
    deps:
    - path: data/fashion-mnist/raw/
      md5: 8a31b1338b609cf1133d1df639de606c.dir
      size: 30878645
      nfiles: 4
    - path: src/prepare.py
      md5: 2c9ddd60ad065771628c58c618663050
      size: 3881
    params:
      params.yaml:
        prepare.remix: false
        prepare.remix_split: 0.2
        prepare.seed: 20210428
    outs:
    - path: data/fashion-mnist/prepared
      md5: c5095cd3e98121bc8d2bebe27d702ab5.dir
      size: 54951020
      nfiles: 2
...

Reproduce

git clone [email protected]:iterative/get-started-experiments.git
cd get-started-experiments
mkdir data/fashion-mnist/prepared
dvc list . data/fashion-mnist/prepared

gives:

ERROR: failed to list '.' - The path 'data/fashion-mnist/prepared' does not exist in the target repository '/Users/ivan/Projects/test-bug' neither as a DVC output nor as a Git-tracked file.

Expected

To see prepared.

Environment information

(.env) √ Projects/test-bug % dvc version
DVC version: 2.3.0+eb46c0
---------------------------------
Platform: Python 3.8.9 on macOS-10.15.6-x86_64-i386-64bit
Supports: All remotes
Cache types: <https://error.dvc.org/no-dvc-cache>
Caches: local
Remotes: https
Workspace directory: apfs on /dev/disk1s1
Repo: dvc, git
@shcheklein shcheklein added the bug Did we break something? label Jun 3, 2021
@dberenbaum
Copy link
Collaborator

@shcheklein could you give some context on priority?

@shcheklein
Copy link
Member Author

We can discuss this on the next VS Code <> DVC meetings what would be the best way for us to communicate - regular issues vs those that we have in VS Code. Broadly speaking, VS Code depends on dvc list, dvc diff, dvc status, dvc pull, dvc checkout in its basic (files/datasets) feature. And it uses those commands to the full extent - different options, targets, etc - and we see a lot of rough edges now. In a lot of cases it can wait, but it will block the release (not date yet).

My take. Before the release, we'll need to stabilize those commands - their output (exits codes, etc), performance, their behavior with different options/targets.

@shcheklein
Copy link
Member Author

VS Code alpha users hit this issue: iterative/vscode-dvc#529

@dberenbaum dberenbaum added product: VSCode Integration with VSCode extension p1-important Important, aka current backlog of things to do labels Jun 4, 2021
@karajan1001
Copy link
Contributor

duplicated with #5841 ?

@dberenbaum
Copy link
Collaborator

#5841 doesn't look like it's a dvc-tracked directory, but otherwise they look the same, and I don't think that part should matter here? In either case, dvc list should show the directory and not throw an error.

@shcheklein
Copy link
Member Author

Quick note: I know that get-started-experiments has changed underneath us. Please let me know if you need a better reproduction script. The current one is not exactly correct. I'll try to update it today. And sorry about that, I'll be using mkdir style going forward.

@karajan1001
Copy link
Contributor

Quick note: I know that get-started-experiments has changed underneath us. Please let me know if you need a better reproduction script. The current one is not exactly correct. I'll try to update it today. And sorry about that, I'll be using mkdir style going forward.

#6120 might fix it, and we have a reproduction script in it.

@dberenbaum
Copy link
Collaborator

@karajan1001 @efiop When will get back to #6120?

@efiop efiop moved this from Backlog to Todo in DVC May 3, 2022
@karajan1001 karajan1001 moved this from Todo to Review In Progress in DVC May 11, 2022
@karajan1001
Copy link
Contributor

@mattlbeck could you please try if it works on the latest main branch?

@efiop
Copy link
Contributor

efiop commented May 13, 2022

Closing for now, should be fixed by #6120

@efiop efiop closed this as completed May 13, 2022
Repository owner moved this from Review In Progress to Done in DVC May 13, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A: status Related to the dvc diff/list/status bug Did we break something? p1-important Important, aka current backlog of things to do product: VSCode Integration with VSCode extension
Projects
No open projects
Archived in project
Development

No branches or pull requests

5 participants