-
Notifications
You must be signed in to change notification settings - Fork 146
Expand file tree
/
Copy pathCustomTestReflectable.swift
More file actions
73 lines (70 loc) · 1.96 KB
/
CustomTestReflectable.swift
File metadata and controls
73 lines (70 loc) · 1.96 KB
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2026 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for Swift project authors
//
/// A protocol describing types with a custom reflection when presented as part
/// of a test's output.
///
/// ## See Also
///
/// - ``Swift/Mirror/init(reflectingForTest:)-(Any)``
/// - ``Swift/Mirror/init(reflectingForTest:)-(CustomTestReflectable)``
///
/// @Metadata {
/// @Available(Swift, introduced: 6.4)
/// }
public protocol CustomTestReflectable {
/// The custom mirror for this instance.
///
/// Do not use this property directly. To get the test reflection of a value,
/// use ``Swift/Mirror/init(reflectingForTest:)-(CustomTestReflectable)``.
///
/// @Metadata {
/// @Available(Swift, introduced: 6.4)
/// }
var customTestMirror: Mirror { get }
}
/// @Metadata {
/// @Available(Swift, introduced: 6.4)
/// }
extension Mirror {
/// Initialize this instance so that it can be presented in a test's output.
///
/// - Parameters:
/// - subject: The value to reflect.
///
/// ## See Also
///
/// - ``CustomTestReflectable``
///
/// @Metadata {
/// @Available(Swift, introduced: 6.4)
/// }
public init(reflectingForTest subject: some CustomTestReflectable) {
self = subject.customTestMirror
}
/// Initialize this instance so that it can be presented in a test's output.
///
/// - Parameters:
/// - subject: The value to reflect.
///
/// ## See Also
///
/// - ``CustomTestReflectable``
///
/// @Metadata {
/// @Available(Swift, introduced: 6.4)
/// }
public init(reflectingForTest subject: some Any) {
if let subject = subject as? any CustomTestReflectable {
self.init(reflectingForTest: subject)
} else {
self.init(reflecting: subject)
}
}
}