0
|
1 /* |
|
2 * main.cpp -- test Irccd.Unicode 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 /* |
|
20 * /!\ Be sure that this file is kept saved in UTF-8 /!\ |
|
21 */ |
|
22 |
|
23 #include <gtest/gtest.h> |
|
24 |
|
25 #include <js-irccd.h> |
|
26 #include <js-unicode.h> |
|
27 |
|
28 using namespace irccd; |
|
29 |
|
30 TEST(TestJsUnicode, isLetter) |
|
31 { |
|
32 js::Context ctx; |
|
33 |
|
34 loadJsIrccd(ctx); |
|
35 loadJsUnicode(ctx); |
|
36 |
|
37 try { |
|
38 ctx.peval(js::Script{"result = Irccd.Unicode.isLetter(String('é').charCodeAt(0));"}); |
|
39 ASSERT_TRUE(ctx.getGlobal<bool>("result")); |
|
40 |
|
41 ctx.peval(js::Script{"result = Irccd.Unicode.isLetter(String('€').charCodeAt(0));"}); |
|
42 ASSERT_FALSE(ctx.getGlobal<bool>("result")); |
|
43 } catch (const std::exception &ex) { |
|
44 FAIL() << ex.what(); |
|
45 } |
|
46 } |
|
47 |
|
48 TEST(TestJsUnicode, isLower) |
|
49 { |
|
50 js::Context ctx; |
|
51 |
|
52 loadJsIrccd(ctx); |
|
53 loadJsUnicode(ctx); |
|
54 |
|
55 try { |
|
56 ctx.peval(js::Script{"result = Irccd.Unicode.isLower(String('é').charCodeAt(0));"}); |
|
57 ASSERT_TRUE(ctx.getGlobal<bool>("result")); |
|
58 |
|
59 ctx.peval(js::Script{"result = Irccd.Unicode.isLower(String('É').charCodeAt(0));"}); |
|
60 ASSERT_FALSE(ctx.getGlobal<bool>("result")); |
|
61 } catch (const std::exception &ex) { |
|
62 FAIL() << ex.what(); |
|
63 } |
|
64 } |
|
65 |
|
66 TEST(TestJsUnicode, isUpper) |
|
67 { |
|
68 js::Context ctx; |
|
69 |
|
70 loadJsIrccd(ctx); |
|
71 loadJsUnicode(ctx); |
|
72 |
|
73 try { |
|
74 ctx.peval(js::Script{"result = Irccd.Unicode.isUpper(String('É').charCodeAt(0));"}); |
|
75 ASSERT_TRUE(ctx.getGlobal<bool>("result")); |
|
76 |
|
77 ctx.peval(js::Script{"result = Irccd.Unicode.isUpper(String('é').charCodeAt(0));"}); |
|
78 ASSERT_FALSE(ctx.getGlobal<bool>("result")); |
|
79 } catch (const std::exception &ex) { |
|
80 FAIL() << ex.what(); |
|
81 } |
|
82 } |
|
83 |
|
84 int main(int argc, char **argv) |
|
85 { |
|
86 testing::InitGoogleTest(&argc, argv); |
|
87 |
|
88 return RUN_ALL_TESTS(); |
|
89 } |