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

Test Discovery failing #24656

Closed
eleanorjboyd opened this issue Dec 24, 2024 · 28 comments · Fixed by #24690
Closed

Test Discovery failing #24656

eleanorjboyd opened this issue Dec 24, 2024 · 28 comments · Fixed by #24690
Assignees
Labels
bug Issue identified by VS Code Team member as probable bug regression Bug didn't exist in a previous release triage-needed Needs assignment to the proper sub-team

Comments

@eleanorjboyd
Copy link
Member

eleanorjboyd commented Dec 24, 2024

Details: Currently test discovery will "hang" with version 2024.22.1 if you have >30 tests in your workspace due to a buffer overflow issue. This should only occur for Mac and Linux machines.

Workaround: Downgrade your python extension version to 2024.20.*.

@eleanorjboyd eleanorjboyd added bug Issue identified by VS Code Team member as probable bug regression Bug didn't exist in a previous release labels Dec 24, 2024
@eleanorjboyd eleanorjboyd self-assigned this Dec 24, 2024
@github-actions github-actions bot added the triage-needed Needs assignment to the proper sub-team label Dec 24, 2024
@eleanorjboyd eleanorjboyd pinned this issue Dec 24, 2024
@brianoflondon
Copy link

brianoflondon commented Dec 24, 2024

If you don't have more than 30 tests in your workspace, are you even testing 🤪.

Merry Christmas, Happy Holidays, thanks for all you do, we'll survive till you fix it.

The way to downgrade: on the Extension page, click the drop down arrow on the Uninstall Button and you can "Install Specific Version...". Also make sure Auto Update is switched off or it will bounce you straight back to the broken one.

2024.22.0 seems to be working for me.
Image

@jflam
Copy link

jflam commented Dec 24, 2024

Just ran into this bug this AM. Confirming that downgrading is the correct interim solution for this.

@jbhannah
Copy link

jbhannah commented Dec 24, 2024

The codebase that I encountered this with and reported in #24655 is pretty small, only 16 tests and (per cov) 258 total statements. Downgrading to 2024.22.0, or disabling the pythonTestAdapter experiment in 2024.22.1, fixed the issue for me (but disabling the experiment also took away the neat little coverage indicators 😔, so I've chosen to downgrade for now).

@WellingtonNico
Copy link

Same problem here, there is not error logs, never ends finding tests, but in the python test logs pytest collect almost finished

this is the image of the hanging

Image

this is the logs when it collects successfully

[1m============================= test session starts ==============================�[0m
platform darwin -- Python 3.11.3, pytest-8.3.4, pluggy-1.5.0
rootdir: /Users/teste/projetos/pessoal/python/fastapi-todo-list
configfile: pytest.ini
plugins: asyncio-0.24.0, cov-6.0.0, anyio-4.7.0, xdist-3.6.1
asyncio: mode=Mode.AUTO, default_loop_scope=None
collected 1 item

<Dir fastapi-todo-list>
  <Package tests>
    <Module test_first.py>
      <Function test_first_test>

�[32m========================== �[32m1 test collected�[0m�[32m in 0.01s�[0m�[32m ===========================�[0m
Starting now, all test run output will be sent to the Test Result panel, while test discovery output will be sent to the "Python" output channel instead of the "Python Test Log" channel. The "Python Test Log" channel will be deprecated within the next month. See https://github.com/microsoft/vscode-python/wiki/New-Method-for-Output-Handling-in-Python-Testing for details.

this is the log for that project that does hang when collecting

you can notice there is a log missing at the end that exists in the above log: test collected

�[1m============================= test session starts ==============================�[0m
platform darwin -- Python 3.12.8, pytest-8.3.4, pluggy-1.5.0 -- /Users/teste/projetos/pessoal/python/fastapi-todo_list/.venv/bin/python
cachedir: .pytest_cache
rootdir: /Users/teste/projetos/pessoal/python/fastapi-todo_list
configfile: pytest.ini
plugins: asyncio-0.24.0, cov-6.0.0, anyio-4.7.0, xdist-3.6.1
asyncio: mode=Mode.AUTO, default_loop_scope=None
�[1mcollecting ... �[0mcollected 17 items

<Dir fastapi-todo_list>
  <Package tests>
    <Dir auth>
      <Module test_auth_api.py>
        <Coroutine test_signup>
        <Coroutine test_login>
        <Coroutine test_me_with_todos>
        <Coroutine test_me_without_todos>
        <Coroutine test_logout_on_get_and_post>
    <Dir main>
      <Module test_main.py>
        <Coroutine test_healthy>
    <Dir todo>
      <Module test_todo_api.py>
        <Coroutine test_get_user_todos_security>
        <Coroutine test_get_user_todos>
        <Coroutine test_create_todo_security>
        <Coroutine test_create_todo>
        <Coroutine test_create_todo_title_validation>
        <Coroutine test_update_todo_security>
        <Coroutine test_update_todo>
        <Coroutine test_delete_todo_security>
        <Coroutine test_delete_todo>
        <Coroutine test_count_user_todos>
        <Coroutine test_get_todos_full>

I tried both with same python version and it does not work as well, both projects have the same dependencies, the only difference are the tests. In my Django projects the tests stopped working too, they were working just fine yesterday(2024/12/23), the same problem occurs, hangs when collecting the tests.

what I already tried:

  • fresh install
  • new user with totally fresh install and only the needed extensions(I thought it was gonna work)
  • different python versions

I'm currently using macOS, latest version with m3 pro chip, I also made sure I'm using the correct build version for apple silicon.

update

inside devcontainer it finds the tests and also run, but I was not able to debug them like yesterday, the debug menu appears, I can even set the breakpoints but the code never pauses(and yes, I'm did debug tests inside dev container before and it was working).
I have just a few extensions inside dev container, more than when I tested with fresh instalation with new user, for me it looks like something maybe related to macos

what worked

I downgraded python, and debugpy extension version, the tests were found, for all projects, but I still was not able to debug them, accidentaly I noticed it worked for a new project that I created just to test this case, so I cloned my repo into a new folder and everything worked again, so I also tried to update the python extensions again and It broke again, :(

@patrickkidd
Copy link

I also had this issue with 2024.22.1 - same symptoms and output panel contents - and downgrading to 2024.22.0 fixes it for me. I am reproducing it by adding additional test cases or longer test case names like the following snippet which suggests a buffer overflow to me. Sometimes it freezes at different buffer lengths but usually within 100 chars of the example in the snippet:

def test_one():
    pass

def test_two():
    pass

def test_three():
    pass

def test_four():
    pass

def test_five():
    pass

def test_six():
    pass

def test_seven():
    pass

def test_eight():
    pass

def test_nine():
    pass

def test_ten():
    pass

def test_eleven():
    pass

def test_twelve():
    pass

def test_thirteen():
    pass

def test_fourteen():
    pass

def test_fifteen():
    pass

def test_sixteen():
    pass

def test_seventeen():
    pass

def test_eighteen():
    pass

def test_nineteen():
    pass

def test_twenty():
    pass

def test_twenty_one():
    pass

def test_twenty_two():
    pass

def test_twenty_three():
    pass

def test_twenty_four():
    pass

def test_twenty_five():
    pass

def test_twenty_six():
    pass

## Uncomment only one of the below examples at a time to reproduce the problem, at least on my machine.

## SUCCEEDS

# def test_twenty_seven():
#     pass


## SUCCEEDS

# def test_twenty_1234567891234567890123456789012345():
#     pass

## FREEZES

# def test_twenty_12345678912345678901234567890123456():
#     pass


## FREEZES

# def test_twenty_seven():
#     pass

# def test_twenty_nine():
#     pass


@BobKerns
Copy link

Probably redundant since it's been identified as a buffer overflow issue, but the specific place it hangs in the plugin is line 943 in __init__.py :

            request = f"""content-length: {len(data)}\ncontent-type: application/json\n\n{data}"""
            __writer.write(request) # HANGS HERE 😞

            __writer.flush()

This may be a repeat bug? I've had discovery suddenly start hanging like this in the past, but didn't suspect an update, and never got to track it this far. It may be worth a warning in the code on the other end, and a test case.

@BobKerns
Copy link

Maybe one symptom of a larger problem? I'm seeing similar hangs elsewhere:

  • Markdown Preview
  • Markdown Preview Enhanced
  • Source Control

Source Control involves a large number of pending changes.
Markdown fails even with a small .md file, but perhaps prepended CSS, etc. makes it start off large?

@karthiknadig karthiknadig marked this as a duplicate of #24660 Dec 28, 2024
@karthiknadig karthiknadig marked this as a duplicate of #24663 Dec 28, 2024
@karthiknadig karthiknadig marked this as a duplicate of #24661 Dec 28, 2024
@karthiknadig karthiknadig changed the title Test Discovery Stalling for Large Workspaces Test Discovery failing Dec 28, 2024
@omriperl
Copy link

Any chance for a fix here soon?

@karthiknadig karthiknadig marked this as not a duplicate of #24661 Dec 29, 2024
@ricchyways
Copy link

Details

@dnwillia
Copy link

dnwillia commented Dec 30, 2024

I can confirm that v2024.22.1 is hanging on multiple repos using pytest (eg: https://github.com/ansys/pyansys-units), and that downgrading to v2024.22.0 makes it go away.

@Montags24
Copy link

I can confirm that v2024.22.1 is hanging on multiple repos using pytest (eg: https://github.com/ansys/pyansys-units), and that downgrading to v2024.22.0 makes it go away.

Can confirm this works as well.

@sm373373
Copy link

Same issue, downgrading to v2024.22.0 fixed it for me

eleanorjboyd added a commit that referenced this issue Jan 6, 2025
fixes regression in
#24656 by reverting
problem
eleanorjboyd added a commit to eleanorjboyd/vscode-python that referenced this issue Jan 6, 2025
fixes regression in
microsoft#24656 by reverting
problem
eleanorjboyd added a commit that referenced this issue Jan 6, 2025
fixes regression in
#24656 by reverting
problem
@eleanorjboyd eleanorjboyd marked this as a duplicate of #24688 Jan 6, 2025
@eleanorjboyd eleanorjboyd marked this as a duplicate of #24683 Jan 6, 2025
@eleanorjboyd eleanorjboyd marked this as a duplicate of #24684 Jan 6, 2025
@eleanorjboyd eleanorjboyd marked this as a duplicate of #24672 Jan 6, 2025
eleanorjboyd added a commit that referenced this issue Jan 6, 2025
revert the revert of the old commit so now main uses fifo again
add a limit of 4096 bytes per communication sent between python
subprocess and extension
fixes #24656
@eleanorjboyd
Copy link
Member Author

Hello everyone! I appreciate everyone in the comments helping one another and also for your patience during the holiday season! I have put in a fix for this bug and it is now out on the pre-release version of the vscode-python extension. If people are able to try it out and let me know if this newer version fixes the bug that would be extremely helpful! The version of the extension you need is 2024.23.2025010. Thank you!

@noppanut15
Copy link

Hi @eleanorjboyd, I've tested it with the pre-release version 2024.23.2025010601. The bug is fixed!! Thank you!

@dean-redelinghuys
Copy link

Confirmed fixed on MacOS VSCode with prerelease extension as above. Thanks @eleanorjboyd

eleanorjboyd added a commit to eleanorjboyd/vscode-python that referenced this issue Jan 7, 2025
eleanorjboyd added a commit to eleanorjboyd/vscode-python that referenced this issue Jan 7, 2025
eleanorjboyd added a commit to eleanorjboyd/vscode-python that referenced this issue Jan 7, 2025
revert the revert of the old commit so now main uses fifo again
add a limit of 4096 bytes per communication sent between python
subprocess and extension
fixes microsoft#24656
@eleanorjboyd eleanorjboyd marked this as a duplicate of #24241 Jan 7, 2025
eleanorjboyd added a commit that referenced this issue Jan 7, 2025
fixes #24656

this change:
restores the reverted code which switches to using fifo
fixes the bug for large workspaces with fifo for mac
@brianoflondon
Copy link

2024.23.2025010801 is working for me too.

@eleanorjboyd eleanorjboyd unpinned this issue Jan 9, 2025
@eleanorjboyd
Copy link
Member Author

As an update the point release 2024.22.2 is out and has this fix for those who are not on the pre-release. Thanks!

@jbhannah
Copy link

@eleanorjboyd can confirm that this is fixed for me and fixes #24655 as well, thank you!

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 regression Bug didn't exist in a previous release triage-needed Needs assignment to the proper sub-team
Projects
None yet
Development

Successfully merging a pull request may close this issue.