Skip to content

Subprocess return code is incorrectly returned #737

Open
@rjra100

Description

@rjra100

Type: Bug

Behaviour

It appears that if a python subprocess is called from a debugged process and fails, the return code of the subprocess is not correctly passed on to the caller.

Steps to reproduce:

Example code experiment.py:

import subprocess
import sys

proc = subprocess.run(
    [sys.executable, "-mfred"],
    check=False,
)

print(f"returncode: {proc.returncode}")

If run on the command line, this produces

$ /opt/bb/bin/python3.12 ~/experiment.py 
/opt/bb/bin/python3.12: No module named fred
returncode: 1

If run via a launch config such as

        {
            "name": "Python Debugger: Experiment",
            "type": "debugpy",
            "request": "launch",
            "program": "/home/ralexander72/experiment.py",
            "console": "integratedTerminal"
        }

The output is

$  cd /home/ralexander72/test ; /usr/bin/env /opt/bb/bin/python3.12 /bb/data/ralexander72/vscode-server/extensions/ms-python.debugpy-2025.8.0-linux-x64/bundled/libs/debugpy/adapter/../../debugpy/launcher 60207 -- /home/ralexander72/experiment.py
No module named fred
returncode: 0

Similarly, running with check=True produces an exception in the non-debugged case but apparent success when run via the debugger.

Adding "subProcess": false to the launch config produces the expected output, so presumably the problem is that the debugger is intercepting and debugging the subprocess (which is normally nice behaviour), but failing to pass on the correct return code after termination of the subprocess.

This is highly unexpected behaviour - could you please investigate?

Extension version: 2025.8.0
VS Code version: Code 1.101.1 (18e3a1ec544e6907be1e944a94c496e302073435, 2025-06-18T13:35:12.605Z)
OS version: Windows_NT x64 10.0.19045
Modes:
Connection to 'ssh-remote+mydev' could not be established
Remote OS version: Linux x64 4.18.0-553.50.1.el8_10.x86_64
Remote OS version: Linux x64 4.18.0-553.50.1.el8_10.x86_64

  • Python version (& distribution if applicable, e.g. Anaconda): 3.12.11
  • Type of virtual environment used (e.g. conda, venv, virtualenv, etc.): Unknown
System Info
Item Value
CPUs Intel(R) Core(TM) i9-10980XE CPU @ 3.00GHz (36 x 3000)
GPU Status 2d_canvas: enabled
canvas_oop_rasterization: enabled_on
direct_rendering_display_compositor: disabled_off_ok
gpu_compositing: enabled
multiple_raster_threads: enabled_on
opengl: enabled_on
rasterization: enabled
raw_draw: disabled_off_ok
skia_graphite: disabled_off
video_decode: enabled
video_encode: enabled
vulkan: disabled_off
webgl: enabled
webgl2: enabled
webgpu: enabled
webnn: disabled_off
Load (avg) undefined
Memory (System) 127.80GB (95.16GB free)
Process Argv --folder-uri vscode-remote://ssh-remote%2Bmydev/bb/mbige/mbig_u28868517/ws/nextstep
Screen Reader no
VM 0%

Connection to 'ssh-remote+mydev' could not be established

Item Value
Remote SSH: mydev
OS Linux x64 4.18.0-553.50.1.el8_10.x86_64
CPUs Intel Xeon Processor (Cascadelake) (16 x 0)
Memory (System) 93.89GB (78.18GB free)
VM 0%
Item Value
Remote SSH: mydev
OS Linux x64 4.18.0-553.50.1.el8_10.x86_64
CPUs Intel Xeon Processor (Cascadelake) (16 x 0)
Memory (System) 93.89GB (78.18GB free)
VM 0%

Metadata

Metadata

Assignees

Labels

triage-neededNeeds assignment to the proper sub-team

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions