Mercurial > irccd
annotate tests/js-elapsedtimer/main.cpp @ 108:af84dd3d585b
Irccd: try to fix errors in timer tests, #486
author | David Demelier <markand@malikania.fr> |
---|---|
date | Wed, 27 Apr 2016 13:07:21 +0200 |
parents | 1125d90b3b44 |
children | 1ed760f6e0c6 |
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> |
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
75
diff
changeset
|
24 #include <irccd/js-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 { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
43 if (duk::pevalString(m_context, "timer = new Irccd.ElapsedTimer();") != 0) |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
44 throw duk::error(m_context, -1); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
45 |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
46 std::this_thread::sleep_for(300ms); |
0 | 47 |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
48 if (duk::pevalString(m_context, "result = timer.elapsed();") != 0) |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
49 throw duk::error(m_context, -1); |
0 | 50 |
108
af84dd3d585b
Irccd: try to fix errors in timer tests, #486
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
51 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
|
52 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
|
53 } catch (const std::exception &ex) { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
54 FAIL() << ex.what(); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
55 } |
0 | 56 } |
57 | |
58 TEST_F(TestElapsedTimer, reset) | |
59 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
60 try { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
61 if (duk::pevalString(m_context, "timer = new Irccd.ElapsedTimer();") != 0) |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
62 throw duk::error(m_context, -1); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
63 |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
64 std::this_thread::sleep_for(300ms); |
0 | 65 |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
66 if (duk::pevalString(m_context, "timer.reset(); result = timer.elapsed();") != 0) |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
67 throw duk::error(m_context, -1); |
0 | 68 |
108
af84dd3d585b
Irccd: try to fix errors in timer tests, #486
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
69 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
|
70 } catch (const std::exception &ex) { |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
71 FAIL() << ex.what(); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
72 } |
0 | 73 } |
74 | |
75 int main(int argc, char **argv) | |
76 { | |
77 testing::InitGoogleTest(&argc, argv); | |
78 | |
79 return RUN_ALL_TESTS(); | |
80 } |