Mercurial > irccd
annotate tests/js-elapsedtimer/main.cpp @ 134:dc7d6ba08122
Irccd: load modules and apply them to the plugins
author | David Demelier <markand@malikania.fr> |
---|---|
date | Sun, 15 May 2016 21:36:04 +0200 |
parents | 1ed760f6e0c6 |
children | 9f36f71a08c5 |
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 | |
95
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
75
diff
changeset
|
23 #include <irccd/js-irccd.hpp> |
134
dc7d6ba08122
Irccd: load modules and apply them to the plugins
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
24 #include <irccd/mod-elapsed-timer.hpp> |
0 | 25 |
26 using namespace irccd; | |
27 using namespace std::chrono_literals; | |
28 | |
29 class TestElapsedTimer : public testing::Test { | |
30 protected: | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
31 duk::Context m_context; |
0 | 32 |
33 TestElapsedTimer() | |
34 { | |
35 loadJsIrccd(m_context); | |
36 loadJsElapsedTimer(m_context); | |
37 } | |
38 }; | |
39 | |
40 TEST_F(TestElapsedTimer, standard) | |
41 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
42 try { |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
43 if (duk::pevalString(m_context, "timer = new Irccd.ElapsedTimer();") != 0) { |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
44 throw duk::error(m_context, -1); |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
45 } |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
46 |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
47 std::this_thread::sleep_for(300ms); |
0 | 48 |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
49 if (duk::pevalString(m_context, "result = timer.elapsed();") != 0) { |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
50 throw duk::error(m_context, -1); |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
51 } |
0 | 52 |
108
af84dd3d585b
Irccd: try to fix errors in timer tests, #486
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
53 ASSERT_GE(duk::getGlobal<int>(m_context, "result"), 250); |
af84dd3d585b
Irccd: try to fix errors in timer tests, #486
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
54 ASSERT_LE(duk::getGlobal<int>(m_context, "result"), 350); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
55 } catch (const std::exception &ex) { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
56 FAIL() << ex.what(); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
57 } |
0 | 58 } |
59 | |
60 TEST_F(TestElapsedTimer, reset) | |
61 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
62 try { |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
63 if (duk::pevalString(m_context, "timer = new Irccd.ElapsedTimer();") != 0) { |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
64 throw duk::error(m_context, -1); |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
65 } |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
66 |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
67 std::this_thread::sleep_for(300ms); |
0 | 68 |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
69 if (duk::pevalString(m_context, "timer.reset(); result = timer.elapsed();") != 0) { |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
70 throw duk::error(m_context, -1); |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
108
diff
changeset
|
71 } |
0 | 72 |
108
af84dd3d585b
Irccd: try to fix errors in timer tests, #486
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
73 ASSERT_LE(duk::getGlobal<int>(m_context, "result"), 100); |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
74 } catch (const std::exception &ex) { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
75 FAIL() << ex.what(); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
76 } |
0 | 77 } |
78 | |
79 int main(int argc, char **argv) | |
80 { | |
81 testing::InitGoogleTest(&argc, argv); | |
82 | |
83 return RUN_ALL_TESTS(); | |
84 } |