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

Prefix conda environment gets run by name instead of path #24627

Closed
karthiknadig opened this issue Dec 17, 2024 · 11 comments · Fixed by #24709
Closed

Prefix conda environment gets run by name instead of path #24627

karthiknadig opened this issue Dec 17, 2024 · 11 comments · Fixed by #24709
Assignees
Labels
bug Issue identified by VS Code Team member as probable bug triage-needed Needs assignment to the proper sub-team

Comments

@karthiknadig
Copy link
Member

Discussed in #24626

Originally posted by gandhis1 December 17, 2024
In version 2024.16.1, when I run test discovery, or really any command that ultimately invokes conda, I see the following:

2024-12-17 10:09:14.508 [info] > conda run -p ./envs/linux_main --no-capture-output python ~/.vscode-server/extensions/ms-python.python-2024.16.1-linux-x64/python_files/get_output_via_markers.py -m pytest -p vscode_pytest --collect-only .

This works, and this is what I expect, since my environments are nameless and path-based. Here is the anonymized output of conda info --env:

                         /home/myuser/git/myrepo/envs/linux_arctic
                         /home/myuser/git/myrepo/envs/linux_main
base                  *  /opt/miniconda3

In recent versions (this has been ongoing for several weeks I believe), I see this (2024.23.2024121701):

2024-12-17 10:32:03.637 [info] > ~/git/myrepo2/envs/linux_py38/bin/conda run -n linux_main --no-capture-output python ~/.vscode-server/extensions/ms-python.python-2024.23.2024121701-linux-x64/python_files/get_output_via_markers.py ~/.vscode-server/extensions/ms-python.python-2024.23.2024121701-linux-x64/python_files/printEnvVariables.py
2024-12-17 10:32:03.637 [info] shell: bash
2024-12-17 10:32:04.012 [error] getActivatedEnvironmentVariables Error: Command failed: /home/myuser/git/myrepo/envs/linux_py38/bin/conda run -n linux_main --no-capture-output python /home/myuser/.vscode-server/extensions/ms-python.python-2024.23.2024121701-linux-x64/python_files/get_output_via_markers.py /home/myuser/.vscode-server/extensions/ms-python.python-2024.23.2024121701-linux-x64/python_files/printEnvVariables.py

EnvironmentLocationNotFound: Not a conda environment: /home/myuser/git/myrepo/envs/239fb791f5e1df62ec6015e65582c32020a01c5d/envs/linux_main


    at genericNodeError (node:internal/errors:984:15)
    at wrappedFn (node:internal/errors:538:14)
    at ChildProcess.exithandler (node:child_process:422:12)
    at ChildProcess.emit (node:events:530:35)
    at maybeClose (node:internal/child_process:1104:16)
    at Socket.<anonymous> (node:internal/child_process:456:11)
    at Socket.emit (node:events:518:28)
    at Pipe.<anonymous> (node:net:343:12) {
  code: 1,
  killed: false,
  signal: null,
  cmd: '/home/myuser/git/myrepo2/envs/linux_py38/bin/conda run -n linux_main --no-capture-output python /home/myuser/.vscode-server/extensions/ms-python.python-2024.23.2024121701-linux-x64/python_files/get_output_via_markers.py /home/myuser/.vscode-server/extensions/ms-python.python-2024.23.2024121701-linux-x64/python_files/printEnvVariables.py'
}

Fundamentally, the issue I see is that this should be using -p and not -n. It's also using a somewhat arbitrary conda executable.

@github-actions github-actions bot added the triage-needed Needs assignment to the proper sub-team label Dec 17, 2024
@karthiknadig
Copy link
Member Author

karthiknadig commented Dec 17, 2024

@gandhis1 Can you provide the initial part of the logs:
Image

The logs that you shared here don't contain a line that says " Conda env is named/prefix". it comes from the detector.
#24626 (reply in thread)

@gandhis1
Copy link

gandhis1 commented Dec 17, 2024

Here is everything before "discover tests":

