blob: 5a49f26fe4372ef2f1e0674e11d821b34df172ce (
plain)
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
69
70
71
72
73
|
(.module:
[lux #*
["_" test (#+ Test)]
["." io]
[abstract/monad (#+ do)]
[control
pipe]
data/text/format
[math
["r" random]]]
{1
["." / ("#@." monad)]})
(def: #export test
Test
(do r.monad
[_ (wrap [])]
(<| (_.context (%name (name-of /.Promise)))
($_ _.and
(wrap (do /.monad
[running? (/.future (io.io #1))]
(_.assert "Can run IO actions in separate threads."
running?)))
(wrap (do /.monad
[_ (/.wait 500)]
(_.assert "Can wait for a specified amount of time."
#1)))
(wrap (do /.monad
[[left right] (/.and (/.future (io.io #1))
(/.future (io.io #0)))]
(_.assert "Can combine promises sequentially."
(and left (not right)))))
(wrap (do /.monad
[?left (/.or (/.delay 100 #1)
(/.delay 200 #0))
?right (/.or (/.delay 200 #1)
(/.delay 100 #0))]
(_.assert "Can combine promises alternatively."
(case [?left ?right]
[(#.Left #1) (#.Right #0)]
#1
_
#0))))
(wrap (do /.monad
[?left (/.either (/.delay 100 #1)
(/.delay 200 #0))
?right (/.either (/.delay 200 #1)
(/.delay 100 #0))]
(_.assert "Can combine promises alternatively [Part 2]."
(and ?left (not ?right)))))
(_.test "Can poll a promise for its value."
(and (|> (/.poll (/@wrap #1))
(case> (#.Some #1) #1 _ #0))
(|> (/.poll (/.delay 200 #1))
(case> #.None #1 _ #0))))
(wrap (do /.monad
[?none (/.time-out 100 (/.delay 200 #1))
?some (/.time-out 200 (/.delay 100 #1))]
(_.assert "Can establish maximum waiting times for promises to be fulfilled."
(case [?none ?some]
[#.None (#.Some #1)]
#1
_
#0))))
))))
|