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
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 /*
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 * main.cpp -- test Irccd.Logger API
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 *
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
4 * Copyright (c) 2013-2016 David Demelier <markand@malikania.fr>
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 *
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 * copyright notice and this permission notice appear in all copies.
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 *
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 */
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
18
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 #include <gtest/gtest.h>
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
20
95
1125d90b3b44 Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents: 84
diff changeset
21 #include <irccd/sysconfig.hpp>
0
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
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
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
26
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
27 using namespace irccd;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
28
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 namespace {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
30
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
31 std::string lineInfo;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
32 std::string lineWarning;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
33 std::string lineDebug;
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
34
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
35 } // !namespace
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
36
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
37 class TestLogger : public log::Interface {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
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
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
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
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
52 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
53 };
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
54
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
55 TEST(TestJsLogger, info)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
56 {
75
f8160d515a76 Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents: 0
diff changeset
57 duk::Context ctx;
0
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
58
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
59 loadJsIrccd(ctx);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
60 loadJsLogger(ctx);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
61
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
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
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
68
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
69 ASSERT_EQ("plugin test: hello!", lineInfo);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
70 } catch (const std::exception &ex) {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
71 FAIL() << ex.what();
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
72 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
73 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
74
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
75 TEST(TestJsLogger, warning)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
76 {
75
f8160d515a76 Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents: 0
diff changeset
77 duk::Context ctx;
0
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
78
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
79 loadJsIrccd(ctx);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
80 loadJsLogger(ctx);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
81
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
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
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
88
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
89 ASSERT_EQ("plugin test: FAIL!", lineWarning);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
90 } catch (const std::exception &ex) {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
91 FAIL() << ex.what();
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
92 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
93 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
94
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
95 #if !defined(NDEBUG)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
96
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
97 TEST(TestJsLogger, debug)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
98 {
75
f8160d515a76 Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents: 0
diff changeset
99 duk::Context ctx;
0
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
100
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
101 loadJsIrccd(ctx);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
102 loadJsLogger(ctx);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
103
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
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
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
110
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
111 ASSERT_EQ("plugin test: starting", lineDebug);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
112 } catch (const std::exception &ex) {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
113 FAIL() << ex.what();
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
114 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
115 }
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
116
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
117 #endif
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
118
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
119 int main(int argc, char **argv)
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
120 {
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
121 testing::InitGoogleTest(&argc, argv);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
122
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
123 log::setVerbose(true);
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
124 log::setInterface(std::make_unique<TestLogger>());
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
125
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
126 return RUN_ALL_TESTS();
1158cffe5a5e Initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
127 }