forked from swiftlang/swift
- Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTiming.swift
45 lines (36 loc) · 877 Bytes
/
Timing.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
// RUN: %empty-directory(%t)
// RUN: %target-build-swift %s -parse-as-library -Onone -g -o %t/Timing
// RUN: %target-codesign %t/Timing
// RUN: (env SWIFT_BACKTRACE=enable=yes,cache=no %target-run %t/Timing 2>&1 || true) | %FileCheck %s
// UNSUPPORTED: use_os_stdlib
// UNSUPPORTED: back_deployment_runtime
// UNSUPPORTED: asan
// REQUIRES: executable_test
// REQUIRES: backtracing
// REQUIRES: OS=macosx || OS=linux-gnu
func level1(){
level2()
}
func level2(){
level3()
}
func level3(){
level4()
}
func level4(){
level5()
}
func level5(){
print("About to crash")
letptr=UnsafeMutablePointer<Int>(bitPattern:4)!
ptr.pointee =42
}
@main
structTiming{
staticfunc main(){
level1()
}
}
// The backtracer should say how long the backtrace took, in seconds, with
// two decimal places.
// CHECK: Backtrace took {{[0-9]+}}.{{[0-9][0-9]}}s