summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2022-01-29 10:24:21 +0100
committerSébastien Helleu <flashcode@flashtux.org>2022-01-29 10:24:21 +0100
commit083662cb34bbadd8dfa887cc02aa2f7d21ff8f88 (patch)
tree2e3678a3582a59213df87a3cac1f19db8b50d4d7
parentbf9cf3875fbd70f06b2d166a7b842e45f17f9817 (diff)
downloadweechat-083662cb34bbadd8dfa887cc02aa2f7d21ff8f88.zip
tests: add tests on GUI chat functions
Functions tested: - gui_chat_utf_char_valid - gui_chat_char_size_screen - gui_chat_strlen - gui_chat_strlen_screen - gui_chat_string_add_offset - gui_chat_string_add_offset_screen - gui_chat_string_real_pos - gui_chat_string_pos - gui_chat_get_word_info - gui_chat_printf_date_tags_internal - gui_chat_printf_date_tags - gui_chat_printf_y
-rw-r--r--ChangeLog.adoc1
-rw-r--r--doc/en/weechat_dev.en.adoc1
-rw-r--r--doc/fr/weechat_dev.fr.adoc1
-rw-r--r--doc/ja/weechat_dev.ja.adoc2
-rw-r--r--doc/sr/weechat_dev.sr.adoc2
-rw-r--r--tests/CMakeLists.txt1
-rw-r--r--tests/Makefile.am1
-rw-r--r--tests/tests.cpp1
-rw-r--r--tests/unit/gui/test-gui-chat.cpp624
9 files changed, 634 insertions, 0 deletions
diff --git a/ChangeLog.adoc b/ChangeLog.adoc
index a0fcea6de..941f960d0 100644
--- a/ChangeLog.adoc
+++ b/ChangeLog.adoc
@@ -42,6 +42,7 @@ Bug fixes::
Tests::
+ * core: add tests on GUI chat functions
* core: add build of Debian packages in CI
[[v3.4]]
diff --git a/doc/en/weechat_dev.en.adoc b/doc/en/weechat_dev.en.adoc
index afe69cd95..ca1b9c491 100644
--- a/doc/en/weechat_dev.en.adoc
+++ b/doc/en/weechat_dev.en.adoc
@@ -420,6 +420,7 @@ WeeChat "core" is located in following directories:
|          test-core-utf8.cpp | Tests: UTF-8.
|          test-core-util.cpp | Tests: utility functions.
|       gui/ | Root of unit tests for interfaces.
+|          test-gui-chat.cpp | Tests: chat functions.
|          test-gui-color.cpp | Tests: colors.
|          test-gui-line.cpp | Tests: lines.
|          test-gui-nick.cpp | Tests: nicks.
diff --git a/doc/fr/weechat_dev.fr.adoc b/doc/fr/weechat_dev.fr.adoc
index 6438dfb9d..70a04c796 100644
--- a/doc/fr/weechat_dev.fr.adoc
+++ b/doc/fr/weechat_dev.fr.adoc
@@ -422,6 +422,7 @@ Le cœur de WeeChat est situé dans les répertoires suivants :
|          test-core-utf8.cpp | Tests : UTF-8.
|          test-core-util.cpp | Tests : fonctions utiles.
|       gui/ | Racine des tests unitaires pour les interfaces.
+|          test-gui-chat.cpp | Tests : fonctions de discussion.
|          test-gui-color.cpp | Tests : couleurs.
|          test-gui-line.cpp | Tests : lignes.
|          test-gui-nick.cpp | Tests : pseudos.
diff --git a/doc/ja/weechat_dev.ja.adoc b/doc/ja/weechat_dev.ja.adoc
index 88bffe35c..75bf2fc2b 100644
--- a/doc/ja/weechat_dev.ja.adoc
+++ b/doc/ja/weechat_dev.ja.adoc
@@ -446,6 +446,8 @@ WeeChat "core" は以下のディレクトリに配置されています:
|          test-core-util.cpp | テスト: ユーティリティ関数
|       gui/ | インターフェースの単体テストを収める最上位ディレクトリ
// TRANSLATION MISSING
+|          test-gui-chat.cpp | Tests: chat functions.
+// TRANSLATION MISSING
|          test-gui-color.cpp | Tests: colors.
|          test-gui-line.cpp | テスト: 行
// TRANSLATION MISSING
diff --git a/doc/sr/weechat_dev.sr.adoc b/doc/sr/weechat_dev.sr.adoc
index 516bd6bd2..05631fa8d 100644
--- a/doc/sr/weechat_dev.sr.adoc
+++ b/doc/sr/weechat_dev.sr.adoc
@@ -420,6 +420,8 @@ WeeChat „језгро” се налази у следећим директо
|          test-core-utf8.cpp | Тестови: UTF-8.
|          test-core-util.cpp | Тестови: помоћне функције.
|       gui/ | Корен unit тестова интерфејса.
+// TRANSLATION MISSING
+|          test-gui-chat.cpp | Tests: chat functions.
|          test-gui-color.cpp | Тестови: боје.
|          test-gui-line.cpp | Тестови: линије.
|          test-gui-nick.cpp | Тестови: надимци.
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
index 029dc0f1d..dc0e7bc57 100644
--- a/tests/CMakeLists.txt
+++ b/tests/CMakeLists.txt
@@ -42,6 +42,7 @@ set(LIB_WEECHAT_UNIT_TESTS_CORE_SRC
unit/core/test-core-url.cpp
unit/core/test-core-utf8.cpp
unit/core/test-core-util.cpp
+ unit/gui/test-gui-chat.cpp
unit/gui/test-gui-color.cpp
unit/gui/test-gui-line.cpp
unit/gui/test-gui-nick.cpp
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 6e31955c8..0519fa31a 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -39,6 +39,7 @@ lib_weechat_unit_tests_core_a_SOURCES = unit/core/test-core-arraylist.cpp \
unit/core/test-core-url.cpp \
unit/core/test-core-utf8.cpp \
unit/core/test-core-util.cpp \
+ unit/gui/test-gui-chat.cpp \
unit/gui/test-gui-color.cpp \
unit/gui/test-gui-line.cpp \
unit/gui/test-gui-nick.cpp \
diff --git a/tests/tests.cpp b/tests/tests.cpp
index 774bd973a..87371973f 100644
--- a/tests/tests.cpp
+++ b/tests/tests.cpp
@@ -79,6 +79,7 @@ IMPORT_TEST_GROUP(CoreUrl);
IMPORT_TEST_GROUP(CoreUtf8);
IMPORT_TEST_GROUP(CoreUtil);
/* GUI */
+IMPORT_TEST_GROUP(GuiChat);
IMPORT_TEST_GROUP(GuiColor);
IMPORT_TEST_GROUP(GuiLine);
IMPORT_TEST_GROUP(GuiNick);
diff --git a/tests/unit/gui/test-gui-chat.cpp b/tests/unit/gui/test-gui-chat.cpp
new file mode 100644
index 000000000..22c440726
--- /dev/null
+++ b/tests/unit/gui/test-gui-chat.cpp
@@ -0,0 +1,624 @@
+/*
+ * test-gui-chat.cpp - test chat functions
+ *
+ * Copyright (C) 2022 Sébastien Helleu <flashcode@flashtux.org>
+ *
+ * This file is part of WeeChat, the extensible chat client.
+ *
+ * WeeChat is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * WeeChat is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with WeeChat. If not, see <https://www.gnu.org/licenses/>.
+ */
+
+#include "CppUTest/TestHarness.h"
+
+extern "C"
+{
+#include <string.h>
+#include "src/gui/gui-buffer.h"
+#include "src/gui/gui-chat.h"
+#include "src/gui/gui-line.h"
+#include "src/gui/gui-window.h"
+
+extern int gui_chat_char_size_screen (const char *utf_char);
+}
+
+#define WEE_GET_WORD_INFO(__result_word_start_offset, \
+ __result_word_end_offset, \
+ __result_word_length_with_spaces, \
+ __result_word_length, __string) \
+ word_start_offset = -2; \
+ word_end_offset = -2; \
+ word_length_with_spaces = -2; \
+ word_length = -2; \
+ gui_chat_get_word_info (gui_windows, __string, \
+ &word_start_offset, &word_end_offset, \
+ &word_length_with_spaces, &word_length); \
+ LONGS_EQUAL(__result_word_start_offset, word_start_offset); \
+ LONGS_EQUAL(__result_word_end_offset, word_end_offset); \
+ LONGS_EQUAL(__result_word_length_with_spaces, \
+ word_length_with_spaces); \
+ LONGS_EQUAL(__result_word_length, word_length);
+
+TEST_GROUP(GuiChat)
+{
+};
+
+/*
+ * Tests functions:
+ * gui_chat_init
+ */
+
+TEST(GuiChat, Init)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_prefix_build
+ */
+
+TEST(GuiChat, PrefixBuild)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_utf_char_valid
+ */
+
+TEST(GuiChat, UtfCharValid)
+{
+ LONGS_EQUAL(0, gui_chat_utf_char_valid (NULL));
+ LONGS_EQUAL(0, gui_chat_utf_char_valid (""));
+
+ LONGS_EQUAL(0, gui_chat_utf_char_valid ("\x01"));
+ LONGS_EQUAL(0, gui_chat_utf_char_valid ("\x1F"));
+
+ LONGS_EQUAL(0, gui_chat_utf_char_valid ("\x92"));
+ LONGS_EQUAL(0, gui_chat_utf_char_valid ("\x7F"));
+
+ LONGS_EQUAL(1, gui_chat_utf_char_valid ("\x93"));
+ LONGS_EQUAL(1, gui_chat_utf_char_valid ("\x80"));
+
+ LONGS_EQUAL(1, gui_chat_utf_char_valid ("abc"));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_char_size_screen
+ */
+
+TEST(GuiChat, CharSizeScreen)
+{
+ LONGS_EQUAL(0, gui_chat_char_size_screen (NULL));
+
+ LONGS_EQUAL(1, gui_chat_char_size_screen ("\x01"));
+
+ LONGS_EQUAL(1, gui_chat_char_size_screen ("no\xc3\xabl"));
+ LONGS_EQUAL(2, gui_chat_char_size_screen ("\xe2\xbb\xa9"));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_strlen
+ */
+
+TEST(GuiChat, Strlen)
+{
+ LONGS_EQUAL(0, gui_chat_strlen (NULL));
+ LONGS_EQUAL(0, gui_chat_strlen (""));
+
+ LONGS_EQUAL(3, gui_chat_strlen ("abc"));
+ LONGS_EQUAL(4, gui_chat_strlen ("no\xc3\xabl"));
+ LONGS_EQUAL(1, gui_chat_strlen ("\xe2\xbb\xa9"));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_strlen_screen
+ */
+
+TEST(GuiChat, StrlenScreen)
+{
+ LONGS_EQUAL(0, gui_chat_strlen_screen (NULL));
+ LONGS_EQUAL(0, gui_chat_strlen_screen (""));
+
+ LONGS_EQUAL(3, gui_chat_strlen_screen ("abc"));
+ LONGS_EQUAL(4, gui_chat_strlen_screen ("no\xc3\xabl"));
+ LONGS_EQUAL(2, gui_chat_strlen_screen ("\xe2\xbb\xa9"));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_string_add_offset
+ */
+
+TEST(GuiChat, StringAddOffset)
+{
+ const char *str_empty = "";
+ const char *str_noel = "no\xc3\xabl";
+ const char *str_other = "A\xe2\xbb\xa9Z";
+
+ POINTERS_EQUAL(NULL, gui_chat_string_add_offset (NULL, -1));
+ POINTERS_EQUAL(NULL, gui_chat_string_add_offset (NULL, 0));
+ POINTERS_EQUAL(NULL, gui_chat_string_add_offset (NULL, 1));
+
+ POINTERS_EQUAL(str_empty, gui_chat_string_add_offset (str_empty, -1));
+ POINTERS_EQUAL(str_empty, gui_chat_string_add_offset (str_empty, 0));
+ POINTERS_EQUAL(str_empty, gui_chat_string_add_offset (str_empty, 1));
+
+ POINTERS_EQUAL(str_noel, gui_chat_string_add_offset (str_noel, -1));
+ POINTERS_EQUAL(str_noel, gui_chat_string_add_offset (str_noel, 0));
+ POINTERS_EQUAL(str_noel + 1, gui_chat_string_add_offset (str_noel, 1));
+ POINTERS_EQUAL(str_noel + 2, gui_chat_string_add_offset (str_noel, 2));
+ POINTERS_EQUAL(str_noel + 4, gui_chat_string_add_offset (str_noel, 3));
+ POINTERS_EQUAL(str_noel + 5, gui_chat_string_add_offset (str_noel, 4));
+ POINTERS_EQUAL(str_noel + 5, gui_chat_string_add_offset (str_noel, 5));
+
+ POINTERS_EQUAL(str_other, gui_chat_string_add_offset (str_other, -1));
+ POINTERS_EQUAL(str_other, gui_chat_string_add_offset (str_other, 0));
+ POINTERS_EQUAL(str_other + 1, gui_chat_string_add_offset (str_other, 1));
+ POINTERS_EQUAL(str_other + 4, gui_chat_string_add_offset (str_other, 2));
+ POINTERS_EQUAL(str_other + 5, gui_chat_string_add_offset (str_other, 3));
+ POINTERS_EQUAL(str_other + 5, gui_chat_string_add_offset (str_other, 4));
+ POINTERS_EQUAL(str_other + 5, gui_chat_string_add_offset (str_other, 5));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_string_add_offset_screen
+ */
+
+TEST(GuiChat, StringAddOffsetScreen)
+{
+ const char *str_empty = "";
+ const char *str_noel = "no\xc3\xabl";
+ const char *str_other = "A\xe2\xbb\xa9Z";
+
+ POINTERS_EQUAL(NULL, gui_chat_string_add_offset_screen (NULL, -1));
+ POINTERS_EQUAL(NULL, gui_chat_string_add_offset_screen (NULL, 0));
+ POINTERS_EQUAL(NULL, gui_chat_string_add_offset_screen (NULL, 1));
+
+ POINTERS_EQUAL(str_empty, gui_chat_string_add_offset_screen (str_empty, -1));
+ POINTERS_EQUAL(str_empty, gui_chat_string_add_offset_screen (str_empty, 0));
+ POINTERS_EQUAL(str_empty, gui_chat_string_add_offset_screen (str_empty, 1));
+
+ POINTERS_EQUAL(str_noel, gui_chat_string_add_offset_screen (str_noel, -1));
+ POINTERS_EQUAL(str_noel, gui_chat_string_add_offset_screen (str_noel, 0));
+ POINTERS_EQUAL(str_noel + 1, gui_chat_string_add_offset_screen (str_noel, 1));
+ POINTERS_EQUAL(str_noel + 2, gui_chat_string_add_offset_screen (str_noel, 2));
+ POINTERS_EQUAL(str_noel + 4, gui_chat_string_add_offset_screen (str_noel, 3));
+ POINTERS_EQUAL(str_noel + 5, gui_chat_string_add_offset_screen (str_noel, 4));
+ POINTERS_EQUAL(str_noel + 5, gui_chat_string_add_offset_screen (str_noel, 5));
+
+ POINTERS_EQUAL(str_other, gui_chat_string_add_offset_screen (str_other, -1));
+ POINTERS_EQUAL(str_other, gui_chat_string_add_offset_screen (str_other, 0));
+ POINTERS_EQUAL(str_other + 1, gui_chat_string_add_offset_screen (str_other, 1));
+ POINTERS_EQUAL(str_other + 1, gui_chat_string_add_offset_screen (str_other, 2));
+ POINTERS_EQUAL(str_other + 4, gui_chat_string_add_offset_screen (str_other, 3));
+ POINTERS_EQUAL(str_other + 5, gui_chat_string_add_offset_screen (str_other, 4));
+ POINTERS_EQUAL(str_other + 5, gui_chat_string_add_offset_screen (str_other, 5));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_string_real_pos
+ */
+
+TEST(GuiChat, StringRealPos)
+{
+ LONGS_EQUAL(0, gui_chat_string_real_pos (NULL, -1, 0));
+ LONGS_EQUAL(0, gui_chat_string_real_pos (NULL, 0, 0));
+ LONGS_EQUAL(0, gui_chat_string_real_pos (NULL, 1, 0));
+
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("", -1, 0));
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("", 0, 0));
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("", 1, 0));
+
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("abc", 0, 0));
+ LONGS_EQUAL(1, gui_chat_string_real_pos ("abc", 1, 0));
+ LONGS_EQUAL(2, gui_chat_string_real_pos ("abc", 2, 0));
+
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("no\xc3\xabl", 0, 0));
+ LONGS_EQUAL(1, gui_chat_string_real_pos ("no\xc3\xabl", 1, 0));
+ LONGS_EQUAL(2, gui_chat_string_real_pos ("no\xc3\xabl", 2, 0));
+
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("\xe2\xbb\xa9", 0, 0));
+ LONGS_EQUAL(3, gui_chat_string_real_pos ("\xe2\xbb\xa9", 1, 0));
+ LONGS_EQUAL(3, gui_chat_string_real_pos ("\xe2\xbb\xa9", 2, 0));
+
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("\xe2\xbb\xa9", 0, 1));
+ LONGS_EQUAL(0, gui_chat_string_real_pos ("\xe2\xbb\xa9", 1, 1));
+ LONGS_EQUAL(3, gui_chat_string_real_pos ("\xe2\xbb\xa9", 2, 1));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_string_pos
+ */
+
+TEST(GuiChat, StringPos)
+{
+ LONGS_EQUAL(0, gui_chat_string_pos (NULL, -1));
+ LONGS_EQUAL(0, gui_chat_string_pos (NULL, 0));
+ LONGS_EQUAL(0, gui_chat_string_pos (NULL, 1));
+
+ LONGS_EQUAL(0, gui_chat_string_pos ("", -1));
+ LONGS_EQUAL(0, gui_chat_string_pos ("", 0));
+ LONGS_EQUAL(0, gui_chat_string_pos ("", 1));
+
+ LONGS_EQUAL(0, gui_chat_string_pos ("abc", 0));
+ LONGS_EQUAL(1, gui_chat_string_pos ("abc", 1));
+ LONGS_EQUAL(2, gui_chat_string_pos ("abc", 2));
+
+ LONGS_EQUAL(0, gui_chat_string_pos ("no\xc3\xabl", 0));
+ LONGS_EQUAL(1, gui_chat_string_pos ("no\xc3\xabl", 1));
+ LONGS_EQUAL(2, gui_chat_string_pos ("no\xc3\xabl", 2));
+
+ LONGS_EQUAL(0, gui_chat_string_pos ("\xe2\xbb\xa9", 0));
+ LONGS_EQUAL(1, gui_chat_string_pos ("\xe2\xbb\xa9", 1));
+ LONGS_EQUAL(1, gui_chat_string_pos ("\xe2\xbb\xa9", 2));
+}
+
+/*
+ * Tests functions:
+ * gui_chat_get_word_info
+ */
+
+TEST(GuiChat, GetWordInfo)
+{
+ int word_start_offset, word_end_offset, word_length_with_spaces;
+ int word_length;
+
+ WEE_GET_WORD_INFO (0, 0, 0, -1, NULL);
+ WEE_GET_WORD_INFO (0, 0, 0, -1, "");
+ WEE_GET_WORD_INFO (0, 0, 1, 1, "a");
+ WEE_GET_WORD_INFO (0, 2, 3, 3, "abc");
+ WEE_GET_WORD_INFO (2, 4, 5, 3, " abc");
+ WEE_GET_WORD_INFO (2, 4, 5, 3, " abc ");
+ WEE_GET_WORD_INFO (0, 4, 5, 5, "first second");
+ WEE_GET_WORD_INFO (1, 5, 6, 5, " first second");
+}
+
+/*
+ * Tests functions:
+ * gui_chat_get_time_string
+ */
+
+TEST(GuiChat, GetTimeString)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_get_time_length
+ */
+
+TEST(GuiChat, GetTimeLength)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_change_time_format
+ */
+
+TEST(GuiChat, ChangeTimeFormat)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_buffer_valid
+ */
+
+TEST(GuiChat, BufferValid)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_add_line_waiting_buffer
+ */
+
+TEST(GuiChat, AddLineWaitingBuffer)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_print_lines_waiting_buffer
+ */
+
+TEST(GuiChat, PrintLinesWaitingBuffer)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_printf_date_tags_internal
+ * gui_chat_printf_date_tags
+ */
+
+TEST(GuiChat, PrintDateTags)
+{
+ struct t_gui_line *ptr_last_line;
+ struct t_gui_line_data *ptr_data;
+
+ /* invalid buffer */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf ((struct t_gui_buffer *)0x1, "test");
+ POINTERS_EQUAL(ptr_last_line, gui_buffers->own_lines->last_line);
+
+ /* NULL message */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf (gui_buffers, NULL);
+ POINTERS_EQUAL(ptr_last_line, gui_buffers->own_lines->last_line);
+
+ /* empty message */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf (gui_buffers, "");
+ CHECK(ptr_last_line != gui_buffers->own_lines->last_line);
+ ptr_data = gui_buffers->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(gui_buffers, ptr_data->buffer);
+ LONGS_EQUAL(-1, ptr_data->y);
+ CHECK(ptr_data->date > 0);
+ CHECK(ptr_data->date == ptr_data->date_printed);
+ CHECK(ptr_data->str_time && ptr_data->str_time[0]);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(0, ptr_data->refresh_needed);
+ STRCMP_EQUAL("", ptr_data->prefix);
+ LONGS_EQUAL(0, ptr_data->prefix_length);
+ STRCMP_EQUAL("", ptr_data->message);
+
+ /* message (no prefix) */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf (gui_buffers, "this is a test");
+ CHECK(ptr_last_line != gui_buffers->own_lines->last_line);
+ ptr_data = gui_buffers->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(gui_buffers, ptr_data->buffer);
+ LONGS_EQUAL(-1, ptr_data->y);
+ CHECK(ptr_data->date > 0);
+ CHECK(ptr_data->date == ptr_data->date_printed);
+ CHECK(ptr_data->str_time && ptr_data->str_time[0]);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(0, ptr_data->refresh_needed);
+ STRCMP_EQUAL("", ptr_data->prefix);
+ LONGS_EQUAL(0, ptr_data->prefix_length);
+ STRCMP_EQUAL("this is a test", ptr_data->message);
+
+ /* message with prefix */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf (gui_buffers, "nick\tthis is a test");
+ CHECK(ptr_last_line != gui_buffers->own_lines->last_line);
+ ptr_data = gui_buffers->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(gui_buffers, ptr_data->buffer);
+ LONGS_EQUAL(-1, ptr_data->y);
+ CHECK(ptr_data->date > 0);
+ CHECK(ptr_data->date == ptr_data->date_printed);
+ CHECK(ptr_data->str_time && ptr_data->str_time[0]);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(0, ptr_data->refresh_needed);
+ STRCMP_EQUAL("nick", ptr_data->prefix);
+ LONGS_EQUAL(4, ptr_data->prefix_length);
+ STRCMP_EQUAL("this is a test", ptr_data->message);
+
+ /* message with prefix */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf (gui_buffers, "nick\tthis is a test");
+ CHECK(ptr_last_line != gui_buffers->own_lines->last_line);
+ ptr_data = gui_buffers->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(gui_buffers, ptr_data->buffer);
+ LONGS_EQUAL(-1, ptr_data->y);
+ CHECK(ptr_data->date > 0);
+ CHECK(ptr_data->date == ptr_data->date_printed);
+ CHECK(ptr_data->str_time && ptr_data->str_time[0]);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(0, ptr_data->refresh_needed);
+ STRCMP_EQUAL("nick", ptr_data->prefix);
+ LONGS_EQUAL(4, ptr_data->prefix_length);
+ STRCMP_EQUAL("this is a test", ptr_data->message);
+
+ /* message with ignored prefix (space + tab) */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf (gui_buffers, " \tthis is a test");
+ CHECK(ptr_last_line != gui_buffers->own_lines->last_line);
+ ptr_data = gui_buffers->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(gui_buffers, ptr_data->buffer);
+ LONGS_EQUAL(-1, ptr_data->y);
+ CHECK(ptr_data->date > 0);
+ CHECK(ptr_data->date == ptr_data->date_printed);
+ CHECK(ptr_data->str_time && ptr_data->str_time[0]);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(0, ptr_data->refresh_needed);
+ STRCMP_EQUAL("", ptr_data->prefix);
+ LONGS_EQUAL(0, ptr_data->prefix_length);
+ STRCMP_EQUAL("this is a test", ptr_data->message);
+
+ /* message with no time displayed (two tabs) */
+ ptr_last_line = gui_buffers->own_lines->last_line;
+ gui_chat_printf (gui_buffers, "\t\tthis is a test");
+ CHECK(ptr_last_line != gui_buffers->own_lines->last_line);
+ ptr_data = gui_buffers->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(gui_buffers, ptr_data->buffer);
+ LONGS_EQUAL(-1, ptr_data->y);
+ LONGS_EQUAL(0, ptr_data->date);
+ CHECK(ptr_data->date_printed > 0);
+ POINTERS_EQUAL(NULL, ptr_data->str_time);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(0, ptr_data->refresh_needed);
+ POINTERS_EQUAL(NULL, ptr_data->prefix);
+ LONGS_EQUAL(0, ptr_data->prefix_length);
+ STRCMP_EQUAL("this is a test", ptr_data->message);
+}
+
+/*
+ * Tests functions:
+ * gui_chat_printf_y
+ */
+
+TEST(GuiChat, PrintY)
+{
+ struct t_gui_buffer *buffer;
+ struct t_gui_line_data *ptr_data;
+
+ buffer = gui_buffer_new (NULL, "test", NULL, NULL, NULL, NULL, NULL, NULL);
+ CHECK(buffer);
+ gui_buffer_set (buffer, "type", "free");
+
+ /* invalid buffer pointer */
+ gui_chat_printf_y ((struct t_gui_buffer *)0x1, 0, "test");
+ POINTERS_EQUAL(NULL, buffer->own_lines->last_line);
+
+ /* invalid buffer: not with free content */
+ gui_chat_printf_y (gui_buffers, 0, "test");
+ POINTERS_EQUAL(NULL, buffer->own_lines->last_line);
+
+ /* NULL message */
+ gui_chat_printf_y (buffer, 0, NULL);
+ POINTERS_EQUAL(NULL, buffer->own_lines->last_line);
+
+ /* empty message */
+ gui_chat_printf_y (buffer, 0, "");
+ POINTERS_EQUAL(NULL, buffer->own_lines->last_line);
+
+ /* message on first line */
+ gui_chat_printf_y (buffer, 0, "this is a test on line 1");
+ CHECK(buffer->own_lines->last_line);
+ ptr_data = buffer->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(buffer, ptr_data->buffer);
+ LONGS_EQUAL(0, ptr_data->y);
+ LONGS_EQUAL(0, ptr_data->date);
+ LONGS_EQUAL(0, ptr_data->date_printed);
+ POINTERS_EQUAL(NULL, ptr_data->str_time);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(1, ptr_data->refresh_needed);
+ POINTERS_EQUAL(NULL, ptr_data->prefix);
+ LONGS_EQUAL(0, ptr_data->prefix_length);
+ STRCMP_EQUAL("this is a test on line 1", ptr_data->message);
+
+ /* message on third line */
+ gui_chat_printf_y (buffer, 2, "this is a test on line 3");
+ CHECK(buffer->own_lines->last_line);
+ ptr_data = buffer->own_lines->last_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(buffer, ptr_data->buffer);
+ LONGS_EQUAL(2, ptr_data->y);
+ LONGS_EQUAL(0, ptr_data->date);
+ LONGS_EQUAL(0, ptr_data->date_printed);
+ POINTERS_EQUAL(NULL, ptr_data->str_time);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(1, ptr_data->refresh_needed);
+ POINTERS_EQUAL(NULL, ptr_data->prefix);
+ LONGS_EQUAL(0, ptr_data->prefix_length);
+ STRCMP_EQUAL("this is a test on line 3", ptr_data->message);
+
+ /* delete first line */
+ gui_chat_printf_y (buffer, 0, "");
+ ptr_data = buffer->own_lines->first_line->data;
+ CHECK(ptr_data);
+ POINTERS_EQUAL(buffer, ptr_data->buffer);
+ LONGS_EQUAL(0, ptr_data->y);
+ LONGS_EQUAL(0, ptr_data->date);
+ LONGS_EQUAL(0, ptr_data->date_printed);
+ POINTERS_EQUAL(NULL, ptr_data->str_time);
+ LONGS_EQUAL(0, ptr_data->tags_count);
+ POINTERS_EQUAL(NULL, ptr_data->tags_array);
+ LONGS_EQUAL(1, ptr_data->displayed);
+ LONGS_EQUAL(0, ptr_data->notify_level);
+ LONGS_EQUAL(0, ptr_data->highlight);
+ LONGS_EQUAL(1, ptr_data->refresh_needed);
+ POINTERS_EQUAL(NULL, ptr_data->prefix);
+ LONGS_EQUAL(0, ptr_data->prefix_length);
+ STRCMP_EQUAL("", ptr_data->message);
+
+ /* delete third line */
+ gui_chat_printf_y (buffer, 2, "");
+ CHECK(buffer->own_lines->first_line);
+ CHECK(buffer->own_lines->first_line->next_line);
+ POINTERS_EQUAL(NULL, buffer->own_lines->first_line->next_line->next_line);
+
+ /* delete secondline */
+ gui_chat_printf_y (buffer, 1, "");
+ CHECK(buffer->own_lines->first_line);
+ POINTERS_EQUAL(NULL, buffer->own_lines->first_line->next_line);
+
+ gui_buffer_close (buffer);
+}
+
+/*
+ * Tests functions:
+ * gui_chat_hsignal_quote_line_cb
+ */
+
+TEST(GuiChat, HsignalQuoteLineCb)
+{
+ /* TODO: write tests */
+}
+
+/*
+ * Tests functions:
+ * gui_chat_end
+ */
+
+TEST(GuiChat, ChatEnd)
+{
+ /* TODO: write tests */
+}