Files
swift-mirror/test/Concurrency/sendable_existentials.swift
Michael Gottesman df2844d267 [concurrency] Cleanup verify-additional-prefix usage in tests.
This includes a bunch of fixes. It is not exhaustive but fit my time boxed time
period I set aside to look at this today.

A quick non-exhaustive list:

1. I removed unnecessary verify-additional-prefix lines.
2. Split tests with typechecker error and non-typechecker error components.
3. Removed complete- lines that we used when testing w/without send
non sednable.
4. Translated complete-and-tns- lines to be just complete- since they are just
testing strict-concurrency=complete and we are not testing complete without
send non sendable anymore.
2025-08-12 10:56:02 -07:00

68 lines
2.7 KiB
Swift

// RUN: %target-swift-frontend -strict-concurrency=targeted -emit-sil -o /dev/null %s -verify
// RUN: %target-swift-frontend -strict-concurrency=complete -verify-additional-prefix complete- -emit-sil -o /dev/null %s -verify
// REQUIRES: concurrency
// REQUIRES: OS=macosx
@preconcurrency func send(_: Sendable) { }
func sendOpt(_: Sendable?) { }
enum E {
case something(Sendable)
}
@available(SwiftStdlib 5.1, *)
func testE(a: Any, aOpt: Any?) async {
send(a) // expected-warning{{type 'Any' does not conform to the 'Sendable' protocol}}
sendOpt(a) // expected-warning{{type 'Any' does not conform to the 'Sendable' protocol}}
sendOpt(aOpt) // expected-warning{{type 'Any' does not conform to the 'Sendable' protocol}}
let _: E = .something(a) // expected-warning{{type 'Any' does not conform to the 'Sendable' protocol}}
_ = E.something(a) // expected-warning{{type 'Any' does not conform to the 'Sendable' protocol}}
var sendable: Sendable
sendable = a // expected-warning{{type 'Any' does not conform to the 'Sendable' protocol}}
var arrayOfSendable: [Sendable]
arrayOfSendable = [a, a] // expected-warning 2{{type 'Any' does not conform to the 'Sendable' protocol}}
func localFunc() { }
sendable = localFunc // expected-warning{{type '() -> ()' does not conform to the 'Sendable' protocol}}
// expected-note@-1{{a function type must be marked '@Sendable' to conform to 'Sendable'}}
_ = sendable
_ = arrayOfSendable
}
func testESilently(a: Any, aOpt: Any?) {
send(a) // expected-complete-warning {{'Any' does not conform to the 'Sendable' protocol}}
sendOpt(a) // expected-complete-warning {{'Any' does not conform to the 'Sendable' protocol}}
sendOpt(aOpt) // expected-complete-warning {{'Any' does not conform to the 'Sendable' protocol}}
let _: E = .something(a) // expected-complete-warning {{'Any' does not conform to the 'Sendable' protocol}}
_ = E.something(a) // expected-complete-warning {{'Any' does not conform to the 'Sendable' protocol}}
var sendable: Sendable
sendable = a // expected-complete-warning {{'Any' does not conform to the 'Sendable' protocol}}
var arrayOfSendable: [Sendable]
arrayOfSendable = [a, a] // expected-complete-warning 2{{'Any' does not conform to the 'Sendable' protocol}}
func localFunc() { }
sendable = localFunc // expected-complete-warning {{'() -> ()' does not conform to the 'Sendable' protocol}}
// expected-complete-note @-1 {{a function type must be marked '@Sendable' to conform to 'Sendable'}}
_ = sendable
_ = arrayOfSendable
}
func testErasure() {
class A {}
class B : A {}
func produce() -> any B & Sendable {
fatalError()
}
let _: any A & Sendable = produce() // no warning
}