-
Notifications
You must be signed in to change notification settings - Fork 82
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
Using recording an issue inside of a detached task causes a crash. #480
Comments
The crash here is a known issue in Xcode 16 Beta, tracked by rdar://122190668. To resolve it, some work will be needed on the Xcode side, but it's also likely some additional action will be needed here in the swift-testing codebase, so I will leave this issue open to track that side of things. |
(To clarify: the crash is specific to Xcode 16.) |
Having not tried Swift Testing on Xcode 15, is the behavior that it silently drops the issue? |
Right. But that said, other tools (such as VS Code or |
To clarify more: the crash is specific to Xcode 16, which is the first version of Xcode to include support for Swift Testing. I meant that the crash is a bug in Xcode specifically, and not workflows that involve e.g. Linux or a package dependency on Swift Testing rather than Xcode and the copy of Swift Testing embedded in it. I hope that makes more sense! |
Oh! I gotcha! Thanks! |
Folks, did a fix for this make it into Xcode 16.x yet? I'm seeing the same thing both locally and on CI:
|
Interestingly, one project (SPM) I have was generally fine with Xcode 16.0 on macOS 15.0 but this is happening inconsistently (about 50% of the time) since 16.1/15.1 respectively. I see there's an update in Xcode command-line tools coming down the pipe now (Oct 29 23:27 GMT), so will see if that makes a difference. |
Xcode CL Tools don't include the component that causes the crash (as far as I'm aware, anyway.) |
Yes, it made no difference. Didn't think it would; just wishful thinking. |
I'm sorry it's not going well! Apple is tracking this issue, but since Xcode is not part of the open source Swift project, there's not a lot we can say publicly about it. |
No worries. I appreciate the correspondence 👍 |
Description
This is something I learned while researching potential ways to address #475. Which, at the time I wrote that issue, I thought would have just resulted in the failure being silently dropped.
The current way of determining what the current reporting tests natively in Swift-Testing is broken when you run an expect inside of a detached task. Technically, you get a failing test result, but it's because the test runner crashed. I haven't yet spelunked enough through the codebase to figure out where that crash is.
This is because
Test.current
is stored as a task-local value. Which means that when you make an expect inside of a detached task, Swift Testing has lost that context, which means thatTest.current
is incorrectly (from the semantics of the current running test) as nil.I don't know the concurrency system well enough to be able to suggest a good solution. The issue is that, because Swift Testing supports task-based parallelization, the value of
Test.current
strongly depends on the task it's running on. Which makes having a globalTest.current
like what's in swift-corelibs-xctest the wrong solution.Expected behavior
No response
Actual behavior
No response
Steps to reproduce
This test should pass. The test runner crashes with a non-zero error instead.
swift-testing version/commit hash
Testing Library Version: 75.7 (arm64e-apple-macos13.0)
Swift & OS version (output of
swift --version ; uname -a
)No response
The text was updated successfully, but these errors were encountered: