Files
swift-mirror/test/Concurrency/async_cancellation.swift

59 lines
1.4 KiB
Swift

// RUN: %target-swift-frontend -disable-availability-checking %s -emit-sil -o /dev/null -verify
// RUN: %target-swift-frontend -disable-availability-checking %s -emit-sil -o /dev/null -verify -strict-concurrency=complete
// REQUIRES: concurrency
// REQUIRES: asserts
enum PictureData {
case value(String)
case failedToLoadImagePlaceholder
}
@available(SwiftStdlib 5.1, *)
func test_cancellation_checkCancellation() async throws {
try Task.checkCancellation()
}
@available(SwiftStdlib 5.1, *)
func test_cancellation_guard_isCancelled(_ any: Any) async -> PictureData {
guard !Task.isCancelled else {
return PictureData.failedToLoadImagePlaceholder
}
return PictureData.value("...")
}
@available(SwiftStdlib 5.1, *)
struct SomeFile: Sendable {
func close() {}
}
@available(SwiftStdlib 5.1, *)
func test_cancellation_withTaskCancellationHandler(_ anything: Any) async -> PictureData? {
let handle: Task<PictureData, Error> = .init {
let file = SomeFile()
return await withTaskCancellationHandler {
await test_cancellation_guard_isCancelled(file)
} onCancel: {
file.close()
}
}
handle.cancel()
return nil
}
@available(SwiftStdlib 5.1, *)
func test_cancellation_loop() async -> Int {
struct SampleTask { func process() async {} }
let tasks = [SampleTask(), SampleTask()]
var processed = 0
for t in tasks where !Task.isCancelled {
await t.process()
processed += 1
}
return processed
}