-
Notifications
You must be signed in to change notification settings - Fork 326
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Time is reported incorrectly for xunit when different verbosity is used #4894
Comments
I'll admit, you knocked me over with that. 😂 |
Reproduction:
|
This is happening because the logger reports the duration as the difference between the earliest StartTime and latest EndTime on all tests reported from each assembly. But XUnit is not reporting StartTime and EndTime, so we set them both to the same timestamp, meaning that the duration of the first test is missing. The problem is also mentioned here #4156 (comment) Running the same with MSTest does not show the problem: @bradwilson would it be possible to report the start time and end time from xunit to fix this? If not we can approximate by subtracting duration from the time when the test was reported, but that solution is not great. |
I can add this to v3. It's probably not possible in v2 due to the frozen abstractions layer. |
This is working now in VSTest adapter Fix commit: xunit/visualstudio.xunit@3ad2641 Using the repro project, built against v2 Core Framework, and using VSTest adapter And here it is running with |
It's also worth noting that our calculation of execution time is a more accurate measure than just subtracting finish time from start time, especially if you're running w/ the old aggressive parallelism algorithm (this changed to a more conservative parallelism algorithm in 2.8.0 to make test timing more accurate, at the potential expense of total execution time). I presume Test Explorer will continue to report our explicit execution time (aka |
Yes they are using duration, if you'd like to change it, please file a visual studio feedback issue so it can sit in their queue. And thanks for fixing it for v3. |
I checked the code and we simply assign UTC now when the test result is constructed to both StartTime and EndTime, so to fix it in v2 you could simply do the same and just subtract the Duration from the end time when constructing ObjectModel TestResult. |
Nope, this absolutely is what I want them to keep doing. 😁
Yes, I believe we'll be pushing everybody over to the v3 VSTest adapter before 2 months from now, so there's not much reason that I can see to make this change if it's just for our sake. Once our users upgrade to a 3.x build of |
full issue is in here in dotnet repo: dotnet/runtime#98205 (comment)
This is probably linked to the fact that normal console logger is measuring execution by datetime.now and the minimal output logger is collecting first and last test from each dll, and then reporting the diff.
The text was updated successfully, but these errors were encountered: