Skip to content
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

Closed
nohwnd opened this issue Feb 13, 2024 · 9 comments · Fixed by #5143
Closed

Time is reported incorrectly for xunit when different verbosity is used #4894

nohwnd opened this issue Feb 13, 2024 · 9 comments · Fixed by #5143
Assignees

Comments

@nohwnd
Copy link
Member

nohwnd commented Feb 13, 2024

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.

@bradwilson
Copy link

minimal output logger is collecting first and last test from each dll, and then reporting the diff.

I'll admit, you knocked me over with that. 😂

@rmunn
Copy link

rmunn commented Feb 14, 2024

Reproduction:

  • Clone https://github.com/rmunn/dotnet-test-xunit-timing-repro
  • Run dotnet test /v:q. Test duration is wrong: first test is not counted in total duration.
  • Run dotnet test /v:n. Test duration is still wrong, in the same way.
  • Run dotnet test --logger "console;verbosity=quiet". Test duration is still wrong, in the same way.
  • Run dotnet test --logger "console;verbosity=normal". Test duration is correct.

@nohwnd
Copy link
Member Author

nohwnd commented Jul 12, 2024

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:
image

@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.

@bradwilson
Copy link

I can add this to v3. It's probably not possible in v2 due to the frozen abstractions layer.

@bradwilson
Copy link

bradwilson commented Jul 13, 2024

This is working now in VSTest adapter 3.0.0-pre.12, for v1/v2/v3 test projects. https://xunit.net/docs/using-ci-builds

Fix commit: xunit/visualstudio.xunit@3ad2641

Using the repro project, built against v2 Core Framework, and using VSTest adapter 3.0.0-pre.11:

image

And here it is running with 3.0.0-pre.12:

image

@bradwilson
Copy link

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 Duration) in the UI?

@nohwnd
Copy link
Member Author

nohwnd commented Jul 15, 2024

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.

@nohwnd
Copy link
Member Author

nohwnd commented Jul 15, 2024

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.
I will do the same fix in vstest, but you will be able to ship it much quickker, mine would be in test.sdk 17.12, which will be out not sooner than in couple of months.

https://github.com/microsoft/vstest/blob/main/src/Microsoft.TestPlatform.ObjectModel/TestResult.cs#L34-L35

@bradwilson
Copy link

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.

Nope, this absolutely is what I want them to keep doing. 😁

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. I will do the same fix in vstest, but you will be able to ship it much quickker, mine would be in test.sdk 17.12, which will be out not sooner than in couple of months.

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 xunit.runner.visualstudio, this will get fixed for all tests (v1, v2, and v3), as it's always our policy that our runners are backward compatible (and forward compatible within the same major Core Framework version), and the fix for this is entirely contained within the VSTest adapter.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants