Mercurial > irccd
annotate tests/js-elapsedtimer/main.cpp @ 351:15da984ce7ea
Irccd: revert ownership as it's a cleaner solution
author | David Demelier <markand@malikania.fr> |
---|---|
date | Mon, 14 Nov 2016 13:32:38 +0100 |
parents | 287e9ede5eef |
children | c6fbb6e0e06d |
rev | line source |
---|---|
0 | 1 /* |
2 * main.cpp -- test Irccd.ElapsedTimer 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 | |
21 #include <thread> | |
22 | |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
23 #include <irccd/irccd.hpp> |
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
24 #include <irccd/mod-irccd.hpp> |
134
dc7d6ba08122
Irccd: load modules and apply them to the plugins
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
25 #include <irccd/mod-elapsed-timer.hpp> |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
26 #include <irccd/plugin-js.hpp> |
350 | 27 #include <irccd/service.hpp> |
0 | 28 |
29 using namespace irccd; | |
30 using namespace std::chrono_literals; | |
31 | |
32 class TestElapsedTimer : public testing::Test { | |
33 protected: | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
34 Irccd m_irccd; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
35 std::shared_ptr<JsPlugin> m_plugin; |
0 | 36 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
37 TestElapsedTimer() |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
38 : m_plugin(std::make_shared<JsPlugin>("empty", SOURCEDIR "/empty.js")) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
39 { |
351
15da984ce7ea
Irccd: revert ownership as it's a cleaner solution
David Demelier <markand@malikania.fr>
parents:
350
diff
changeset
|
40 IrccdModule().load(m_irccd, m_plugin); |
15da984ce7ea
Irccd: revert ownership as it's a cleaner solution
David Demelier <markand@malikania.fr>
parents:
350
diff
changeset
|
41 ElapsedTimerModule().load(m_irccd, m_plugin); |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
42 } |
0 | 43 }; |
44 | |
45 TEST_F(TestElapsedTimer, standard) | |
46 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
47 try { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
48 if (duk_peval_string(m_plugin->context(), "timer = new Irccd.ElapsedTimer();") != 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
49 throw dukx_exception(m_plugin->context(), -1); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
50 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
51 std::this_thread::sleep_for(300ms); |
0 | 52 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
53 if (duk_peval_string(m_plugin->context(), "result = timer.elapsed();") != 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
54 throw dukx_exception(m_plugin->context(), -1); |
0 | 55 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
56 ASSERT_TRUE(duk_get_global_string(m_plugin->context(), "result")); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
57 ASSERT_GE(duk_get_int(m_plugin->context(), -1), 250); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
58 ASSERT_LE(duk_get_int(m_plugin->context(), -1), 350); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
59 } catch (const std::exception &ex) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
60 FAIL() << ex.what(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
61 } |
0 | 62 } |
63 | |
64 TEST_F(TestElapsedTimer, reset) | |
65 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
66 try { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
67 if (duk_peval_string(m_plugin->context(), "timer = new Irccd.ElapsedTimer();") != 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
68 throw dukx_exception(m_plugin->context(), -1); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
69 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
70 std::this_thread::sleep_for(300ms); |
0 | 71 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
72 if (duk_peval_string(m_plugin->context(), "timer.reset(); result = timer.elapsed();") != 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
73 throw dukx_exception(m_plugin->context(), -1); |
0 | 74 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
75 ASSERT_TRUE(duk_get_global_string(m_plugin->context(), "result")); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
76 ASSERT_LE(duk_get_int(m_plugin->context(), -1), 100); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
77 } catch (const std::exception &ex) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
78 FAIL() << ex.what(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
79 } |
0 | 80 } |
81 | |
82 int main(int argc, char **argv) | |
83 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
84 testing::InitGoogleTest(&argc, argv); |
0 | 85 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
86 return RUN_ALL_TESTS(); |
0 | 87 } |