diff options
| author | Matthew Fennell <matthew@fennell.dev> | 2025-12-27 12:40:20 +0000 |
|---|---|---|
| committer | Matthew Fennell <matthew@fennell.dev> | 2025-12-27 12:40:20 +0000 |
| commit | 5d8e439bc597159e3c9f0a8b65c0ae869dead3a8 (patch) | |
| tree | ed28aefed8add0da1c55c08fdf80b23c4346e0dc /tests/test-model-sort.c | |
Import Upstream version 43.0upstream/latest
Diffstat (limited to 'tests/test-model-sort.c')
| -rw-r--r-- | tests/test-model-sort.c | 143 |
1 files changed, 143 insertions, 0 deletions
diff --git a/tests/test-model-sort.c b/tests/test-model-sort.c new file mode 100644 index 0000000..b54b29f --- /dev/null +++ b/tests/test-model-sort.c @@ -0,0 +1,143 @@ +/* test-model-sort.c + * + * Copyright 2018 Georges Basile Stavracas Neto <georges.stavracas@gmail.com> + * + * This program 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. + * + * This program 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 this program. If not, see <http://www.gnu.org/licenses/>. + * + * SPDX-License-Identifier: GPL-3.0-or-later + */ + +#include "models/gtd-list-model-sort.h" + +#include <math.h> +#include <string.h> + +#define TEST_TYPE_ITEM (test_item_get_type()) + +struct _TestItem +{ + GObject p; + guint n; +}; + +G_DECLARE_FINAL_TYPE (TestItem, test_item, TEST, ITEM, GObject) +G_DEFINE_TYPE (TestItem, test_item, G_TYPE_OBJECT) + +static void +test_item_class_init (TestItemClass *klass) +{ +} + +static void +test_item_init (TestItem *self) +{ +} + +static TestItem * +test_item_new (guint n) +{ + TestItem *item; + + item = g_object_new (TEST_TYPE_ITEM, NULL); + item->n = n; + + return item; +} + +static gint +sort_func1 (GObject *a, + GObject *b, + gpointer user_data) +{ + return TEST_ITEM (a)->n - TEST_ITEM (b)->n; +} + +static gint +sort_func2 (GObject *a, + GObject *b, + gpointer user_data) +{ + return (TEST_ITEM (a)->n & 1) - (TEST_ITEM (b)->n & 1); +} + +static void +test_basic (void) +{ + GtdListModelSort *sort; + GListStore *model; + guint i; + + model = g_list_store_new (TEST_TYPE_ITEM); + g_assert (model); + + sort = gtd_list_model_sort_new (G_LIST_MODEL (model)); + g_assert (sort); + + /* Test requesting past boundary */ + g_assert_null (g_list_model_get_item (G_LIST_MODEL (sort), 0)); + g_assert_null (g_list_model_get_item (G_LIST_MODEL (sort), 1)); + + for (i = 0; i < 1000; i++) + { + g_autoptr (TestItem) val = test_item_new (1000 - i); + g_list_store_append (model, val); + } + + /* Test requesting past boundary */ + g_assert_null (g_list_model_get_item (G_LIST_MODEL (sort), 1000)); + + /* Ascendent sorting */ + gtd_list_model_sort_set_sort_func (sort, sort_func1, NULL, NULL); + + g_assert_cmpint (1000, ==, g_list_model_get_n_items (G_LIST_MODEL (model))); + g_assert_cmpint (1000, ==, g_list_model_get_n_items (G_LIST_MODEL (sort))); + + for (i = 1; i < 1000; i++) + { + g_autoptr (TestItem) current = g_list_model_get_item (G_LIST_MODEL (sort), i); + g_autoptr (TestItem) previous = g_list_model_get_item (G_LIST_MODEL (sort), i - 1); + + g_assert_cmpint (previous->n, <, current->n); + } + + /* Odd/Even sorting */ + gtd_list_model_sort_set_sort_func (sort, sort_func2, NULL, NULL); + + g_assert_cmpint (1000, ==, g_list_model_get_n_items (G_LIST_MODEL (model))); + g_assert_cmpint (1000, ==, g_list_model_get_n_items (G_LIST_MODEL (sort))); + + for (i = 0; i < 1000; i++) + { + g_autoptr (TestItem) current = g_list_model_get_item (G_LIST_MODEL (sort), i); + + if (i < 500) + g_assert_cmpint (current->n % 2, ==, 0); + else + g_assert_cmpint (current->n % 2, ==, 1); + } + + g_clear_object (&model); + g_clear_object (&sort); +} + +gint +main (gint argc, + gchar *argv[]) +{ + g_test_init (&argc, &argv, NULL); + + g_test_add_func ("/models/model-sort/basic", test_basic); + + return g_test_run (); +} |
