]> gitweb.factorcode.org Git - factor.git/blob - basis/timers/timers-tests.factor
more test IN: cleanup.
[factor.git] / basis / timers / timers-tests.factor
1 USING: timers timers.private calendar concurrency.count-downs
2 concurrency.promises fry kernel math math.order sequences
3 threads tools.test tools.time ;
4
5 { } [
6     1 <count-down>
7     { f } clone 2dup
8     [ first stop-timer count-down ] 2curry 1 seconds later
9     swap set-first
10     await
11 ] unit-test
12
13 { } [
14     self [ resume ] curry instant later drop
15     "test" suspend drop
16 ] unit-test
17
18 { t } [
19     [
20         <promise>
21         [ '[ t _ fulfill ] 2 seconds later drop ]
22         [ 5 seconds ?promise-timeout drop ] bi
23     ] benchmark 1,500,000,000 2,500,000,000 between?
24 ] unit-test
25
26 { { 3 } } [
27     { 3 } dup
28     '[ 4 _ set-first ] 2 seconds later
29     1/2 seconds sleep
30     stop-timer
31 ] unit-test
32
33 { { 1 } } [
34     { 0 }
35     dup '[ 0 _ [ 1 + ] change-nth ] 3 seconds later
36     [ stop-timer ] [ start-timer ] bi
37     4 seconds sleep
38 ] unit-test
39
40 { { 0 } } [
41     { 0 }
42     dup '[ 3 seconds sleep 1 _ set-first ] 1 seconds later
43     2 seconds sleep stop-timer
44     1/2 seconds sleep
45 ] unit-test
46
47 { { 0 } } [
48     { 0 }
49     dup '[ 1 _ set-first ] 300 milliseconds later
50     150 milliseconds sleep
51     [ restart-timer ] [ 200 milliseconds sleep stop-timer ] bi
52 ] unit-test
53
54 { { 1 } } [
55     { 0 }
56     dup '[ 0 _ [ 1 + ] change-nth ] 200 milliseconds later
57     100 milliseconds sleep restart-timer 300 milliseconds sleep
58 ] unit-test
59
60 { { 4 } } [
61     { 0 }
62     dup '[ 0 _ [ 1 + ] change-nth ] 300 milliseconds 300 milliseconds
63     <timer> dup start-timer
64     700 milliseconds sleep dup restart-timer
65     700 milliseconds sleep stop-timer 500 milliseconds sleep
66 ] unit-test