forked from gleam-lang/otp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsupervisor_test.gleam
64 lines (57 loc) · 1.86 KB
/
supervisor_test.gleam
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
import gleam/erlang/process
import gleam/otp/actor
import gleam/otp/supervisor.{add, returning, worker}
import gleeunit/should
pub fn supervisor_test() {
let subject = process.new_subject()
// Children send their name back to the test process during
// initialisation so that we can tell they (re)started
let child =
worker(fn(name) {
actor.start_spec(
actor.Spec(
init: fn() {
process.send(subject, #(name, process.self()))
actor.Ready(name, process.new_selector())
},
init_timeout: 10,
loop: fn(_msg, state) { actor.continue(state) },
),
)
})
// Each child returns the next name, which is their name + 1
let child =
child
|> returning(fn(name, _subject) { name + 1 })
supervisor.start_spec(
supervisor.Spec(
argument: 1,
frequency_period: 1,
max_frequency: 5,
init: fn(children) {
children
|> add(child)
|> add(child)
|> add(child)
},
),
)
|> should.be_ok
// Assert children have started
let assert Ok(#(1, p)) = process.receive(subject, 10)
let assert Ok(#(2, _)) = process.receive(subject, 10)
let assert Ok(#(3, _)) = process.receive(subject, 10)
let assert Error(Nil) = process.receive(subject, 10)
// Kill first child an assert they all restart
process.kill(p)
let assert Ok(#(1, p1)) = process.receive(subject, 10)
let assert Ok(#(2, p2)) = process.receive(subject, 10)
let assert Ok(#(3, _)) = process.receive(subject, 10)
let assert Error(Nil) = process.receive(subject, 10)
// Kill second child an assert the following children restart
process.kill(p2)
let assert Ok(#(2, _)) = process.receive(subject, 10)
let assert Ok(#(3, _)) = process.receive(subject, 10)
let assert Error(Nil) = process.receive(subject, 10)
let assert True = process.is_alive(p1)
}