-
Notifications
You must be signed in to change notification settings - Fork 13k
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
Spurious failure in coverage report test #83262
Comments
Cc'ing some people who worked on that test: @richkadel @tmiasko |
The MIR pass produced from
|
Submitted that comment prematurely. I'm putting more comments in #83257 because I think it's just as likely the MIRI changed the MIR that the coverage pass needs to generate coverage. But it's not clear. It's also from a doctest, which is something @Swatinem worked on in the last couple of months. Maybe something changed affecting how doctest works. |
Indeed, but my PR does not change rustc at all, so this cannot be caused by my PR. |
@tmiasko - The timing is very coincidental with your PR landing last night. Based on Ralf's last comment, I would expect other PRs to fail similarly. I don't know how your PR passed, or how this could be spurious, but it is suspect. If we see more of these failures, you may need to look at reverting the PR. But I think we should make sure this is repeatable first. @wesleywiser FYI |
Timing indeed makes that PR suspect. That being said, I don't see how it could introduce any functional changes for builds without MIR inlining, like in this test case. |
@richkadel we've seen this several times since then, and it's likely that we'll want to address it either by removing the test or repeatedly running it if it fails, etc. -- do you have any thoughts on how it may have occurred? The next step is likely trying to run builds in a loop locally, though unfortunately it looks like the issue is somehow tied to MSVC which will make many of the infra team members not have immediate access to machines on that platform I believe... |
Is it always the doc test? Fyi, @Swatinem if it is. |
Hm, this might be related to this comment here: rust/src/test/run-make-fulldeps/coverage-reports/expected_show_coverage.doctest.txt Lines 70 to 75 in 91f2e2d
LLVM assumes functions are unique by name. But every doctest has its own Not sure on what this depends. But the rust/src/test/run-make-fulldeps/coverage-reports/Makefile Lines 108 to 110 in 91f2e2d
rust/src/test/run-make-fulldeps/coverage-reports/Makefile Lines 119 to 125 in 91f2e2d
I think the action item here is:
|
Or, I think I named the function |
That sounds more like a bug in coverage collection/reporting then? Surely that should work properly also when users have multiple functions with the same name (to the extend that Rust allows that). |
@RalfJung I think that is some kind of logic in llvm that uses only one functions data if multiple functions with the same mangled (C) name are present. I have been playing around with ordering of CLI parameters and file naming, but wasn’t able to reproduce this. My hunch is that maybe it is a pid reuse issue, in which case the earlier coverage file is overwritten. I have a PR that tries to reduce the chance of this. Or maybe llvm is using some kind of timestamp to decide which record to keep and which to discard. I have too little insight to know. |
It looks like @Aaron1011 just hit this same spurious failure, in #85211. I hadn't heard anything about this issue since @RalfJung first reported it on March 18. I don't know if the rate is accelerating, but I see there were other reports mentioned here, and agree we should do something. @Swatinem - I don't think MSVC testing of the coverage of doctests adds a lot of additional value. It probably tests the variability in Makefile and shell scripting more than any variability in coverage of doc tests on Windows. I suggest just disabling this test on MSVC, at least for now, until we someday migrate coverage tests off of Makefiles. I am out of office today through next Monday (my daughter is graduating from University of Illinois!) and don't have much time to work (and I'm slow to respond, sorry). @Swatinem - I don't know if you have time, but it may not be hard to add a directive to ignore MSVC for specific coverage tests. I think we have one or two similar directives in the Makefile. |
@Swatinem - I think my hunch is similar or the same. I suspect it might have something to do with the OS/shell environment in Windows for MSVC builds. PID reuse, or timing, or file lock, or something that we take for granted on a Unixy environment but doesn't work as consistently on Windows (or at least not how we might expect, coming from more of a Unix background). That seems more likely than an LLVM bug, to me. I think migrating off of Makefiles would most likely help (#85009) if our hunches are right. FYI: @tmandry @wesleywiser |
Avoid possible filename collision in coverage tests Previously, coverage tests were writing profiler data to files based on their pid. As rustdoc spawns each doctest as its own process, it might be possible in rare cases that a pid is being reused which would cause a file to be overwritten, leading to incorrect coverage results. should help with rust-lang#83262 r? `@tmandry`
Triage: Has anyone of you seen this spurious failure in the last say two years? Or can we close this issue as obsolete? |
Triage: |
In #83257 (comment), run-make-fulldeps\coverage-reports failed on x86_64-msvc-1 even though the PR just bumped the Miri submodule -- so this has to be a spurious failure, right?
@rust-lang/infra maybe you have a good idea for whom to ping about this.
The text was updated successfully, but these errors were encountered: