Mercurial > irccd
annotate tests/js-logger/main.cpp @ 124:0895acad4072
Irccd: implement Service and InterruptService, #494, #495
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 10 May 2016 22:11:36 +0200 |
parents | 1ed760f6e0c6 |
children | 28080933bac6 |
rev | line source |
---|---|
0 | 1 /* |
2 * main.cpp -- test Irccd.Logger 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:
84
diff
changeset
|
21 #include <irccd/sysconfig.hpp> |
0 | 22 |
95
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
84
diff
changeset
|
23 #include <irccd/js-irccd.hpp> |
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
84
diff
changeset
|
24 #include <irccd/js-logger.hpp> |
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
84
diff
changeset
|
25 #include <irccd/logger.hpp> |
0 | 26 |
27 using namespace irccd; | |
28 | |
29 namespace { | |
30 | |
31 std::string lineInfo; | |
32 std::string lineWarning; | |
33 std::string lineDebug; | |
34 | |
35 } // !namespace | |
36 | |
37 class TestLogger : public log::Interface { | |
38 public: | |
105
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
39 void info(const std::string &line) override |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
40 { |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
41 lineInfo = line; |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
42 } |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
43 |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
44 void warning(const std::string &line) override |
0 | 45 { |
105
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
46 lineWarning = line; |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
47 } |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
48 |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
49 void debug(const std::string &line) override |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
50 { |
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
51 lineDebug = line; |
0 | 52 } |
53 }; | |
54 | |
55 TEST(TestJsLogger, info) | |
56 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
57 duk::Context ctx; |
0 | 58 |
59 loadJsIrccd(ctx); | |
60 loadJsLogger(ctx); | |
61 | |
62 try { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
63 duk::putGlobal(ctx, "\xff""\xff""name", "test"); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
64 |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
105
diff
changeset
|
65 if (duk::pevalString(ctx, "Irccd.Logger.info(\"hello!\");") != 0) { |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
66 throw duk::error(ctx, -1); |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
105
diff
changeset
|
67 } |
0 | 68 |
69 ASSERT_EQ("plugin test: hello!", lineInfo); | |
70 } catch (const std::exception &ex) { | |
71 FAIL() << ex.what(); | |
72 } | |
73 } | |
74 | |
75 TEST(TestJsLogger, warning) | |
76 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
77 duk::Context ctx; |
0 | 78 |
79 loadJsIrccd(ctx); | |
80 loadJsLogger(ctx); | |
81 | |
82 try { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
83 duk::putGlobal(ctx, "\xff""\xff""name", "test"); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
84 |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
105
diff
changeset
|
85 if (duk::pevalString(ctx, "Irccd.Logger.warning(\"FAIL!\");") != 0) { |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
86 throw duk::error(ctx, -1); |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
105
diff
changeset
|
87 } |
0 | 88 |
89 ASSERT_EQ("plugin test: FAIL!", lineWarning); | |
90 } catch (const std::exception &ex) { | |
91 FAIL() << ex.what(); | |
92 } | |
93 } | |
94 | |
95 #if !defined(NDEBUG) | |
96 | |
97 TEST(TestJsLogger, debug) | |
98 { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
99 duk::Context ctx; |
0 | 100 |
101 loadJsIrccd(ctx); | |
102 loadJsLogger(ctx); | |
103 | |
104 try { | |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
105 duk::putGlobal(ctx, "\xff""\xff""name", "test"); |
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
106 |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
105
diff
changeset
|
107 if (duk::pevalString(ctx, "Irccd.Logger.debug(\"starting\");") != 0) { |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
108 throw duk::error(ctx, -1); |
111
1ed760f6e0c6
Irccd: new brace styles, #487
David Demelier <markand@malikania.fr>
parents:
105
diff
changeset
|
109 } |
0 | 110 |
111 ASSERT_EQ("plugin test: starting", lineDebug); | |
112 } catch (const std::exception &ex) { | |
113 FAIL() << ex.what(); | |
114 } | |
115 } | |
116 | |
117 #endif | |
118 | |
119 int main(int argc, char **argv) | |
120 { | |
121 testing::InitGoogleTest(&argc, argv); | |
122 | |
123 log::setVerbose(true); | |
124 log::setInterface(std::make_unique<TestLogger>()); | |
125 | |
126 return RUN_ALL_TESTS(); | |
127 } |