-
Notifications
You must be signed in to change notification settings - Fork 10.4k
/
Copy pathdistributed_property_must_be_throws.swift
37 lines (30 loc) · 1.89 KB
/
distributed_property_must_be_throws.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
// RUN: %empty-directory(%t)
// RUN: %target-swift-frontend-emit-module -emit-module-path %t/FakeDistributedActorSystems.swiftmodule -module-name FakeDistributedActorSystems -disable-availability-checking %S/Inputs/FakeDistributedActorSystems.swift
// RUN: %target-swift-frontend -typecheck -verify -verify-ignore-unknown -disable-availability-checking -I %t 2>&1 %s
// REQUIRES: concurrency
// REQUIRES: distributed
import Distributed
import FakeDistributedActorSystems
let globalActorSystem = LocalTestingDistributedActorSystem()
distributed actor MyDistributedActor {
typealias ActorSystem = LocalTestingDistributedActorSystem
distributed var distributedProperty: Set<Int> { [] }
distributed var accessMe: Set<Int> { [] }
// expected-note@-1{{access to distributed property 'accessMe' from outside the distributed actor 'MyDistributedActor' must be asynchronous}}
}
func test(da: MyDistributedActor) async throws {
_ = await da.distributedProperty // expected-error{{property access can throw but is not marked with 'try'}}
// expected-note@-1{{did you mean to use 'try'?}}
// expected-note@-2{{did you mean to handle error as optional value?}}
// expected-note@-3{{did you mean to disable error propagation?}}
_ = try da.distributedProperty // expected-error{{expression is 'async' but is not marked with 'await'}}
// expected-note@-1{{property access is 'async'}}
_ = try await da.distributedProperty // ok, implicitly async + throws
}
func testSyncFunc(da: MyDistributedActor) throws {
_ = da.accessMe // expected-error{{actor-isolated distributed property 'accessMe' can not be referenced from a non-isolated context}}
// expected-error@-1{{property access can throw but is not marked with 'try'}}
// expected-note@-2{{did you mean to use 'try'?}}
// expected-note@-3{{did you mean to handle error as optional value?}}
// expected-note@-4{{did you mean to disable error propagation?}}
}