2024-12-17 11:38:46.030 [info] Experiment 'pythonRecommendTensorboardExt' is active
2024-12-17 11:38:46.030 [info] Experiment 'pythonTerminalEnvVarActivation' is active
2024-12-17 11:38:46.030 [info] Experiment 'pythonTestAdapter' is active
2024-12-17 11:38:46.030 [info] Native locator: Refresh started
2024-12-17 11:38:47.511 [info] > pyenv which python
2024-12-17 11:38:47.511 [info] cwd: .
2024-12-17 11:38:47.534 [info] Conda environment manager found at: /opt/miniconda3/bin/conda
2024-12-17 11:38:47.550 [info] Conda environment manager found at: /home/myuser/git/myrepo2/envs/linux_py311/bin/conda
2024-12-17 11:38:47.555 [info] Conda environment manager found at: /home/myuser/git/myrepo2/envs/linux_py38/bin/conda
2024-12-17 11:38:47.562 [info] Native locator: Refresh finished in 1862 ms
2024-12-17 11:38:48.168 [info] > ~/git/myrepo2/envs/linux_py38/bin/conda info --json
2024-12-17 11:38:50.380 [info] Python interpreter path: ./envs/linux_main/bin/python

I don't see a line saying "Conda env is named"

@karthiknadig karthiknadig self-assigned this Dec 17, 2024
@karthiknadig karthiknadig added the bug Issue identified by VS Code Team member as probable bug label Dec 17, 2024
@karthiknadig
Copy link
Member Author

Can you ~/git/myrepo2/envs/linux_py38/bin/conda info --json ? That seems like your in project conda binary, as opposed to running conda info --json that uses your global conda binary.

@gandhis1
Copy link

gandhis1 commented Dec 17, 2024

Here is the output of that. As a clarification, note that linux_py38, linux_main, etc. are symbolic links to an environment using a hash as the name.

{
  "GID": 1339600513,
  "UID": 1339615977,
  "active_prefix": "/home/myuser/git/myrepo/envs/linux_main",
  "active_prefix_name": "/home/myuser/git/myrepo/envs/linux_main",
  "av_data_dir": "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d/etc/conda",
  "av_metadata_url_base": null,
  "channels": [
    "https://repo.anaconda.com/pkgs/main/linux-64",
    "https://repo.anaconda.com/pkgs/main/noarch",
    "https://repo.anaconda.com/pkgs/r/linux-64",
    "https://repo.anaconda.com/pkgs/r/noarch"
  ],
  "conda_build_version": "24.5.0",
  "conda_env_version": "24.7.1",
  "conda_location": "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d/lib/python3.8/site-packages/conda",
  "conda_prefix": "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d",
  "conda_shlvl": 2,
  "conda_version": "24.7.1",
  "config_files": [],
  "default_prefix": "/home/myuser/git/myrepo/envs/linux_main",
  "env_vars": {
    "CIO_TEST": "<not set>",
    "CONDA_ALLOW_SOFTLINKS": "false",
    "CONDA_DEFAULT_ENV": "linux_main",
    "CONDA_EXE": "/opt/miniconda3/bin/conda",
    "CONDA_PREFIX": "/home/myuser/git/myrepo/envs/linux_main",
    "CONDA_PREFIX_1": "/opt/miniconda3",
    "CONDA_PREFIX_2": "/home/myuser/git/myrepo/envs/linux_main",
    "CONDA_PROMPT_MODIFIER": "(linux_main) ",
    "CONDA_PYTHON_EXE": "/opt/miniconda3/bin/python",
    "CONDA_ROOT": "/opt/miniconda3",
    "CONDA_SHLVL": "2",
    "CURL_CA_BUNDLE": "<not set>",
    "JAVA_LD_LIBRARY_PATH": "/home/myuser/git/myrepo/envs/linux_main/lib/jvm/lib/server",
    "LD_PRELOAD": "<not set>",
    "PATH": "/home/myuser/.vscode-server/cli/servers/Stable-138f619c86f1199955d53b4166bef66ef252935c/server/bin/remote-cli:/opt/miniconda3/condabin:/home/myuser/git/myrepo/envs/linux_main/bin:/opt/miniconda3/condabin:/home/myuser/.local/bin:/home/myuser/bin:/opt/miniconda3/condabin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/myuser/micromamba:/opt/miniconda3/condabin:/home/myuser/.vscode-server/cli/servers/Stable-138f619c86f1199955d53b4166bef66ef252935c/server/bin/remote-cli:/opt/miniconda3/condabin:/opt/miniconda3/bin:/opt/miniconda3/condabin:/home/myuser/.local/bin:/home/myuser/bin:/opt/miniconda3/condabin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/myuser/micromamba:/home/myuser/.vscode-server/cli/servers/Stable-138f619c86f1199955d53b4166bef66ef252935c/server/bin/remote-cli:/opt/miniconda3/bin:/opt/miniconda3/condabin:/home/myuser/.local/bin:/home/myuser/bin:/opt/miniconda3/condabin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/myuser/micromamba",
    "REQUESTS_CA_BUNDLE": "<not set>",
    "SE_MANAGER_PATH": "/home/myuser/git/myrepo/envs/linux_main/bin/selenium-manager",
    "SSL_CERT_FILE": "/etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem"
  },
  "envs": [
    "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d",
    "/home/myuser/git/myrepo2/envs/linux_py311",
    "/home/myuser/git/myrepo2/envs/linux_py38",
    "/home/myuser/git/myrepo-systematic/envs/linux_arctic",
    "/home/myuser/git/myrepo/envs/linux_arctic",
    "/home/myuser/git/myrepo/envs/linux_main"
  ],
  "envs_dirs": [
    "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d/envs",
    "/home/myuser/.conda/envs"
  ],
  "netrc_file": null,
  "offline": false,
  "pkgs_dirs": [
    "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d/pkgs",
    "/home/myuser/.conda/pkgs"
  ],
  "platform": "linux-64",
  "python_version": "3.8.20.final.0",
  "rc_path": "/home/myuser/.condarc",
  "requests_version": "2.32.3",
  "root_prefix": "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d",
  "root_writable": true,
  "site_dirs": [],
  "solver": {
    "default": true,
    "name": "libmamba",
    "user_agent": "solver/libmamba conda-libmamba-solver/24.9.0 libmambapy/1.5.8"
  },
  "sys.executable": "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d/bin/python",
  "sys.prefix": "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d",
  "sys.version": "3.8.20 | packaged by conda-forge | (default, Sep 30 2024, 17:52:49) \n[GCC 13.3.0]",
  "sys_rc_path": "/home/myuser/git/myrepo2/envs/239fb791f5e1df62ec6015e65582c32020a01c5d/.condarc",
  "user_agent": "conda/24.7.1 requests/2.32.3 CPython/3.8.20 Linux/5.14.0-362.24.1.el9_3.x86_64 rhel/9.3 glibc/2.34 solver/libmamba conda-libmamba-solver/24.9.0 libmambapy/1.5.8",
  "user_rc_path": "/home/myuser/.condarc",
  "virtual_pkgs": [
    [
      "__archspec",
      "1",
      "cascadelake"
    ],
    [
      "__conda",
      "24.7.1",
      "0"
    ],
    [
      "__glibc",
      "2.34",
      "0"
    ],
    [
      "__linux",
      "5.14.0",
      "0"
    ],
    [
      "__unix",
      "0",
      "0"
    ]
  ]
}

