forked from swiftlang/swift
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSimpleAsyncBacktrace.swift
57 lines (46 loc) · 1.24 KB
/
SimpleAsyncBacktrace.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
// RUN: %empty-directory(%t)
// RUN: %target-build-swift %s -g -parse-as-library -Onone -o %t/SimpleAsyncBacktrace
// RUN: %target-codesign %t/SimpleAsyncBacktrace
// RUN: %target-run %t/SimpleAsyncBacktrace | %FileCheck %s
// REQUIRES: concurrency
// REQUIRES: concurrency_runtime
// REQUIRES: executable_test
// REQUIRES: backtracing
// REQUIRES: OS=macosx || OS=linux-gnu
// UNSUPPORTED: use_os_stdlib
// UNSUPPORTED: back_deployment_runtime
import _Backtracing
@available(SwiftStdlib 5.1, *)
func level1() async {
await level2()
}
@available(SwiftStdlib 5.1, *)
func level2() async {
level3()
}
@available(SwiftStdlib 5.1, *)
func level3() {
level4()
}
@available(SwiftStdlib 5.1, *)
func level4() {
level5()
}
@available(SwiftStdlib 5.1, *)
func level5() {
let backtrace = try! Backtrace.capture()
// CHECK: 0{{[ \t]+}}0x{{[0-9a-f]+}} [ra]
// CHECK-NEXT: 1{{[ \t]+}}0x{{[0-9a-f]+}} [ra]
// CHECK-NEXT: 2{{[ \t]+}}0x{{[0-9a-f]+}} [ra]
// CHECK-NEXT: 3{{[ \t]+}}0x{{[0-9a-f]+}} [ra]
// CHECK-NEXT: 4{{[ \t]+}}0x{{[0-9a-f]+}} [async]
// CHECK-NEXT: 5{{[ \t]+}}0x{{[0-9a-f]+}} [async]
print(backtrace)
}
@available(SwiftStdlib 5.1, *)
@main
struct SimpleAsyncBacktrace {
static func main() async {
await level1()
}
}