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

"Run Test with Coverage" runs *all* tests when test execution fails #24307

Open
bersbersbers opened this issue Oct 15, 2024 · 11 comments
Open

"Run Test with Coverage" runs *all* tests when test execution fails #24307

bersbersbers opened this issue Oct 15, 2024 · 11 comments
Assignees
Labels
area-testing feature-request Request for new features or functionality triage-needed Needs assignment to the proper sub-team

Comments

@bersbersbers
Copy link

TLDR:

  • do not run all tests when test execution fails
  • also, do not run tests at all when you cannot collect the IDs

I am currently debugging a problem in my tests, most likely related to nedbat/coveragepy#1392. I am trying the omit workaround, but currently, I am getting vscode-pytest errors such as:

test_bug.py .                                                            [100%]Error[vscode-pytest]: unable to read testIds from temp fileNo source for code: 'C:\Git\Bug\shibokensupport\signature\lib\tool.py'.

When this happens, VS Code re-starts all tests, which is not what I want at all.

Compare this snippet:

try:
# Read the test ids from the file, delete file, and run pytest.
ids_path = pathlib.Path(run_test_ids_pipe)
ids = ids_path.read_text(encoding="utf-8").splitlines()
try:
ids_path.unlink()
except Exception as e:
print("Error[vscode-pytest]: unable to delete temp file" + str(e))
arg_array = ["-p", "vscode_pytest", *args, *ids]
print("Running pytest with args: " + str(arg_array))
pytest.main(arg_array)
except Exception as e:
print("Error[vscode-pytest]: unable to read testIds from temp file" + str(e))
run_pytest(args)

IMHO, this should rather be something like (untested!) - note the return in the first block and the different arg_array in the last block:

try: 
    # Read the test ids from the file, delete file, and run pytest. 
    ids_path = pathlib.Path(run_test_ids_pipe) 
    ids = ids_path.read_text(encoding="utf-8").splitlines() 
except Exception as e: 
    print("Error[vscode-pytest]: unable to read testIds from temp file: " + str(e)) 
    return
finally:
    try: 
        ids_path.unlink() 
    except Exception as e: 
        print("Error[vscode-pytest]: unable to delete temp file: " + str(e)) 

try: 
    arg_array = ["-p", "vscode_pytest", *args, *ids] 
    print("Running pytest with args: " + str(arg_array)) 
    pytest.main(arg_array) 
except Exception as e: 
    print("Error[vscode-pytest]: unable to run tests: " + str(e)) 
    arg_array = [*args, *ids] 
    print("Running pytest with args: " + str(arg_array)) 
    run_pytest(arg_array)
@bersbersbers bersbersbers added the feature-request Request for new features or functionality label Oct 15, 2024
@github-actions github-actions bot added the triage-needed Needs assignment to the proper sub-team label Oct 15, 2024
@eleanorjboyd
Copy link
Member

hoping to take a look at fixing this soon- sorry for the delay

@RamiAwar
Copy link

RamiAwar commented Oct 31, 2024

I'm getting something similar actually, might be relevant given closeness in time of reports:
Error[vscode-pytest]: unable to read testIds from temp file[Errno 2] No such file or directory: '/tmp/test-ids-e2faf2fe418633dcef80.txt'

I'm trying to run one test but it 'fails to detect the test ID'.

Note that I'm using devcontainers, with Python + Pylance + pytest explorer installed inside.

Also, not sure if relevant: I looked at /tmp/ but can't see any files named like this. I only see files named like python-test-discovery-698debb64df061b8b350.sock

LOGS:

2024-10-31 22:11:25.650 [info] Attempting to use temp directory for test ids file, file name: test-ids-750dd803c28e00398642.txt
env vars: "TEST_RUN_PIPE":"/tmp/python-test-results-59956af0fc8ae043f0d0.sock","RUN_TEST_IDS_PIPE":"/tmp/test-ids-750dd803c28e00398642.txt"}

2024-10-31 22:11:25.658 [info] Running pytest with arguments: /root/.vscode-server/extensions/ms-python.python-2024.16.1-linux-arm64/python_files/vscode_pytest/run_pytest_script.py --rootdir=/code/myproj

2024-10-31 22:11:25.658 [info] > /usr/local/bin/python ~/.vscode-server/extensions/ms-python.python-2024.16.1-linux-arm64/python_files/vscode_pytest/run_pytest_script.py --rootdir=.

2024-10-31 22:11:25.658 [info] cwd: .

At this point I see this in my test results:

Error[vscode-pytest]: unable to read testIds from temp file[Errno 2] No such file or directory: '/tmp/test-ids-750dd803c28e00398642.txt'

Python logs don't show anything useful after that and I cancel the test runs. I also watch ls /tmp as I clicked on a test run and only saw the -result files appear. No IDs files.

@eleanorjboyd
Copy link
Member

hm interesting- this seems different, could you file a new issue? We use that txt file as a temp to transfer the names of the test ids to the subprocess we spin up so I would guess it might be permissions having to do with the temp directory since we aren't doing anythign specific beyond that

@RamiAwar
Copy link

RamiAwar commented Nov 8, 2024

hm interesting- this seems different, could you file a new issue? We use that txt file as a temp to transfer the names of the test ids to the subprocess we spin up so I would guess it might be permissions having to do with the temp directory since we aren't doing anythign specific beyond that