@karthiknadig
Copy link
Member Author

@gandhis1 Can you try setting python.condaPath setting in your user settings? Just so it prevents python extension for seeing other conda that it probably should not.

@leeleavitt
Copy link

leeleavitt commented Dec 19, 2024

On version it runs this command,

conda run -p ./.venv --no-capture-output python ~/.vscode/extensions/ms-python.python-2024.4.1/python_files/get_output_via_markers.py ~/.vscode/extensions/ms-python.python-2024.4.1/python_files/printEnvVariables.py

On the new one it runs this command,

conda run -n .venv --no-capture-output python ~/.vscode/extensions/ms-python.python-2024.22.0-darwin-arm64/python_files/get_output_via_markers.py ~/.vscode/extensions/ms-python.python-2024.22.0-darwin-arm64/python_files/printEnvVariables.py

@gandhis1
Copy link

Do you need any more information to replicate the issue? I think replication could be as simple as creating a path-based, anonymous conda environment, and then attempting to use it as the interpreter in VS code.

@aicd0
Copy link

aicd0 commented Jan 4, 2025

Same issues here, anyone looking into this?

@karthiknadig karthiknadig changed the title Nameless conda environment gets run by name instead of path Prefix conda environment gets run by name instead of path Jan 9, 2025
@gandhis1
Copy link

So the attached PR appears to restore the original behavior as for which conda executable gets used, but did you confirm that was the root cause of VS code referencing an anonymous conda environment with a -p path parameter and not a -n name parameter? If the latter issue isn't fixed I suspect the problem I reported here won't be either.

@karthiknadig
Copy link
Member Author

The environments dirs returned when using conda that was not on path led to wrong checks when trying to determine if a environment was prefix or not. In cases where conda was using -n for -p, was because we were using wrong conda and it would tell us that the dir where the .conda env was is a default environments dir. Causing us to treat it as a named environment.

@karthiknadig
Copy link
Member Author

There is also another issue that pet is reporting multiple base environments.
microsoft/python-environment-tools#184

A workaround for that is remove conda installed in the environment, typically you don't need to have those, since there is already a global conda available.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Issue identified by VS Code Team member as probable bug triage-needed Needs assignment to the proper sub-team
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants