Skip to content

Script subprocesses cannot be debugged #1929

@anuraaga

Description

@anuraaga

Currently, if a python script is executed directly as a subprocess by using a shebang, it isn't debugged.

This is clear from the code which is currently only checking the executable name for python and family.

for name in _get_str_type_compatible(filename, ["python", "jython", "pypy"]):

Looking at pydevd logs, it exits with "Process is not python, returning." as expected from the code.

pydev_log.debug("Process is not python, returning.")

Not simple, but IIUC fixing this means that it should open the file, check for a shebang, and replace the executable with the shebang line + script location. I'm uncertain if only patch_args needs to be updated with such logic or every caller of is_python.

Note I don't create the script myself but use project.scripts, and uv_build compiles the script wrapper when running uv sync. A manually shebanged file would naturally have the same issue though is easier for the user to replace with a python invocation - with a project.scripts, there is some awkwardness with it being in the .venv/bin directory, not cwd (I am using a multi-project workspace). As a workaround, I will probably still resolve the absolute path of the script and prepend python.

Environment data

Skipping since it's obvious from the code

Actual behavior

debugpy does not patch the subprocess args for a python script, causing debug to fail

Expected behavior

A python script subprocess can be debugged

Steps to reproduce:

  1. Create a python script with a shebang
  2. Create another script that invokes the script directly with subprocess.run, without python
  3. Debug the launcher script with a breakpoint in the shebang script

My shebang script for a django project created by uv looks like

manage

#!/Users/anuraag/git/workspace/.venv/bin/python3
# -*- coding: utf-8 -*-
import sys
from sysadmin.manage import main
if __name__ == "__main__":
    if sys.argv[0].endswith("-script.pyw"):
        sys.argv[0] = sys.argv[0][:-11]
    elif sys.argv[0].endswith(".exe"):
        sys.argv[0] = sys.argv[0][:-4]
    sys.exit(main())

Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't working

    Type

    No fields configured for Bug.

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions