blob: 1353aefa402013f03731ab1129f1f22be998bc61 [file]
/*
* Copyright © 2018 Ebrahim Byagowi
*
* This is part of HarfBuzz, a text shaping library.
*
* Permission is hereby granted, without written agreement and without
* license or royalty fees, to use, copy, modify, and distribute this
* software and its documentation for any purpose, provided that the
* above copyright notice and the following two paragraphs appear in
* all copies of this software.
*
* IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
* ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
* IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
* THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
*/
#include "hb-test.h"
/* Unit tests for hb-map.h */
static void
assert_map_has (const hb_map_t *m, hb_codepoint_t key, hb_codepoint_t value)
{
g_assert_true (hb_map_has (m, key));
g_assert_cmpint (hb_map_get (m, key), ==, value);
}
static void
test_map_basic (void)
{
hb_map_t *empty = hb_map_get_empty ();
hb_map_t *m;
g_assert_true (hb_map_is_empty (empty));
g_assert_true (!hb_map_allocation_successful (empty));
hb_map_destroy (empty);
m = hb_map_create ();
g_assert_true (hb_map_allocation_successful (m));
g_assert_true (hb_map_is_empty (m));
hb_map_set (m, 213, 223);
hb_map_set (m, 643, 675);
g_assert_cmpint (hb_map_get_population (m), ==, 2);
g_assert_cmpint (hb_map_get (m, 213), ==, 223);
g_assert_true (!hb_map_has (m, 123));
g_assert_true (hb_map_has (m, 213));
hb_map_del (m, 213);
g_assert_true (!hb_map_has (m, 213));
g_assert_cmpint (hb_map_get (m, 643), ==, 675);
hb_map_set (m, 237, 673);
g_assert_true (hb_map_has (m, 237));
hb_map_clear (m);
g_assert_true (!hb_map_has (m, 237));
g_assert_true (!hb_map_has (m, 643));
g_assert_cmpint (hb_map_get_population (m), ==, 0);
hb_map_destroy (m);
}
static void
test_map_copy_equal_hash_update (void)
{
hb_map_t *m = hb_map_create ();
hb_map_t *copy;
hb_map_t *updated;
hb_map_set (m, 11, 101);
hb_map_set (m, 22, 202);
copy = hb_map_copy (m);
g_assert_true (hb_map_allocation_successful (copy));
g_assert_true (hb_map_is_equal (m, copy));
g_assert_true (hb_map_is_equal (copy, m));
g_assert_cmpint (hb_map_hash (m), ==, hb_map_hash (copy));
hb_map_set (m, 33, 303);
g_assert_true (!hb_map_is_equal (m, copy));
g_assert_true (!hb_map_has (copy, 33));
assert_map_has (copy, 11, 101);
assert_map_has (copy, 22, 202);
updated = hb_map_create ();
hb_map_set (updated, 22, 222);
hb_map_set (updated, 44, 404);
hb_map_update (copy, updated);
g_assert_cmpint (hb_map_get_population (copy), ==, 3);
assert_map_has (copy, 11, 101);
assert_map_has (copy, 22, 222);
assert_map_has (copy, 44, 404);
assert_map_has (m, 22, 202);
hb_map_destroy (updated);
hb_map_destroy (copy);
hb_map_destroy (m);
}
static void
test_map_next_keys_values (void)
{
hb_map_t *m = hb_map_create ();
hb_set_t *iter_keys = hb_set_create ();
hb_set_t *iter_values = hb_set_create ();
hb_set_t *keys = hb_set_create ();
hb_set_t *values = hb_set_create ();
hb_codepoint_t key;
hb_codepoint_t value;
unsigned int count = 0;
int idx = -1;
hb_map_set (m, 7, 70);
hb_map_set (m, 19, 190);
hb_map_set (m, 23, 190);
while (hb_map_next (m, &idx, &key, &value))
{
g_assert_true (!hb_set_has (iter_keys, key));
assert_map_has (m, key, value);
hb_set_add (iter_keys, key);
hb_set_add (iter_values, value);
count++;
}
g_assert_cmpint (count, ==, hb_map_get_population (m));
g_assert_cmpint (hb_set_get_population (iter_keys), ==, 3);
g_assert_true (hb_set_has (iter_keys, 7));
g_assert_true (hb_set_has (iter_keys, 19));
g_assert_true (hb_set_has (iter_keys, 23));
g_assert_cmpint (hb_set_get_population (iter_values), ==, 2);
g_assert_true (hb_set_has (iter_values, 70));
g_assert_true (hb_set_has (iter_values, 190));
hb_map_keys (m, keys);
hb_map_values (m, values);
g_assert_true (hb_set_is_equal (keys, iter_keys));
g_assert_true (hb_set_is_equal (values, iter_values));
hb_set_destroy (values);
hb_set_destroy (keys);
hb_set_destroy (iter_values);
hb_set_destroy (iter_keys);
hb_map_destroy (m);
}
static void
test_map_userdata (void)
{
hb_map_t *m = hb_map_create ();
hb_user_data_key_t key[2];
int *data = (int *) malloc (sizeof (int));
int *data2;
*data = 3123;
hb_map_set_user_data (m, &key[0], data, free, TRUE);
g_assert_cmpint (*((int *) hb_map_get_user_data (m, &key[0])), ==, 3123);
data2 = (int *) malloc (sizeof (int));
*data2 = 6343;
hb_map_set_user_data (m, &key[0], data2, free, FALSE);
g_assert_cmpint (*((int *) hb_map_get_user_data (m, &key[0])), ==, 3123);
hb_map_set_user_data (m, &key[0], data2, free, TRUE);
g_assert_cmpint (*((int *) hb_map_get_user_data (m, &key[0])), ==, 6343);
hb_map_destroy (m);
}
static void
test_map_refcount (void)
{
hb_map_t *m = hb_map_create ();
hb_map_t *m2;
hb_map_set (m, 213, 223);
g_assert_cmpint (hb_map_get (m, 213), ==, 223);
m2 = hb_map_reference (m);
hb_map_destroy (m);
/* We copied its reference so it is still usable after one destroy */
g_assert_true (hb_map_has (m, 213));
g_assert_true (hb_map_has (m2, 213));
hb_map_destroy (m2);
/* Now you can't access them anymore */
}
static void
test_map_get_population (void)
{
hb_map_t *m = hb_map_create ();
hb_map_set (m, 12, 21);
g_assert_cmpint (hb_map_get_population (m), ==, 1);
hb_map_set (m, 78, 87);
g_assert_cmpint (hb_map_get_population (m), ==, 2);
hb_map_set (m, 78, 87);
g_assert_cmpint (hb_map_get_population (m), ==, 2);
hb_map_set (m, 78, 13);
g_assert_cmpint (hb_map_get_population (m), ==, 2);
hb_map_set (m, 95, 56);
g_assert_cmpint (hb_map_get_population (m), ==, 3);
hb_map_del (m, 78);
g_assert_cmpint (hb_map_get_population (m), ==, 2);
hb_map_del (m, 103);
g_assert_cmpint (hb_map_get_population (m), ==, 2);
hb_map_destroy (m);
}
int
main (int argc, char **argv)
{
hb_test_init (&argc, &argv);
hb_test_add (test_map_basic);
hb_test_add (test_map_copy_equal_hash_update);
hb_test_add (test_map_next_keys_values);
hb_test_add (test_map_userdata);
hb_test_add (test_map_refcount);
hb_test_add (test_map_get_population);
return hb_test_run();
}