Files
swift-mirror/test/embedded/custom-executor.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

57 lines
1.6 KiB
Swift

// RUN: %empty-directory(%t)
// RUN: %target-swift-frontend -enable-experimental-feature Embedded -parse-as-library %s -c -o %t/a.o
// RUN: %target-clang -x c -std=c11 -I %swift_obj_root/include -c %S/Inputs/executor.c -o %t/executor.o
// RUN: %target-clang %t/a.o %t/executor.o -o %t/a.out %swift_obj_root/lib/swift/embedded/%target-cpu-apple-macos/libswift_Concurrency.a -dead_strip
// RUN: %target-run %t/a.out | %FileCheck %s
// REQUIRES: executable_test
// REQUIRES: swift_in_compiler
// REQUIRES: optimized_stdlib
// REQUIRES: OS=macosx
// REQUIRES: swift_feature_Embedded
import _Concurrency
public func test() async -> Int {
print("test")
let t = Task {
print("return 42")
return 42
}
print("await")
let v = await t.value
print("return")
return v
}
@main
struct Main {
static func main() async {
print("main")
// CHECK: main
let t = Task {
print("task")
let x = await test()
print(x == 42 ? "42" : "???")
}
// CHECK-NEXT: executor: job [[JOB1:0x[0-9a-f]+]] enqueued
print("after task")
// CHECK-NEXT: after task
await t.value
// CHECK-NEXT: executor: running
// CHECK-NEXT: executor: job [[JOB1]] running
// CHECK-NEXT: task
// CHECK-NEXT: test
// CHECK-NEXT: executor: job [[JOB2:0x[0-9a-f]+]] enqueued
// CHECK-NEXT: await
// CHECK-NEXT: executor: job [[JOB2]] running
// CHECK-NEXT: return 42
// CHECK-NEXT: executor: job [[JOB1]] enqueued
// CHECK-NEXT: executor: job [[JOB1]] running
// CHECK-NEXT: return
// CHECK-NEXT: 42
// CHECK-NEXT: executor: job [[JOB3:0x[0-9a-f]+]] enqueued
// CHECK-NEXT: executor: job [[JOB3]] running
}
}