Done, put it in #24406

@eleanorjboyd
Copy link
Member

Hi @bersbersbers, could you clarify what you mean here: "do not run all tests when test execution fails". Which test execution fails? The reading the testIds? Also could you give it another try - we have changed to using a different communication method which might help, this is only out on the pre-release of the python extension so you would need to try it there. Thanks!

@bersbersbers
Copy link
Author

Which test execution fails?

What I mean is that in the code snippet above, pytest.main(arg_array) throws an exception (in my case, it was a NoSource exception, but it can be anything). See the far end of the console output starting with test_bug.py .. The code then incorrectly prints it is "unable to read testIds from temp file", but that is a misleading error message. IMHO, reading of test IDs and running the tests should be in two independent try blocks, see my proposed code snippet above.

Also could you give it another try

Yes, will do tomorrow. But I am fairly certain the commuication method does not have anything to do with this, because it's not the reading of test IDs that fails, but the test process itself.

@github-actions github-actions bot removed the info-needed Issue requires more information from poster label Nov 14, 2024
@bersbersbers
Copy link
Author

bersbersbers commented Nov 15, 2024

Also could you give it another try

I did. Obviously, since #24308 seems to be fixed, my original reproducer does not work any more. But I can still reproduce the behavior by adding

if any("::" in arg for arg in args):
    raise RuntimeError("foo")

to _pytest\config\__init__.py, main() function.

(This is supposed to simulate a pytest crash similar to before. Note that the above main() function does not catch all exceptions.)

Then run test with coverage for a single test. What then happens is:

  • pytest starts for one test and crashes.
  • pytest_code reports "unable to read testIds from temp file". This is incorrect.
  • pytest is re-started for all tests. This is the bug.

(This is with v2024.21.2024111501)

@eleanorjboyd
Copy link
Member

we fix restarting tests- I think this should fix the problem, let me know if not. Thanks!

@eleanorjboyd eleanorjboyd added the info-needed Issue requires more information from poster label Dec 10, 2024
@bersbersbers
Copy link
Author

bersbersbers commented Dec 12, 2024

Updated to 2024.22.0, problem still exists. Which, if I may say so, is not surprising since the buggy snippet that I pointed out in the OP (#24307 (comment)) has not changed, looking at today's main branch:

try:
# Read the test ids from the file, delete file, and run pytest.
ids_path = pathlib.Path(run_test_ids_pipe)
ids = ids_path.read_text(encoding="utf-8").splitlines()
try:
ids_path.unlink()
except Exception as e:
print("Error[vscode-pytest]: unable to delete temp file" + str(e))
arg_array = ["-p", "vscode_pytest", *args, *ids]
print("Running pytest with args: " + str(arg_array))
pytest.main(arg_array)
except Exception as e:
print("Error[vscode-pytest]: unable to read testIds from temp file" + str(e))
run_pytest(args)

@github-actions github-actions bot removed the info-needed Issue requires more information from poster label Dec 12, 2024
@TimotheeJeannin
Copy link

TimotheeJeannin commented Dec 29, 2024

I also experience this issue with vscode-python 2024.22.1. When I run some tests with coverage, vscode launches all the tests out of nowhere.

Running pytest with args: ['-p', 'vscode_pytest', '-n', 'auto', '--color=yes', '--ignore=templates', '--rootdir=/home/tim/Workspace/ApiFlash', '--cov=.', '/home/tim/Workspace/ApiFlash/py_test/unit/dashboard/test_plans.py::test_plans_page', '/home/tim/Workspace/ApiFlash/py_test/unit/dashboard/test_plans.py::test_display_the_current_plan', '/home/tim/Workspace/ApiFlash/py_test/unit/dashboard/test_plans.py::test_plans_switch_cost']
============================= test session starts ==============================
platform linux -- Python 3.8.20, pytest-8.3.4, pluggy-1.5.0
rootdir: /home/tim/Workspace/ApiFlash
plugins: xdist-3.6.1, cov-5.0.0, subtests-0.13.1
created: 3/3 workers
3 workers [3 items]

...                                                                      [100%]Error[vscode-pytest]: unable to read testIds from temp fileCouldn't parse '/home/tim/Workspace/ApiFlash/templates/dashboard/base.html' as Python source: 'invalid syntax' at line 1
============================= test session starts ==============================
platform linux -- Python 3.8.20, pytest-8.3.4, pluggy-1.5.0
rootdir: /home/tim/Workspace/ApiFlash
plugins: xdist-3.6.1, cov-5.0.0, subtests-0.13.1
collected 569 items
[...]

Vscode does that only when I run tests with coverage. If I run tests normally it does not launch all tests for no reason.
Also, if I add --cov=path_to_python_sources it works as expected.
It looks like the issue happens because vscode-python adds --cov=. by default and fails to process some non-python files.

@eleanorjboyd I think this issue should be reopened because it's not fixed.

Let me know if there is more information you need.

@eleanorjboyd
Copy link
Member

ah yes good point- let me investigate further! Thanks

@eleanorjboyd eleanorjboyd reopened this Jan 6, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area-testing feature-request Request for new features or functionality triage-needed Needs assignment to the proper sub-team
Projects
None yet
Development

No branches or pull requests

4 participants