Mercurial > irccd
annotate tests/js-timer/main.cpp @ 127:77f950caab35
Irccd: implement RuleService, #498
author | David Demelier <markand@malikania.fr> |
---|---|
date | Wed, 11 May 2016 13:27:39 +0200 |
parents | 1125d90b3b44 |
children | 2d8343b86e2e |
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> |
95
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
75
diff
changeset
|
24 #include <irccd/system.hpp> |
0 | 25 |
26 using namespace irccd; | |
27 | |
28 TEST(Basic, single) | |
29 { | |
30 Irccd irccd; | |
31 ElapsedTimer timer; | |
32 | |
33 auto plugin = std::make_shared<Plugin>("timer", IRCCD_TESTS_DIRECTORY "/timer-single.js"); | |
34 | |
35 irccd.addPlugin(plugin); | |
36 | |
37 while (timer.elapsed() < 3000) { | |
38 irccd.poll(); | |
39 irccd.dispatch(); | |
40 } | |
41 | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
42 ASSERT_EQ(1, duk::getGlobal<int>(plugin->context(), "count")); |
0 | 43 } |
44 | |
45 TEST(Basic, repeat) | |
46 { | |
47 Irccd irccd; | |
48 ElapsedTimer timer; | |
49 | |
50 auto plugin = std::make_shared<Plugin>("timer", IRCCD_TESTS_DIRECTORY "/timer-repeat.js"); | |
51 | |
52 irccd.addPlugin(plugin); | |
53 | |
54 while (timer.elapsed() < 3000) { | |
55 irccd.poll(); | |
56 irccd.dispatch(); | |
57 } | |
58 | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
59 ASSERT_GE(duk::getGlobal<int>(plugin->context(), "count"), 5); |
0 | 60 } |
61 | |
62 #if 0 | |
63 | |
64 /* | |
65 * XXX: currently disabled because it will break single-shot timers. | |
66 */ | |
67 | |
68 TEST(Basic, pending) | |
69 { | |
70 /* | |
71 * This test ensure that if pending actions on a stopped timer are never executed. | |
72 */ | |
73 Irccd irccd; | |
74 ElapsedTimer timer; | |
75 | |
76 auto plugin = std::make_shared<Plugin>("timer", IRCCD_TESTS_DIRECTORY "/timer-pending.js"); | |
77 | |
78 irccd.addPlugin(plugin); | |
79 irccd.poll(); | |
80 irccd.dispatch(); | |
81 | |
82 ASSERT_EQ(0, plugin->context().getGlobal<int>("count")); | |
83 } | |
84 | |
85 #endif | |
86 | |
87 int main(int argc, char **argv) | |
88 { | |
89 /* Needed for some components */ | |
90 sys::setProgramName("irccd"); | |
91 path::setApplicationPath(argv[0]); | |
92 log::setInterface(std::make_unique<log::Console>()); | |
93 log::setVerbose(true); | |
94 testing::InitGoogleTest(&argc, argv); | |
95 | |
96 return RUN_ALL_TESTS(); | |
97 } |