Mercurial > irccd
annotate tests/src/libirccd-js/js-api-chrono/main.cpp @ 846:dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
- Add new start function to restart a paused timer (closes #1669),
- Rename restart function to resume (closes #1668),
author | David Demelier <markand@malikania.fr> |
---|---|
date | Wed, 10 Jul 2019 13:39:20 +0200 |
parents | tests/src/libirccd-js/js-api-elapsedtimer/main.cpp@06cc2f95f479 |
children | 7619105cc818 |
rev | line source |
---|---|
0 | 1 /* |
846
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
2 * main.cpp -- test Irccd.Chrono API |
0 | 3 * |
824
06cc2f95f479
misc: happy new year!
David Demelier <markand@malikania.fr>
parents:
773
diff
changeset
|
4 * Copyright (c) 2013-2019 David Demelier <markand@malikania.fr> |
0 | 5 * |
6 * Permission to use, copy, modify, and/or distribute this software for any | |
7 * purpose with or without fee is hereby granted, provided that the above | |
8 * copyright notice and this permission notice appear in all copies. | |
9 * | |
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | |
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | |
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | |
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | |
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | |
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | |
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | |
17 */ | |
18 | |
846
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
19 #define BOOST_TEST_MODULE "Chrono Javascript API" |
492
173c52d3120b
Tests: create js_test fixture, closes #688
David Demelier <markand@malikania.fr>
parents:
489
diff
changeset
|
20 #include <boost/test/unit_test.hpp> |
0 | 21 |
22 #include <thread> | |
23 | |
758
445c071e8efb
Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents:
757
diff
changeset
|
24 #include <irccd/test/js_fixture.hpp> |
492
173c52d3120b
Tests: create js_test fixture, closes #688
David Demelier <markand@malikania.fr>
parents:
489
diff
changeset
|
25 |
0 | 26 using namespace std::chrono_literals; |
27 | |
760
35c1517d705d
Tests: make consistency
David Demelier <markand@malikania.fr>
parents:
758
diff
changeset
|
28 using namespace irccd::js; |
35c1517d705d
Tests: make consistency
David Demelier <markand@malikania.fr>
parents:
758
diff
changeset
|
29 using namespace irccd::test; |
35c1517d705d
Tests: make consistency
David Demelier <markand@malikania.fr>
parents:
758
diff
changeset
|
30 |
35c1517d705d
Tests: make consistency
David Demelier <markand@malikania.fr>
parents:
758
diff
changeset
|
31 namespace irccd { |
0 | 32 |
723
e8c4ba5ed1c6
Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
33 namespace { |
e8c4ba5ed1c6
Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
34 |
846
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
35 BOOST_FIXTURE_TEST_SUITE(chrono_js_api_suite, js_fixture) |
0 | 36 |
846
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
37 BOOST_AUTO_TEST_CASE(simple) |
0 | 38 { |
846
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
39 if (duk_peval_string(plugin_->get_context(), "timer = new Irccd.Chrono();") != 0) |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
760
diff
changeset
|
40 throw duk::get_stack(plugin_->get_context(), -1); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
41 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
760
diff
changeset
|
42 std::this_thread::sleep_for(300ms); |
0 | 43 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
760
diff
changeset
|
44 if (duk_peval_string(plugin_->get_context(), "result = timer.elapsed();") != 0) |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
760
diff
changeset
|
45 throw duk::get_stack(plugin_->get_context(), -1); |
0 | 46 |
773
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
760
diff
changeset
|
47 BOOST_REQUIRE(duk_get_global_string(plugin_->get_context(), "result")); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
760
diff
changeset
|
48 BOOST_REQUIRE_GE(duk_get_int(plugin_->get_context(), -1), 250); |
8c44bbcbbab9
Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents:
760
diff
changeset
|
49 BOOST_REQUIRE_LE(duk_get_int(plugin_->get_context(), -1), 350); |
0 | 50 } |
51 | |
846
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
52 BOOST_AUTO_TEST_CASE(pause) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
53 { |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
54 /* |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
55 * Create a time and stop it immediately. Then wait for 1 seconds, |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
56 * the time must still be near 0. |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
57 */ |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
58 if (duk_peval_string(plugin_->get_context(), "timer = new Irccd.Chrono(); timer.pause();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
59 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
60 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
61 std::this_thread::sleep_for(1s); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
62 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
63 if (duk_peval_string(plugin_->get_context(), "result = timer.elapsed();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
64 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
65 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
66 BOOST_REQUIRE(duk_get_global_string(plugin_->get_context(), "result")); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
67 BOOST_REQUIRE_LE(duk_get_int(plugin_->get_context(), -1), 50); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
68 } |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
69 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
70 BOOST_AUTO_TEST_CASE(resume) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
71 { |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
72 /* |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
73 * Create a time and stop it immediately. Then wait for 1 seconds, |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
74 * resume it and wait for 1 second more. The elapsed time must not be |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
75 * greater than 1s. |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
76 */ |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
77 if (duk_peval_string(plugin_->get_context(), "timer = new Irccd.Chrono(); timer.pause();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
78 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
79 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
80 std::this_thread::sleep_for(1s); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
81 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
82 if (duk_peval_string(plugin_->get_context(), "timer.resume();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
83 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
84 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
85 std::this_thread::sleep_for(1s); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
86 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
87 if (duk_peval_string(plugin_->get_context(), "result = timer.elapsed();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
88 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
89 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
90 BOOST_REQUIRE(duk_get_global_string(plugin_->get_context(), "result")); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
91 BOOST_REQUIRE_GE(duk_get_int(plugin_->get_context(), -1), 950); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
92 BOOST_REQUIRE_LE(duk_get_int(plugin_->get_context(), -1), 1050); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
93 } |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
94 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
95 BOOST_AUTO_TEST_CASE(start) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
96 { |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
97 /* |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
98 * Create a timer and wait for it to accumulate some time. Then use |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
99 * start to reset its value and wait for 1s. The elapsed time must not |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
100 * be greater than 1s. |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
101 */ |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
102 if (duk_peval_string(plugin_->get_context(), "timer = new Irccd.Chrono(); timer.start();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
103 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
104 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
105 std::this_thread::sleep_for(1s); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
106 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
107 if (duk_peval_string(plugin_->get_context(), "timer.start();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
108 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
109 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
110 std::this_thread::sleep_for(1s); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
111 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
112 if (duk_peval_string(plugin_->get_context(), "result = timer.elapsed();") != 0) |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
113 throw duk::get_stack(plugin_->get_context(), -1); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
114 |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
115 BOOST_REQUIRE(duk_get_global_string(plugin_->get_context(), "result")); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
116 BOOST_REQUIRE_GE(duk_get_int(plugin_->get_context(), -1), 950); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
117 BOOST_REQUIRE_LE(duk_get_int(plugin_->get_context(), -1), 1050); |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
118 } |
dcef68d82fd3
irccd: rework Irccd.ElapsedTimer -> Irccd.Chrono API, closes #1667
David Demelier <markand@malikania.fr>
parents:
824
diff
changeset
|
119 |
723
e8c4ba5ed1c6
Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
120 BOOST_AUTO_TEST_SUITE_END() |
0 | 121 |
723
e8c4ba5ed1c6
Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
122 } // !namespace |
e8c4ba5ed1c6
Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents:
722
diff
changeset
|
123 |
760
35c1517d705d
Tests: make consistency
David Demelier <markand@malikania.fr>
parents:
758
diff
changeset
|
124 } // !irccd |