Mercurial > irccd
annotate tests/js-elapsedtimer/main.cpp @ 179:ef527409e638
Irccd: update JavaScript code
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 31 May 2016 21:03:01 +0200 |
parents | 9f36f71a08c5 |
children | cb61cc16e2b6 |
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> |
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
27 #include <irccd/service-module.hpp> |
0 | 28 |
29 using namespace irccd; | |
30 using namespace std::chrono_literals; | |
31 | |
32 class TestElapsedTimer : public testing::Test { | |
33 protected: | |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
34 Irccd m_irccd; |
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
35 std::shared_ptr<JsPlugin> m_plugin; |
0 | 36 |
37 TestElapsedTimer() | |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
38 : m_plugin(std::make_shared<JsPlugin>("empty", SOURCEDIR "/empty.js")) |
0 | 39 { |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
40 m_irccd.moduleService().get("Irccd")->load(m_irccd, *m_plugin); |
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
41 m_irccd.moduleService().get("Irccd.ElapsedTimer")->load(m_irccd, *m_plugin); |
0 | 42 } |
43 }; | |
44 | |
45 TEST_F(TestElapsedTimer, standard) | |
46 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
47 try { |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
48 if (duk::pevalString(m_plugin->context(), "timer = new Irccd.ElapsedTimer();") != 0) |
179
ef527409e638
Irccd: update JavaScript code
David Demelier <markand@malikania.fr>
parents:
167
diff
changeset
|
49 throw duk::exception(m_plugin->context(), -1); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
50 |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
51 std::this_thread::sleep_for(300ms); |
0 | 52 |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
53 if (duk::pevalString(m_plugin->context(), "result = timer.elapsed();") != 0) |
179
ef527409e638
Irccd: update JavaScript code
David Demelier <markand@malikania.fr>
parents:
167
diff
changeset
|
54 throw duk::exception(m_plugin->context(), -1); |
0 | 55 |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
56 ASSERT_GE(duk::getGlobal<int>(m_plugin->context(), "result"), 250); |
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
57 ASSERT_LE(duk::getGlobal<int>(m_plugin->context(), "result"), 350); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
58 } catch (const std::exception &ex) { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
59 FAIL() << ex.what(); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
60 } |
0 | 61 } |
62 | |
63 TEST_F(TestElapsedTimer, reset) | |
64 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
65 try { |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
66 if (duk::pevalString(m_plugin->context(), "timer = new Irccd.ElapsedTimer();") != 0) |
179
ef527409e638
Irccd: update JavaScript code
David Demelier <markand@malikania.fr>
parents:
167
diff
changeset
|
67 throw duk::exception(m_plugin->context(), -1); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
68 |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
69 std::this_thread::sleep_for(300ms); |
0 | 70 |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
71 if (duk::pevalString(m_plugin->context(), "timer.reset(); result = timer.elapsed();") != 0) |
179
ef527409e638
Irccd: update JavaScript code
David Demelier <markand@malikania.fr>
parents:
167
diff
changeset
|
72 throw duk::exception(m_plugin->context(), -1); |
0 | 73 |
167
9f36f71a08c5
Irccd: unbreak test-js-elapsedtimer
David Demelier <markand@malikania.fr>
parents:
134
diff
changeset
|
74 ASSERT_LE(duk::getGlobal<int>(m_plugin->context(), "result"), 100); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
75 } catch (const std::exception &ex) { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
76 FAIL() << ex.what(); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
77 } |
0 | 78 } |
79 | |
80 int main(int argc, char **argv) | |
81 { | |
82 testing::InitGoogleTest(&argc, argv); | |
83 | |
84 return RUN_ALL_TESTS(); | |
85 } |