Files
swift-mirror/test/DebugInfo/sending_params_and_results.swift
Daniel Rodríguez Troitiño ba68faaed5 [test] Mark tests that use experimental/upcoming features as such
Find all the usages of `--enable-experimental-feature` or
`--enable-upcoming-feature` in the tests and replace some of the
`REQUIRES: asserts` to use `REQUIRES: swift-feature-Foo` instead, which
should correctly apply to depending on the asserts/noasserts mode of the
toolchain for each feature.

Remove some comments that talked about enabling asserts since they don't
apply anymore (but I might had miss some).

All this was done with an automated script, so some formatting weirdness
might happen, but I hope I fixed most of those.

There might be some tests that were `REQUIRES: asserts` that might run
in `noasserts` toolchains now. This will normally be because their
feature went from experimental to upcoming/base and the tests were not
updated.
2024-11-02 11:46:46 -07:00

33 lines
1.2 KiB
Swift

// RUN: %target-swift-frontend -emit-ir -g -o - -module-name test -strict-concurrency=complete -swift-version 5 -enable-upcoming-feature SendingArgsAndResults -target %target-swift-5.1-abi-triple %s | %FileCheck %s
// REQUIRES: swift_feature_SendingArgsAndResults
// Test that we can properly reconstruct sending from various tests when
// emitting debug info. Only place examples in here that have already failed.
public struct SendableStruct: Sendable {
}
// This verifies that we can properly type reconstruct:
//
// $ss6ResultOy4test14SendableStructVs5Error_pGIeggT_D
//
// Which is:
//
// @escaping @callee_guaranteed (@guaranteed sending Swift.Result<test.SendableStruct, Swift.Error>) -> ()
//
// CHECK: !{{[0-9]+}} = !DICompositeType(tag: DW_TAG_structure_type, name: "$ss6ResultOy4test14SendableStructVs5Error_pGIeggT_D",
func testReconstructingEscapingClosureWithSendingParam() async throws -> SendableStruct {
func callSendableFunction(_ x: @Sendable () -> ()) {}
func helper(_ completion: @escaping (__shared sending Result<SendableStruct, Swift.Error>) -> Void) {
fatalError()
}
return try await withCheckedThrowingContinuation { continuation in
callSendableFunction {
helper(continuation.resume(with:))
}
}
}