mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
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.
68 lines
2.7 KiB
Swift
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
|
|
}
|