annotate tests/libcommon/js-elapsed-timer/main.cpp @ 189:f28cb6d04731

Misc: extreme refactoring
author David Demelier <markand@malikania.fr>
date Thu, 25 Oct 2018 21:36:14 +0200
parents 0cecdadfb5c4
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 /*
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 * main.cpp -- test ElapsedTimer (JavaScript binding)
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 *
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
4 * Copyright (c) 2013-2018 David Demelier <markand@malikania.fr>
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 *
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 * copyright notice and this permission notice appear in all copies.
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 *
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 */
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
18
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 #include <thread>
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
20
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
21 #define BOOST_TEST_MODULE "Javascript ElapsedTimer"
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
22 #include <boost/format.hpp>
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
23 #include <boost/test/unit_test.hpp>
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
24
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
25 #include <malikania/js/test/js_api_fixture.hpp>
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
26
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
27 using boost::format;
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
28 using boost::str;
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
29
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
30 using namespace std::chrono_literals;
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
31
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
32 namespace mlk {
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
33
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
34 namespace {
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
35
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
36 /*
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
37 * For all tests, we tolerate 30 ms because some systems have bigger lags.
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
38 */
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
39 constexpr int margin = 30;
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
40
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
41 void assert_range(int value, int expected)
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
42 {
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
43 if (value < (expected - margin) || value > (expected + margin))
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
44 throw std::invalid_argument(
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
45 str(format("%d is bigger than [%d, %d]") % value % (expected - margin) % (expected + margin)));
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
46 }
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
47
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
48 BOOST_FIXTURE_TEST_SUITE(test_elapsed_timer_suite, js::test::js_api_fixture)
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
49
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
50 BOOST_AUTO_TEST_CASE(standard)
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
51 {
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
52 if (duk_peval_string(ctx_, "timer = new Malikania.ElapsedTimer();") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
53 throw mlk::js::duk::get_stack(ctx_, -1);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
54
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
55 std::this_thread::sleep_for(300ms);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
56
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
57 if (duk_peval_string(ctx_, "result = timer.elapsed();") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
58 throw mlk::js::duk::get_stack(ctx_, -1);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
59
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
60 duk_get_global_string(ctx_, "result");
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
61 assert_range(duk_to_int(ctx_, -1), 300);
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
62 duk_pop(ctx_);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
63 }
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
64
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
65 BOOST_AUTO_TEST_CASE(pause)
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
66 {
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
67 if (duk_peval_string(ctx_, "timer = new Malikania.ElapsedTimer();") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
68 throw mlk::js::duk::get_stack(ctx_, -1);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
69
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
70 /*
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
71 * Simulate a pause in the game like this:
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
72 *
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
73 * start pause restart elapsed
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
74 * | 10ms |.5ms.| 6ms |
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
75 *
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
76 * Since the game was paused, the 5ms must not be totalized.
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
77 */
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
78 std::this_thread::sleep_for(10ms);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
79
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
80 if (duk_peval_string(ctx_, "timer.pause();") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
81 throw mlk::js::duk::get_stack(ctx_, -1);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
82
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
83 std::this_thread::sleep_for(5ms);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
84
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
85 if (duk_peval_string(ctx_, "timer.restart();") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
86 throw mlk::js::duk::get_stack(ctx_, -1);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
87
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
88 std::this_thread::sleep_for(6ms);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
89
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
90 if (duk_peval_string(ctx_, "result = timer.elapsed()") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
91 throw mlk::js::duk::get_stack(ctx_, -1);
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
92
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
93 duk_get_global_string(ctx_, "result");
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
94 assert_range(duk_to_int(ctx_, -1), 16);
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
95 duk_pop(ctx_);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
96 }
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
97
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
98 BOOST_AUTO_TEST_CASE(doublecheck)
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
99 {
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
100 if (duk_peval_string(ctx_, "timer = new Malikania.ElapsedTimer();") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
101 throw mlk::js::duk::get_stack(ctx_, -1);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
102
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
103 std::this_thread::sleep_for(50ms);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
104
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
105 if (duk_peval_string(ctx_, "result = timer.elapsed()") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
106 throw mlk::js::duk::get_stack(ctx_, -1);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
107
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
108 std::this_thread::sleep_for(50ms);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
109
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
110 if (duk_peval_string(ctx_, "result = timer.elapsed()") != 0)
189
f28cb6d04731 Misc: extreme refactoring
David Demelier <markand@malikania.fr>
parents: 188
diff changeset
111 throw mlk::js::duk::get_stack(ctx_, -1);
188
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
112
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
113 duk_get_global_string(ctx_, "result");
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
114 assert_range(duk_to_int(ctx_, -1), 100);
0cecdadfb5c4 Misc: rework javascript bindings, closes #916
David Demelier <markand@malikania.fr>
parents: 182
diff changeset
115 duk_pop(ctx_);
182
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
116 }
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
117
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
118 BOOST_AUTO_TEST_SUITE_END()
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
119
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
120 } // !namespace
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
121
3107ce017c3a Misc: switch back to SDL
David Demelier <markand@malikania.fr>
parents:
diff changeset
122 } // !mlk