-
Notifications
You must be signed in to change notification settings - Fork 10.4k
/
Copy pathdistributed_actor_local.swift
68 lines (51 loc) · 2 KB
/
distributed_actor_local.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
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
// 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-build-swift -module-name main -Xfrontend -disable-availability-checking -j2 -parse-as-library -I %t %s %S/../Inputs/FakeDistributedActorSystems.swift -o %t/a.out
// RUN: %target-codesign %t/a.out
// RUN: %target-run %t/a.out | %FileCheck %s --color
// REQUIRES: executable_test
// REQUIRES: concurrency
// REQUIRES: distributed
// rdar://76038845
// UNSUPPORTED: use_os_stdlib
// UNSUPPORTED: back_deployment_runtime
import Distributed
import FakeDistributedActorSystems
distributed actor SomeSpecificDistributedActor {
distributed func hello() async throws {
print("hello from \(self.id)")
}
distributed func echo(int: Int) async throws -> Int {
int
}
}
typealias DefaultDistributedActorSystem = FakeActorSystem
// ==== Execute ----------------------------------------------------------------
func test_initializers() {
let address = ActorAddress(parse: "")
let system = DefaultDistributedActorSystem()
_ = SomeSpecificDistributedActor(actorSystem: system)
_ = try! SomeSpecificDistributedActor.resolve(id: address, using: system)
}
func test_address() {
let system = DefaultDistributedActorSystem()
let actor = SomeSpecificDistributedActor(actorSystem: system)
_ = actor.id
}
func test_run(system: FakeActorSystem) async {
let actor = SomeSpecificDistributedActor(actorSystem: system)
print("before") // CHECK: before
try! await actor.hello()
print("after") // CHECK: after
}
func test_echo(system: FakeActorSystem) async {
let actor = SomeSpecificDistributedActor(actorSystem: system)
let echo = try! await actor.echo(int: 42)
print("echo: \(echo)") // CHECK: echo: 42
}
@main struct Main {
static func main() async {
await test_run(system: FakeActorSystem())
await test_echo(system: FakeActorSystem())
}
}