Mercurial > irccd
annotate tests/js-timer/main.cpp @ 207:6635b9187d71
Irccd: switch to 4 spaces indent, #518
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 21 Jun 2016 20:52:17 +0200 |
parents | cb61cc16e2b6 |
children | 79d9840811a1 |
rev | line source |
---|---|
0 | 1 /* |
2 * main.cpp -- test Irccd.Timer API | |
3 * | |
4 * Copyright (c) 2013-2016 David Demelier <markand@malikania.fr> | |
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 | |
19 #include <gtest/gtest.h> | |
20 | |
95
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
75
diff
changeset
|
21 #include <irccd/elapsed-timer.hpp> |
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
75
diff
changeset
|
22 #include <irccd/irccd.hpp> |
127
77f950caab35
Irccd: implement RuleService, #498
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
23 #include <irccd/logger.hpp> |
131
77c90336ba56
Irccd: initial Plugin split, #501
David Demelier <markand@malikania.fr>
parents:
128
diff
changeset
|
24 #include <irccd/plugin-js.hpp> |
128
2d8343b86e2e
Irccd: implement PluginService, #499
David Demelier <markand@malikania.fr>
parents:
127
diff
changeset
|
25 #include <irccd/service-plugin.hpp> |
95
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
75
diff
changeset
|
26 #include <irccd/system.hpp> |
0 | 27 |
28 using namespace irccd; | |
29 | |
30 TEST(Basic, single) | |
31 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
32 Irccd irccd; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
33 ElapsedTimer timer; |
0 | 34 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
35 auto plugin = std::make_shared<JsPlugin>("timer", IRCCD_TESTS_DIRECTORY "/timer-single.js"); |
0 | 36 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
37 plugin->onLoad(irccd); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
38 irccd.pluginService().add(plugin); |
0 | 39 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
40 while (timer.elapsed() < 3000) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
41 irccd.poll(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
42 irccd.dispatch(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
43 } |
0 | 44 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
45 ASSERT_TRUE(duk_get_global_string(plugin->context(), "count")); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
46 ASSERT_EQ(1, duk_get_int(plugin->context(), -1)); |
0 | 47 } |
48 | |
49 TEST(Basic, repeat) | |
50 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
51 Irccd irccd; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
52 ElapsedTimer timer; |
0 | 53 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
54 auto plugin = std::make_shared<JsPlugin>("timer", IRCCD_TESTS_DIRECTORY "/timer-repeat.js"); |
0 | 55 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
56 plugin->onLoad(irccd); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
57 irccd.pluginService().add(plugin); |
0 | 58 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
59 while (timer.elapsed() < 3000) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
60 irccd.poll(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
61 irccd.dispatch(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
62 } |
0 | 63 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
64 ASSERT_TRUE(duk_get_global_string(plugin->context(), "count")); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
65 ASSERT_GE(duk_get_int(plugin->context(), -1), 5); |
0 | 66 } |
67 | |
68 #if 0 | |
69 | |
70 /* | |
71 * XXX: currently disabled because it will break single-shot timers. | |
72 */ | |
73 | |
74 TEST(Basic, pending) | |
75 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
76 /* |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
77 * This test ensure that if pending actions on a stopped timer are never executed. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
78 */ |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
79 Irccd irccd; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
80 ElapsedTimer timer; |
0 | 81 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
82 auto plugin = std::make_shared<Plugin>("timer", IRCCD_TESTS_DIRECTORY "/timer-pending.js"); |
0 | 83 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
84 irccd.addPlugin(plugin); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
85 irccd.poll(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
86 irccd.dispatch(); |
0 | 87 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
88 ASSERT_EQ(0, plugin->context().getGlobal<int>("count")); |
0 | 89 } |
90 | |
91 #endif | |
92 | |
93 int main(int argc, char **argv) | |
94 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
95 // Needed for some components. |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
96 sys::setProgramName("irccd"); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
97 path::setApplicationPath(argv[0]); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
98 log::setInterface(std::make_unique<log::Silent>()); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
99 log::setVerbose(true); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
100 testing::InitGoogleTest(&argc, argv); |
0 | 101 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
190
diff
changeset
|
102 return RUN_ALL_TESTS(); |
0 | 103 } |