Show error logs when test ends due to TIMEOUT#417
Draft
vinnybod wants to merge 1 commit into
Draft
Conversation
When a test times out, stdout/stderr output that was already written is now captured and included in the test report XML. This helps diagnose timeout issues by preserving any logging or print statements that occurred before the timeout interrupt. - Add OutputCapture class that uses TeeOutputStream to capture output - Wire OutputCapture into ActualRunner for timeout scenarios - Inject fallback output into BazelJUnitOutputListener on interrupt - Add fallback stdout/stderr fields to TestData
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
When a test times out, stdout/stderr output that was already written is now captured and included in the test report XML. This helps diagnose timeout issues by preserving any logging or print statements that occurred before the timeout interrupt.
The current behavior only shows
Test timed out and was interruptedEdit: This is probably still not a great solution because the "fallback" stream has the logs from every test case.