blob: 990d6581e26ea4ff763f5325f3e3652a78af14d7 [file] [log] [blame]
// RUN: %target-swift-frontend -swift-version 5 -emit-sil -primary-file %s -o /dev/null -verify
//
// REQUIRES: VENDOR=apple
// Tests for the diagnostics produced by the OSLogOptimization pass that
// performs compile-time analysis and optimization of the new os log APIs.
// Note that many usage errors are caught by the Sema check: ConstantnessSemaDiagnostics.
// The tests here check only those diagnostics that are enforced at the SIL level.
import OSLogTestHelper
func testNonDecimalFormatOptionOnIntegers() {
_osLogTestHelper("Minimum integer value: \(Int.min, format: .hex)")
// expected-error @-1 {{Fatal error: Signed integers must be formatted using .decimal}}
}
// Extending OSLogInterpolation (without the constant_evaluable attribute) would be an
// error.
struct A {
var i: Int
}
extension OSLogInterpolation {
mutating func appendInterpolation(a: A) {
self.appendInterpolation(a.i)
}
}
func testOSLogInterpolationExtension(a: A) {
_osLogTestHelper("Error at line: \(a: a)")
// expected-error @-1 {{invalid log message; extending types defined in the os module is not supported}}
// expected-note @-2 {{'OSLogInterpolation.appendLiteral(_:)' failed evaluation}}
// expected-note @-3 {{value mutable by an unevaluated instruction is not a constant}}
}
internal enum Color {
case red
case blue
}
// Invoking the log calls in unreachable code should not crash the compiler.
func testUnreachableLogCall(c: Color) {
let arg = 10
switch c {
case .red:
return
case .blue:
return
default: // expected-warning {{default will never be executed}}
_osLogTestHelper("Unreachable log call")
_osLogTestHelper("Unreachable log call with argument \(arg)")
_osLogTestHelper(
"""
Unreachable log call with argument and formatting \
\(arg, align: .right(columns: 10))
""")
}
}
// Passing InOut values to the logger should not crash the compiler.
func foo(_ mutableValue: inout String) {
// expected-note@-1 {{parameter 'mutableValue' is declared 'inout'}}
_osLogTestHelper("FMFLabelledLocation: initialized with coder \(mutableValue)")
// expected-error@-1 {{escaping autoclosure captures 'inout' parameter 'mutableValue'}}
// expected-note@-2 {{pass a copy of 'mutableValue'}}
}
// This is an extension used only for testing a diagnostic that doesn't arise
// normally but may be triggered by changes to the library.
extension OSLogInterpolation {
@_transparent
mutating func appendInterpolation(_ c: Color) {
switch c {
case .red:
appendInterpolation(1)
case .blue:
appendInterpolation(0)
}
}
}
func testUnreachableLogCallComplex(c: Color) {
switch c {
case .red:
return
case .blue:
return
default: // expected-warning {{default will never be executed}}
_osLogTestHelper("Some call \(c)")
// expected-warning@-1 {{os log call will never be executed and may have undiagnosed errors}}
// expected-error@-2 {{globalStringTablePointer builtin must be used only on string literals}}
}
}