tests/test_hash_map.c

Wed, 17 Dec 2025 19:05:50 +0100

author
Mike Becker <universe@uap-core.de>
date
Wed, 17 Dec 2025 19:05:50 +0100
changeset 1618
ef7cab6eb131
parent 1616
bdc04a8e0dd3
permissions
-rw-r--r--

huge refactoring of collections to add support for 3-arg compare functions

785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 *
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 * Copyright 2023 Mike Becker, Olaf Wintermann All rights reserved.
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 *
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * Redistribution and use in source and binary forms, with or without
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 * modification, are permitted provided that the following conditions are met:
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 *
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * 1. Redistributions of source code must retain the above copyright
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 * notice, this list of conditions and the following disclaimer.
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 *
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * 2. Redistributions in binary form must reproduce the above copyright
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * notice, this list of conditions and the following disclaimer in the
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 * documentation and/or other materials provided with the distribution.
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 *
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 * POSSIBILITY OF SUCH DAMAGE.
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27 */
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 #include "cx/test.h"
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30 #include "util_allocator.h"
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
31 #include "cx/array_list.h"
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
32 #include "cx/list.h"
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
33
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
34 #include "cx/hash_map.h"
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
36 CX_TEST(test_hash_map_create) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
37 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
38 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
39 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
40 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41 CxMap *map = cxHashMapCreate(allocator, 1, 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
42 struct cx_hash_map_s *hmap = (struct cx_hash_map_s *) map;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
43 CX_TEST_ASSERT(hmap->bucket_count > 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
44 for(size_t i = 0 ; i < hmap->bucket_count ; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
45 CX_TEST_ASSERT(hmap->buckets[i] == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
46 }
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
47 CX_TEST_ASSERT(map->collection.elem_size == 1);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
48 CX_TEST_ASSERT(map->collection.size == 0);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
49 CX_TEST_ASSERT(map->collection.allocator == allocator);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
50 CX_TEST_ASSERT(!map->collection.store_pointer);
1618
ef7cab6eb131 huge refactoring of collections to add support for 3-arg compare functions
Mike Becker <universe@uap-core.de>
parents: 1616
diff changeset
51 CX_TEST_ASSERT(map->collection.simple_cmp == NULL);
ef7cab6eb131 huge refactoring of collections to add support for 3-arg compare functions
Mike Becker <universe@uap-core.de>
parents: 1616
diff changeset
52 CX_TEST_ASSERT(map->collection.advanced_cmp == cx_acmp_memcmp);
ef7cab6eb131 huge refactoring of collections to add support for 3-arg compare functions
Mike Becker <universe@uap-core.de>
parents: 1616
diff changeset
53 CX_TEST_ASSERT(map->collection.cmp_data == &map->collection.elem_size);
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
54 CX_TEST_ASSERT(map->collection.simple_destructor == NULL);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
55 CX_TEST_ASSERT(map->collection.advanced_destructor == NULL);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
56 CX_TEST_ASSERT(map->collection.destructor_data == NULL);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
57
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
58 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
59 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
60 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
61 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
62 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
63
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
64 CX_TEST(test_hash_map_create_store_pointers) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
65 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
66 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
67 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
68 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
69 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
70 struct cx_hash_map_s *hmap = (struct cx_hash_map_s *) map;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
71 CX_TEST_ASSERT(hmap->bucket_count > 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
72 for (size_t i = 0; i < hmap->bucket_count; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
73 CX_TEST_ASSERT(hmap->buckets[i] == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
74 }
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
75 CX_TEST_ASSERT(map->collection.size == 0);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
76 CX_TEST_ASSERT(map->collection.allocator == allocator);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
77 CX_TEST_ASSERT(map->collection.store_pointer);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
78 CX_TEST_ASSERT(map->collection.elem_size == sizeof(void *));
1618
ef7cab6eb131 huge refactoring of collections to add support for 3-arg compare functions
Mike Becker <universe@uap-core.de>
parents: 1616
diff changeset
79 CX_TEST_ASSERT(map->collection.simple_cmp == cx_cmp_ptr);
ef7cab6eb131 huge refactoring of collections to add support for 3-arg compare functions
Mike Becker <universe@uap-core.de>
parents: 1616
diff changeset
80 CX_TEST_ASSERT(map->collection.advanced_cmp == NULL);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
81
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
82 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
83 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
84 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
85 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
86 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
87
1341
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
88 CX_TEST(test_hash_map_emplace) {
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
89 CxTestingAllocator talloc;
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
90 cx_testing_allocator_init(&talloc);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
91 CxAllocator *allocator = &talloc.base;
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
92 CX_TEST_DO {
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
93 CxMap *map = cxHashMapCreate(allocator, 20, 4);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
94
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
95 char *v = cxMapEmplace(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
96 CX_TEST_ASSERT(v != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
97 strcpy(v, "val 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
98
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
99 char *tv = cxMapGet(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
100 CX_TEST_ASSERT(tv != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
101 CX_TEST_ASSERT(0 == strcmp(tv, "val 1"));
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
102
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
103 v = cxMapEmplace(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
104 CX_TEST_ASSERT(v != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
105 CX_TEST_ASSERT(0 != strcmp(v, "val 1"));
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
106
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
107 tv = cxMapGet(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
108 CX_TEST_ASSERT(tv != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
109 CX_TEST_ASSERT(0 != strcmp(tv, "val 1"));
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
110
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
111 cxMapFree(map);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
112 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
113 }
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
114 cx_testing_allocator_destroy(&talloc);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
115 }
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
116
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
117 CX_TEST(test_hash_map_emplace_pointers) {
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
118 CxTestingAllocator talloc;
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
119 cx_testing_allocator_init(&talloc);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
120 CxAllocator *allocator = &talloc.base;
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
121 CX_TEST_DO {
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
122 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 4);
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
123 cxSetAdvancedDestructor(map, cxFree, allocator);
1341
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
124
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
125 char *val1 = cxMalloc(allocator, 8);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
126 strcpy(val1, "val 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
127 char *val2 = cxMalloc(allocator, 8);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
128 strcpy(val2, "val 2");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
129
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
130 char **v1 = cxMapEmplace(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
131 CX_TEST_ASSERT(v1 != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
132 *v1 = val1;
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
133
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
134 char *tv = cxMapGet(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
135 CX_TEST_ASSERT(tv != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
136 CX_TEST_ASSERT(0 == strcmp(tv, "val 1"));
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
137
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
138 // this will call the destructor of former v1
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
139 char **v2 = cxMapEmplace(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
140 CX_TEST_ASSERT(v2 != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
141 *v2 = val2;
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
142 tv = cxMapGet(map, "key 1");
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
143 CX_TEST_ASSERT(tv != NULL);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
144 CX_TEST_ASSERT(0 == strcmp(tv, "val 2"));
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
145
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
146 cxMapFree(map);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
147 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
148 }
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
149 cx_testing_allocator_destroy(&talloc);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
150 }
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
151
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
152 CX_TEST(test_hash_map_rehash) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
153 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
154 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
155 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
156 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
157 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 7);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
158
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
159 cxMapPut(map, "key 1", (void *) "val 1");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
160 cxMapPut(map, "key 2", (void *) "val 2");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
161 cxMapPut(map, "key 3", (void *) "val 3");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
162 cxMapPut(map, "foo 4", (void *) "val 4");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
163 cxMapPut(map, "key 5", (void *) "val 5");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
164 cxMapPut(map, "key 6", (void *) "val 6");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
165 cxMapPut(map, "bar 7", (void *) "val 7");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
166 cxMapPut(map, "key 8", (void *) "val 8");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
167 cxMapPut(map, "key 9", (void *) "val 9");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
168 cxMapPut(map, "key 10", (void *) "val 10");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
169
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
170 CX_TEST_ASSERT(((struct cx_hash_map_s *)map)->bucket_count == 7);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
171 int result = cxMapRehash(map);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
172 CX_TEST_ASSERT(result == 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
173 CX_TEST_ASSERT(((struct cx_hash_map_s *)map)->bucket_count == 25);
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
174 CX_TEST_ASSERT(map->collection.size == 10);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
175
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
176 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 1"), "val 1"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
177 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 2"), "val 2"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
178 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 3"), "val 3"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
179 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "foo 4"), "val 4"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
180 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 5"), "val 5"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
181 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 6"), "val 6"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
182 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "bar 7"), "val 7"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
183 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 8"), "val 8"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
184 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 9"), "val 9"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
185 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key 10"), "val 10"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
186
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
187 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
188 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
189 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
190 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
191 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
192
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
193 CX_TEST(test_hash_map_rehash_not_required) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
194 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
195 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
196 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
197 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
198 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 8);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
199
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
200 cxMapPut(map, "key 1", (void *) "val 1");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
201 cxMapPut(map, "key 2", (void *) "val 2");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
202 cxMapPut(map, "key 3", (void *) "val 3");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
203 cxMapPut(map, "key 4", (void *) "val 4");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
204 cxMapPut(map, "key 5", (void *) "val 5");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
205 cxMapPut(map, "key 6", (void *) "val 6");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
206
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
207 // 6/8 does not exceed 0.75, therefore the function should not rehash
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
208 int result = cxMapRehash(map);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
209 CX_TEST_ASSERT(result == 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
210 CX_TEST_ASSERT(((struct cx_hash_map_s *)map)->bucket_count == 8);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
211
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
212 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
213 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
214 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
215 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
216 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
217
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
218 CX_TEST(test_hash_map_clear) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
219 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
220 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
221 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
222 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
223 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
224
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
225 cxMapPut(map, "key 1", (void *) "val 1");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
226 cxMapPut(map, "key 2", (void *) "val 2");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
227 cxMapPut(map, "key 3", (void *) "val 3");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
228
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
229 CX_TEST_ASSERT(map->collection.size == 3);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
230
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
231 cxMapClear(map);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
232
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
233 CX_TEST_ASSERT(map->collection.size == 0);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
234 CX_TEST_ASSERT(cxMapGet(map, "key 1") == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
235 CX_TEST_ASSERT(cxMapGet(map, "key 2") == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
236 CX_TEST_ASSERT(cxMapGet(map, "key 3") == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
237
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
238 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
239 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
240 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
241 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
242 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
243
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
244 CX_TEST(test_hash_map_store_ucx_strings) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
245 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
246 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
247 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
248 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
249 // create the map
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
250 CxMap *map = cxHashMapCreate(allocator, sizeof(cxstring), 8);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
251
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
252 // define some strings
1582
32b82c424252 removes the CX_STR() macro and instead makes the cx_str() inlinable
Mike Becker <universe@uap-core.de>
parents: 1579
diff changeset
253 cxstring s1 = cx_str("this");
32b82c424252 removes the CX_STR() macro and instead makes the cx_str() inlinable
Mike Becker <universe@uap-core.de>
parents: 1579
diff changeset
254 cxstring s2 = cx_str("is");
32b82c424252 removes the CX_STR() macro and instead makes the cx_str() inlinable
Mike Becker <universe@uap-core.de>
parents: 1579
diff changeset
255 cxstring s3 = cx_str("a");
32b82c424252 removes the CX_STR() macro and instead makes the cx_str() inlinable
Mike Becker <universe@uap-core.de>
parents: 1579
diff changeset
256 cxstring s4 = cx_str("test");
32b82c424252 removes the CX_STR() macro and instead makes the cx_str() inlinable
Mike Becker <universe@uap-core.de>
parents: 1579
diff changeset
257 cxstring s5 = cx_str("setup");
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
258
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
259 // put them into the map
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
260 cxMapPut(map, "s1", &s1);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
261 cxMapPut(map, "s2", &s2);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
262 cxMapPut(map, "s3", &s3);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
263 cxMapPut(map, "s4", &s4);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
264
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
265 // overwrite a value
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
266 cxMapPut(map, "s1", &s5);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
267
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
268 // look up a string
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
269 cxstring * s3p = cxMapGet(map, "s3");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
270 CX_TEST_ASSERT(s3p->length == s3.length);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
271 CX_TEST_ASSERT(s3p->ptr == s3.ptr);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
272 CX_TEST_ASSERT(s3p != &s3);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
273
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
274 // remove a string
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
275 cxstring ret = {0};
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
276 CX_TEST_ASSERT(0 == cxMapRemoveAndGet(map, "s2", &ret));
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
277 CX_TEST_ASSERT(map->collection.size == 3);
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
278 CX_TEST_ASSERT(0 == cx_strcmp(ret, cx_str("is")));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
279
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
280 // iterate
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
281 bool s3found = false, s4found = false, s5found = false;
1115
6db21dee4929 create specialized map iterators - fixes #550
Mike Becker <universe@uap-core.de>
parents: 1114
diff changeset
282 CxMapIterator iter = cxMapIteratorValues(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
283 cx_foreach(cxstring*, s, iter) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
284 s3found |= s3.ptr == s->ptr;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
285 s4found |= s4.ptr == s->ptr;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
286 s5found |= s5.ptr == s->ptr;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
287 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
288 CX_TEST_ASSERT(s3found && s4found && s5found);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
289
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
290 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
291 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
292 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
293 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
294 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
295
1442
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
296 CX_TEST(test_hash_map_integer_keys) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
297 CxMap *map = cxHashMapCreate(NULL, sizeof(cxstring), 0);
1442
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
298 CX_TEST_DO {
1582
32b82c424252 removes the CX_STR() macro and instead makes the cx_str() inlinable
Mike Becker <universe@uap-core.de>
parents: 1579
diff changeset
299 cxstring s1 = cx_str("hello");
32b82c424252 removes the CX_STR() macro and instead makes the cx_str() inlinable
Mike Becker <universe@uap-core.de>
parents: 1579
diff changeset
300 cxstring s2 = cx_str("world");
1442
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
301
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
302 cxMapPut(map, UINT32_C(70875), &s1);
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
303 cxMapPut(map, UINT64_C(5785133750), &s2);
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
304
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
305 CX_TEST_ASSERT(cx_strcmp_p(&s1, cxMapGet(map, UINT32_C(70875))) == 0);
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
306 CX_TEST_ASSERT(cx_strcmp_p(&s2, cxMapGet(map, UINT64_C(5785133750))) == 0);
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
307 }
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
308 cxMapFree(map);
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
309 }
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
310
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
311 CX_TEST(test_hash_map_remove_via_iterator) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
312 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
313 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
314 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
315 CX_TEST_DO {
1510
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
316 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 3);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
317
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
318 cxMapPut(map, "key 1", (void *) "val 1");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
319 cxMapPut(map, "key 2", (void *) "val 2");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
320 cxMapPut(map, "key 3", (void *) "val 3");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
321 cxMapPut(map, "key 4", (void *) "val 4");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
322 cxMapPut(map, "key 5", (void *) "val 5");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
323 cxMapPut(map, "key 6", (void *) "val 6");
1510
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
324 cxMapPut(map, "key 7", (void *) "val 7");
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
325 cxMapPut(map, "key 8", (void *) "val 8");
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
326 cxMapPut(map, "key 9", (void *) "val 9");
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
327
1429
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
328 CxMapIterator iter = cxMapIterator(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
329 cx_foreach(CxMapEntry*, entry, iter) {
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
330 if (((const char *)entry->key->data)[4] % 2 == 1) cxIteratorFlagRemoval(iter);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
331 }
1510
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
332 CX_TEST_ASSERT(cxMapSize(map) == 4);
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
333 CX_TEST_ASSERT(iter.elem_count == 4);
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
334 CX_TEST_ASSERT(iter.index == map->collection.size);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
335
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
336 CX_TEST_ASSERT(cxMapGet(map, "key 1") == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
337 CX_TEST_ASSERT(cxMapGet(map, "key 2") != NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
338 CX_TEST_ASSERT(cxMapGet(map, "key 3") == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
339 CX_TEST_ASSERT(cxMapGet(map, "key 4") != NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
340 CX_TEST_ASSERT(cxMapGet(map, "key 5") == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
341 CX_TEST_ASSERT(cxMapGet(map, "key 6") != NULL);
1510
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
342 CX_TEST_ASSERT(cxMapGet(map, "key 7") == NULL);
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
343 CX_TEST_ASSERT(cxMapGet(map, "key 8") != NULL);
89cf6b4a5792 adjust test_hash_map_remove_via_iterator s.t. we achieve coverage for the case where we remove not the first element of a bucket
Mike Becker <universe@uap-core.de>
parents: 1483
diff changeset
344 CX_TEST_ASSERT(cxMapGet(map, "key 9") == NULL);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
345
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
346 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
347 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
348 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
349 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
350 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
351
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
352 struct test_destr_struct {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
353 char *str;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
354 };
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
355
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
356 static void test_simple_destructor(void *d) {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
357 struct test_destr_struct *data = d;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
358 strcpy(data->str, "OK");
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
359 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
360
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
361 static void test_advanced_destructor(
985
68754c7de906 major refactoring of attributes
Mike Becker <universe@uap-core.de>
parents: 926
diff changeset
362 cx_attr_unused void *unused,
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
363 void *d
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
364 ) {
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
365 test_simple_destructor(d);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
366 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
367
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
368 static CX_TEST_SUBROUTINE(verify_any_destructor, CxMap *map) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
369 CxHashKey k1 = cx_hash_key_str("key 1");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
370 CxHashKey k2 = cx_hash_key_str("key 2");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
371 CxHashKey k3 = cx_hash_key_str("key 3");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
372 CxHashKey k4 = cx_hash_key_str("key 4");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
373 CxHashKey k5 = cx_hash_key_str("key 5");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
374
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
375 char v1[] = "val 1";
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
376 char v2[] = "val 2";
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
377 char v3[] = "val 3";
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
378 char v4[] = "val 4";
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
379 char v5[] = "val 5";
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
380 char v6[] = "val 6";
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
381 char v7[] = "val 7";
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
382
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
383 struct test_destr_struct d1 = {v1};
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
384 struct test_destr_struct d2 = {v2};
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
385 struct test_destr_struct d3 = {v3};
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
386 struct test_destr_struct d4 = {v4};
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
387 struct test_destr_struct d5 = {v5};
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
388 struct test_destr_struct d6 = {v6};
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
389 struct test_destr_struct d7 = {v7};
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
390
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
391 void *v1data = &d1;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
392 void *v2data = &d2;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
393 void *v3data = &d3;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
394 void *v4data = &d4;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
395 void *v5data = &d5;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
396 void *v6data = &d6;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
397 void *v7data = &d7;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
398
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
399 cxMapPut(map, k1, v1data);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
400 cxMapPut(map, k2, v2data);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
401 cxMapPut(map, k3, v3data);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
402 cxMapPut(map, k4, v4data);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
403
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
404 CX_TEST_ASSERT(0 == cxMapRemove(map, k2));
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
405 if (map->collection.store_pointer) {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
406 struct test_destr_struct *r;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
407 CX_TEST_ASSERT(0 == cxMapRemoveAndGet(map, k3, &r));
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
408 CX_TEST_ASSERT(r == &d3);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
409 } else {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
410 struct test_destr_struct r;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
411 CX_TEST_ASSERT(0 == cxMapRemoveAndGet(map, k3, &r));
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
412 CX_TEST_ASSERT(r.str == v3);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
413 }
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
414
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
415 CX_TEST_ASSERT(0 == strcmp(v1, "val 1"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
416 CX_TEST_ASSERT(0 == strcmp(v2, "OK"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
417 CX_TEST_ASSERT(0 == strcmp(v3, "val 3"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
418 CX_TEST_ASSERT(0 == strcmp(v4, "val 4"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
419 CX_TEST_ASSERT(0 == strcmp(v5, "val 5"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
420
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
421 // put k5, overwrite k1, put new k3
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
422 cxMapPut(map, k5, v5data);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
423 cxMapPut(map, k1, v6data);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
424 cxMapPut(map, k3, v7data);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
425
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
426 // destructor the value behind k1 was called, but for k3 not
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
427 CX_TEST_ASSERT(0 == strcmp(v1, "OK"));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
428 CX_TEST_ASSERT(0 == strcmp(v3, "val 3"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
429
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
430 // now remove k1 via key iterator and k5 (val 5) via value iterator
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
431 v1[0] = 'y'; // mark v1 and check that destr is not called for previous val
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
432 {
1429
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
433 CxMapIterator iter = cxMapIteratorKeys(map);
1387
9bdd053820b7 the elem_count member of an iterator was not updated after removing an element flagged by cxIteratorFlagRemoval() - fixes #728
Mike Becker <universe@uap-core.de>
parents: 1341
diff changeset
434 CX_TEST_ASSERT(iter.elem_count == 4);
9bdd053820b7 the elem_count member of an iterator was not updated after removing an element flagged by cxIteratorFlagRemoval() - fixes #728
Mike Becker <universe@uap-core.de>
parents: 1341
diff changeset
435 CX_TEST_ASSERT(cxMapSize(map) == 4);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
436 cx_foreach(CxHashKey*, key, iter) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
437 if (((char*)key->data)[4] == '1') cxIteratorFlagRemoval(iter);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
438 }
1387
9bdd053820b7 the elem_count member of an iterator was not updated after removing an element flagged by cxIteratorFlagRemoval() - fixes #728
Mike Becker <universe@uap-core.de>
parents: 1341
diff changeset
439 CX_TEST_ASSERT(iter.elem_count == 3);
9bdd053820b7 the elem_count member of an iterator was not updated after removing an element flagged by cxIteratorFlagRemoval() - fixes #728
Mike Becker <universe@uap-core.de>
parents: 1341
diff changeset
440 CX_TEST_ASSERT(cxMapSize(map) == 3);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
441 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
442 {
1429
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
443 CxMapIterator iter = cxMapIteratorValues(map);
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
444 cx_foreach(struct test_destr_struct*, v, iter) {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
445 if (v->str[4] == '5') cxIteratorFlagRemoval(iter);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
446 }
1387
9bdd053820b7 the elem_count member of an iterator was not updated after removing an element flagged by cxIteratorFlagRemoval() - fixes #728
Mike Becker <universe@uap-core.de>
parents: 1341
diff changeset
447 CX_TEST_ASSERT(iter.elem_count == 2);
9bdd053820b7 the elem_count member of an iterator was not updated after removing an element flagged by cxIteratorFlagRemoval() - fixes #728
Mike Becker <universe@uap-core.de>
parents: 1341
diff changeset
448 CX_TEST_ASSERT(cxMapSize(map) == 2);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
449 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
450
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
451 CX_TEST_ASSERT(0 == strcmp(v1, "yK"));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
452 CX_TEST_ASSERT(0 == strcmp(v2, "OK"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
453 CX_TEST_ASSERT(0 == strcmp(v3, "val 3"));
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
454 CX_TEST_ASSERT(0 == strcmp(v4, "val 4"));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
455 CX_TEST_ASSERT(0 == strcmp(v5, "OK"));
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
456 CX_TEST_ASSERT(0 == strcmp(v6, "OK"));
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
457 CX_TEST_ASSERT(0 == strcmp(v7, "val 7"));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
458
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
459 // mark the already destroyed items
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
460 // and check that they are not destroyed again
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
461 v1[0] = v2[0] = v4[0] = v5[0] = 'c';
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
462
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
463 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
464
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
465 CX_TEST_ASSERT(0 == strcmp(v1, "cK"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
466 CX_TEST_ASSERT(0 == strcmp(v2, "cK"));
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
467 CX_TEST_ASSERT(0 == strcmp(v3, "val 3"));
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
468 CX_TEST_ASSERT(0 == strcmp(v4, "OK"));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
469 CX_TEST_ASSERT(0 == strcmp(v5, "cK"));
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
470 CX_TEST_ASSERT(0 == strcmp(v6, "OK"));
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
471 CX_TEST_ASSERT(0 == strcmp(v7, "OK"));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
472 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
473
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
474 CX_TEST(test_hash_map_simple_destructor_objects) {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
475 CxTestingAllocator talloc;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
476 cx_testing_allocator_init(&talloc);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
477 CxAllocator *allocator = &talloc.base;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
478 CX_TEST_DO {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
479 CxMap *map = cxHashMapCreate(allocator,
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
480 sizeof(struct test_destr_struct), 0);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
481 map->collection.simple_destructor = test_simple_destructor;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
482 CX_TEST_CALL_SUBROUTINE(verify_any_destructor, map);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
483 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
484 }
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
485 cx_testing_allocator_destroy(&talloc);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
486 }
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
487
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
488 CX_TEST(test_hash_map_advanced_destructor_objects) {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
489 CxTestingAllocator talloc;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
490 cx_testing_allocator_init(&talloc);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
491 CxAllocator *allocator = &talloc.base;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
492 CX_TEST_DO {
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
493 CxMap *map = cxHashMapCreate(allocator,
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
494 sizeof(struct test_destr_struct), 0);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
495 map->collection.advanced_destructor = test_advanced_destructor;
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
496 CX_TEST_CALL_SUBROUTINE(verify_any_destructor, map);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
497 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
498 }
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
499 cx_testing_allocator_destroy(&talloc);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
500 }
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
501
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
502 CX_TEST(test_hash_map_simple_destructor_pointers) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
503 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
504 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
505 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
506 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
507 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 0);
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
508 map->collection.simple_destructor = test_simple_destructor;
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
509 CX_TEST_CALL_SUBROUTINE(verify_any_destructor, map);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
510 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
511 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
512 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
513 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
514
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
515 CX_TEST(test_hash_map_advanced_destructor_pointers) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
516 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
517 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
518 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
519 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
520 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 0);
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
521 map->collection.advanced_destructor = test_advanced_destructor;
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
522 CX_TEST_CALL_SUBROUTINE(verify_any_destructor, map);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
523 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
524 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
525 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
526 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
527
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
528 static bool test_hash_map_clone_func_max_enabled = false;
1443
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
529 static unsigned test_hash_map_clone_func_max_clones;
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
530 static void *test_hash_map_clone_func(void *dst, const void *src,
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
531 const CxAllocator *al, void *data) {
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
532 if (test_hash_map_clone_func_max_enabled) {
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
533 if (test_hash_map_clone_func_max_clones == 0) return NULL;
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
534 test_hash_map_clone_func_max_clones--;
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
535 }
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
536 if (dst == NULL) {
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
537 dst = cxMalloc(al, sizeof(int));
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
538 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
539 *((int*)dst) = *((int*)src) + *((int*)data);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
540 return dst;
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
541 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
542
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
543 CX_TEST(test_hash_map_clone) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
544 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
545 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
546 const char *exist_keys[] = {"k1", "k2", "k3"};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
547 int exists[] = {1, 3, 4};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
548 const char *source_keys[] = {"k4", "k2", "k5"};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
549 int source[] = {7, 9, 15};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
550 for (unsigned int i = 0 ; i < 3 ; i++) {
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
551 cxMapPut(dst, exist_keys[i], &exists[i]);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
552 cxMapPut(src, source_keys[i], &source[i]);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
553 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
554 CX_TEST_DO {
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
555 int c = 4;
1444
dd9dcbb39c2f make clone functions return int instead of size_t
Mike Becker <universe@uap-core.de>
parents: 1443
diff changeset
556 CX_TEST_ASSERT(0 == cxMapClone(dst, src, test_hash_map_clone_func, NULL, &c));
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
557 CX_TEST_ASSERT(cxMapSize(dst) == 5);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
558 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 1);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
559 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 13);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
560 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 4);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
561 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 11);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
562 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k5")) == 19);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
563 CX_TEST_ASSERT(cxMapSize(src) == 3);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
564 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k4")) == 7);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
565 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k2")) == 9);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
566 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k5")) == 15);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
567 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
568 cxMapFree(dst);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
569 cxMapFree(src);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
570 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
571
1443
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
572 CX_TEST(test_hash_map_clone_alloc_fail) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
573 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
574 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
1443
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
575 const char *exist_keys[] = {"k1", "k2", "k3"};
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
576 int exists[] = {1, 3, 4};
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
577 const char *source_keys[] = {"k4", "k2", "k5"};
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
578 int source[] = {7, 9, 15};
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
579 for (unsigned int i = 0 ; i < 3 ; i++) {
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
580 cxMapPut(dst, exist_keys[i], &exists[i]);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
581 cxMapPut(src, source_keys[i], &source[i]);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
582 }
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
583 CX_TEST_DO {
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
584 int c = 4;
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
585 test_hash_map_clone_func_max_enabled = true;
1443
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
586 test_hash_map_clone_func_max_clones = 2;
1444
dd9dcbb39c2f make clone functions return int instead of size_t
Mike Becker <universe@uap-core.de>
parents: 1443
diff changeset
587 CX_TEST_ASSERT(0 != cxMapClone(dst, src, test_hash_map_clone_func, NULL, &c));
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
588 test_hash_map_clone_func_max_enabled = false;
1443
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
589 CX_TEST_ASSERT(cxMapSize(dst) == 4);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
590 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 1);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
591 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 13);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
592 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 4);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
593 // the concrete element which is affected might change when the hash function changes
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
594 CX_TEST_ASSERT(cxMapGet(dst, "k4") == NULL);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
595 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k5")) == 19);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
596 CX_TEST_ASSERT(cxMapSize(src) == 3);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
597 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k4")) == 7);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
598 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k2")) == 9);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
599 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k5")) == 15);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
600 }
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
601 cxMapFree(dst);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
602 cxMapFree(src);
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
603 }
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
604
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
605 CX_TEST(test_hash_map_clone_ptr) {
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
606 CxTestingAllocator talloc;
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
607 cx_testing_allocator_init(&talloc);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
608 CxAllocator *allocator = &talloc.base;
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
609 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
610 cxSetAdvancedDestructor(dst, cxFree, allocator);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
611 CxMap *src = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
612 const char *exist_keys[] = {"k1", "k2", "k3"};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
613 int exists[] = {1, 3, 4};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
614 const char *source_keys[] = {"k4", "k2", "k5"};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
615 int source[] = {7, 9, 15};
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
616 for (unsigned int i = 0 ; i < 3 ; i++) {
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
617 int *y = cxMalloc(allocator, sizeof(int));
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
618 *y = exists[i];
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
619 cxMapPut(dst, exist_keys[i], y);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
620 cxMapPut(src, source_keys[i], &source[i]);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
621 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
622 CX_TEST_DO {
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
623 int c = 4;
1444
dd9dcbb39c2f make clone functions return int instead of size_t
Mike Becker <universe@uap-core.de>
parents: 1443
diff changeset
624 CX_TEST_ASSERT(0 == cxMapClone(dst, src, test_hash_map_clone_func, allocator, &c));
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
625 CX_TEST_ASSERT(cxMapSize(dst) == 5);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
626 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 1);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
627 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 13);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
628 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 4);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
629 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 11);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
630 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k5")) == 19);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
631 CX_TEST_ASSERT(cxMapSize(src) == 3);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
632 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k4")) == 7);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
633 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k2")) == 9);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
634 CX_TEST_ASSERT(*((int*)cxMapGet(src, "k5")) == 15);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
635
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
636 cxMapClear(dst);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
637 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
638 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
639 cxMapFree(dst);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
640 cxMapFree(src);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
641 cx_testing_allocator_destroy(&talloc);
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
642 }
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
643
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
644 CX_TEST(test_hash_map_difference) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
645 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
646
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
647 CxMap *s1 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
648 CxMap *s2 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
649 const char *s1_keys[] = {"k1", "k2", "k3"};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
650 int s1_values[] = {1, 3, 4};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
651 const char *s2_keys[] = {"k4", "k2", "k5"};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
652 int s2_values[] = {7, 9, 15};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
653 for (unsigned int i = 0 ; i < 3 ; i++) {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
654 cxMapPut(s1, s1_keys[i], &s1_values[i]);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
655 cxMapPut(s2, s2_keys[i], &s2_values[i]);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
656 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
657 CX_TEST_DO {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
658 int c = 4;
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
659 CX_TEST_ASSERT(0 == cxMapDifference(dst, s1, s2, test_hash_map_clone_func, NULL, &c));
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
660 CX_TEST_ASSERT(cxMapSize(dst) == 2);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
661 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 5);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
662 CX_TEST_ASSERT(cxMapGet(dst, "k2") == NULL);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
663 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
664 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
665 cxMapFree(dst);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
666 cxMapFree(s1);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
667 cxMapFree(s2);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
668 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
669
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
670 CX_TEST(test_hash_map_difference_alloc_fail) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
671 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
672
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
673 CxMap *s1 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
674 CxMap *s2 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
675 const char *s1_keys[] = {"k1", "k2", "k3"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
676 int s1_values[] = {1, 3, 4};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
677 const char *s2_keys[] = {"k4", "k2", "k5"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
678 int s2_values[] = {7, 9, 15};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
679 for (unsigned int i = 0 ; i < 3 ; i++) {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
680 cxMapPut(s1, s1_keys[i], &s1_values[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
681 cxMapPut(s2, s2_keys[i], &s2_values[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
682 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
683 CX_TEST_DO {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
684 int c = 4;
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
685 test_hash_map_clone_func_max_enabled = true;
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
686 test_hash_map_clone_func_max_clones = 1;
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
687 CX_TEST_ASSERT(1 == cxMapDifference(dst, s1, s2, test_hash_map_clone_func, NULL, &c));
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
688 test_hash_map_clone_func_max_enabled = false;
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
689 CX_TEST_ASSERT(cxMapSize(dst) == 1);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
690 // the concrete element which is affected might change when the hash function changes
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
691 CX_TEST_ASSERT(cxMapGet(dst, "k1") == NULL);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
692 CX_TEST_ASSERT(cxMapGet(dst, "k2") == NULL);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
693 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
694 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
695 cxMapFree(dst);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
696 cxMapFree(s1);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
697 cxMapFree(s2);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
698 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
699
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
700 CX_TEST(test_hash_map_list_difference) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
701 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
702 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
703 CxList *keys = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
704 cxSetCompareFunc(keys, cx_hash_key_cmp);
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
705
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
706 const char *src_keys[] = {"k1", "k2", "k3"};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
707 int src_values[] = {1, 3, 4};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
708 for (unsigned int i = 0 ; i < 3 ; i++) {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
709 cxMapPut(src, src_keys[i], &src_values[i]);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
710 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
711 const char *k[] = {"k4", "k2", "k5"};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
712 for (unsigned int i = 0 ; i < 3 ; i++) {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
713 CxHashKey key = CX_HASH_KEY(k[i]);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
714 cxListAdd(keys, &key);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
715 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
716 CX_TEST_DO {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
717 int c = 4;
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
718 CX_TEST_ASSERT(0 == cxMapListDifference(dst, src, keys, test_hash_map_clone_func, NULL, &c));
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
719 CX_TEST_ASSERT(cxMapSize(dst) == 2);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
720 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 5);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
721 CX_TEST_ASSERT(cxMapGet(dst, "k2") == NULL);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
722 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
723 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
724 cxMapFree(dst);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
725 cxMapFree(src);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
726 cxListFree(keys);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
727 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
728
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
729 CX_TEST(test_hash_map_list_difference_alloc_fail) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
730 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
731 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
732 CxList *keys = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
733 cxSetCompareFunc(keys, cx_hash_key_cmp);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
734
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
735 const char *src_keys[] = {"k1", "k2", "k3"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
736 int src_values[] = {1, 3, 4};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
737 for (unsigned int i = 0 ; i < 3 ; i++) {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
738 cxMapPut(src, src_keys[i], &src_values[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
739 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
740 const char *k[] = {"k4", "k2", "k5"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
741 for (unsigned int i = 0 ; i < 3 ; i++) {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
742 CxHashKey key = CX_HASH_KEY(k[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
743 cxListAdd(keys, &key);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
744 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
745 CX_TEST_DO {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
746 int c = 4;
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
747 test_hash_map_clone_func_max_enabled = true;
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
748 test_hash_map_clone_func_max_clones = 1;
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
749 CX_TEST_ASSERT(1 == cxMapListDifference(dst, src, keys, test_hash_map_clone_func, NULL, &c));
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
750 test_hash_map_clone_func_max_enabled = false;
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
751 CX_TEST_ASSERT(cxMapSize(dst) == 1);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
752 // the concrete element which is affected might change when the hash function changes
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
753 CX_TEST_ASSERT(cxMapGet(dst, "k1") == NULL);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
754 CX_TEST_ASSERT(cxMapGet(dst, "k2") == NULL);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
755 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
756 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
757 cxMapFree(dst);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
758 cxMapFree(src);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
759 cxListFree(keys);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
760 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
761
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
762 CX_TEST(test_hash_map_difference_non_empty_target) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
763 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
764 cxSetAdvancedDestructor(dst, cxFree, (void*) cxDefaultAllocator);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
765
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
766 CxMap *s1 = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
767 CxMap *s2 = cxHashMapCreate(NULL, sizeof(int), 0);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
768 const char *s1_keys[] = {"k1", "k2", "k3"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
769 int s1_values[] = {1, 3, 4};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
770 const char *s2_keys[] = {"k4", "k2", "k5"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
771 int s2_values[] = {7, 9, 15};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
772 for (unsigned int i = 0 ; i < 3 ; i++) {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
773 cxMapPut(s1, s1_keys[i], &s1_values[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
774 cxMapPut(s2, s2_keys[i], &s2_values[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
775 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
776
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
777 // add k5 to dst which is not in src, and also not in the difference
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
778 int *k5 = cxMallocDefault(sizeof(int));
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
779 *k5 = 1337;
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
780 cxMapPut(dst, "k5",k5);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
781
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
782 CX_TEST_DO {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
783 int c = 4;
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
784 CX_TEST_ASSERT(0 == cxMapDifference(dst, s1, s2, test_hash_map_clone_func, NULL, &c));
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
785 CX_TEST_ASSERT(cxMapSize(dst) == 3);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
786 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 5);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
787 CX_TEST_ASSERT(cxMapGet(dst, "k2") == NULL);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
788 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
789 CX_TEST_ASSERT(*(int*)cxMapGet(dst, "k5") == 1337);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
790 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
791 cxMapFree(dst);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
792 cxMapFree(s1);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
793 cxMapFree(s2);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
794 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
795
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
796 CX_TEST(test_hash_map_list_difference_non_empty_target) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
797 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
798 cxSetAdvancedDestructor(dst, cxFree, (void*) cxDefaultAllocator);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
799 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
800 CxList *keys = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
801 cxSetCompareFunc(keys, cx_hash_key_cmp);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
802
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
803 const char *src_keys[] = {"k1", "k2", "k3"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
804 int src_values[] = {1, 3, 4};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
805 for (unsigned int i = 0 ; i < 3 ; i++) {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
806 cxMapPut(src, src_keys[i], &src_values[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
807 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
808 const char *k[] = {"k4", "k2", "k5"};
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
809 for (unsigned int i = 0 ; i < 3 ; i++) {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
810 CxHashKey key = CX_HASH_KEY(k[i]);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
811 cxListAdd(keys, &key);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
812 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
813
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
814 // add k5 to dst which is not in src, and also not in the difference
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
815 int *k5 = cxMallocDefault(sizeof(int));
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
816 *k5 = 1337;
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
817 cxMapPut(dst, "k5",k5);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
818
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
819 CX_TEST_DO {
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
820 int c = 4;
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
821 CX_TEST_ASSERT(0 == cxMapListDifference(dst, src, keys, test_hash_map_clone_func, NULL, &c));
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
822 CX_TEST_ASSERT(cxMapSize(dst) == 3);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
823 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 5);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
824 CX_TEST_ASSERT(cxMapGet(dst, "k2") == NULL);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
825 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
1466
a58c65d31342 difference shall not check already present items in the destination - fixes #753
Mike Becker <universe@uap-core.de>
parents: 1450
diff changeset
826 CX_TEST_ASSERT(*(int*)cxMapGet(dst, "k5") == 1337);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
827 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
828 cxMapFree(dst);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
829 cxMapFree(src);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
830 cxListFree(keys);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
831 }
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
832
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
833 CX_TEST(test_hash_map_difference_ptr) {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
834 CxTestingAllocator talloc;
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
835 cx_testing_allocator_init(&talloc);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
836 CxAllocator *allocator = &talloc.base;
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
837 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
838 cxSetAdvancedDestructor(dst, cxFree, allocator);
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
839
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
840 CxMap *s1 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
841 CxMap *s2 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
842 const char *s1_keys[] = {"k1", "k2", "k3"};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
843 int s1_values[] = {1, 3, 4};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
844 const char *s2_keys[] = {"k4", "k2", "k5"};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
845 int s2_values[] = {7, 9, 15};
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
846 for (unsigned int i = 0 ; i < 3 ; i++) {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
847 cxMapPut(s1, s1_keys[i], &s1_values[i]);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
848 cxMapPut(s2, s2_keys[i], &s2_values[i]);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
849 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
850 CX_TEST_DO {
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
851 int c = 4;
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
852 CX_TEST_ASSERT(0 == cxMapDifference(dst, s1, s2, test_hash_map_clone_func, allocator, &c));
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
853 CX_TEST_ASSERT(cxMapSize(dst) == 2);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
854 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 5);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
855 CX_TEST_ASSERT(cxMapGet(dst, "k2") == NULL);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
856 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
857
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
858 cxMapClear(dst);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
859 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
860 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
861 cxMapFree(dst);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
862 cxMapFree(s1);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
863 cxMapFree(s2);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
864 cx_testing_allocator_destroy(&talloc);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
865 }
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
866
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
867 CX_TEST(test_hash_map_intersection) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
868 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
869
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
870 CxMap *s1 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
871 CxMap *s2 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
872 const char *s1_keys[] = {"k1", "k2", "k3", "k4"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
873 int s1_values[] = {1, 3, 4, 6};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
874 const char *s2_keys[] = {"k4", "k5", "k2", "k6"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
875 int s2_values[] = {5, 9, 15, 23};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
876 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
877 cxMapPut(s1, s1_keys[i], &s1_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
878 cxMapPut(s2, s2_keys[i], &s2_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
879 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
880 CX_TEST_DO {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
881 int c = 4;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
882 CX_TEST_ASSERT(0 == cxMapIntersection(dst, s1, s2, test_hash_map_clone_func, NULL, &c));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
883 CX_TEST_ASSERT(cxMapSize(dst) == 2);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
884 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
885 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 10);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
886 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
887 cxMapFree(dst);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
888 cxMapFree(s1);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
889 cxMapFree(s2);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
890 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
891
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
892 CX_TEST(test_hash_map_intersection_alloc_fail) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
893 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
894
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
895 CxMap *s1 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
896 CxMap *s2 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
897 const char *s1_keys[] = {"k1", "k2", "k3", "k4"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
898 int s1_values[] = {1, 3, 4, 6};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
899 const char *s2_keys[] = {"k4", "k5", "k2", "k6"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
900 int s2_values[] = {5, 9, 15, 23};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
901 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
902 cxMapPut(s1, s1_keys[i], &s1_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
903 cxMapPut(s2, s2_keys[i], &s2_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
904 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
905 CX_TEST_DO {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
906 int c = 4;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
907 test_hash_map_clone_func_max_enabled = true;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
908 test_hash_map_clone_func_max_clones = 1;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
909 CX_TEST_ASSERT(0 != cxMapIntersection(dst, s1, s2, test_hash_map_clone_func, NULL, &c));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
910 test_hash_map_clone_func_max_enabled = false;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
911 CX_TEST_ASSERT(cxMapSize(dst) == 1);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
912 // the concrete element which is affected might change when the hash function changes
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
913 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
914 CX_TEST_ASSERT(cxMapGet(dst, "k4") == NULL);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
915 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
916 cxMapFree(dst);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
917 cxMapFree(s1);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
918 cxMapFree(s2);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
919 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
920
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
921 CX_TEST(test_hash_map_list_intersection) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
922 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
923 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
924 CxList *keys = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
925 cxSetCompareFunc(keys, cx_hash_key_cmp);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
926
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
927 const char *src_keys[] = {"k1", "k2", "k3", "k4"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
928 int src_values[] = {1, 3, 4, 6};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
929 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
930 cxMapPut(src, src_keys[i], &src_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
931 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
932 const char *k[] = {"k4", "k5", "k2", "k6"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
933 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
934 CxHashKey key = CX_HASH_KEY(k[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
935 cxListAdd(keys, &key);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
936 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
937 CX_TEST_DO {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
938 int c = 4;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
939 CX_TEST_ASSERT(0 == cxMapListIntersection(dst, src, keys, test_hash_map_clone_func, NULL, &c));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
940 CX_TEST_ASSERT(cxMapSize(dst) == 2);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
941 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
942 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 10);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
943 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
944 cxMapFree(dst);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
945 cxMapFree(src);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
946 cxListFree(keys);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
947 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
948
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
949 CX_TEST(test_hash_map_list_intersection_alloc_fail) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
950 CxMap *dst = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
951 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
952 CxList *keys = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
953 cxSetCompareFunc(keys, cx_hash_key_cmp);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
954
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
955 const char *src_keys[] = {"k1", "k2", "k3", "k4"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
956 int src_values[] = {1, 3, 4, 6};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
957 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
958 cxMapPut(src, src_keys[i], &src_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
959 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
960 const char *k[] = {"k4", "k5", "k2", "k6"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
961 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
962 CxHashKey key = CX_HASH_KEY(k[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
963 cxListAdd(keys, &key);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
964 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
965 CX_TEST_DO {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
966 int c = 4;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
967 test_hash_map_clone_func_max_enabled = true;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
968 test_hash_map_clone_func_max_clones = 1;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
969 CX_TEST_ASSERT(0 != cxMapListIntersection(dst, src, keys, test_hash_map_clone_func, NULL, &c));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
970 test_hash_map_clone_func_max_enabled = false;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
971 CX_TEST_ASSERT(cxMapSize(dst) == 1);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
972 // the concrete element which is affected might change when the hash function changes
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
973 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
974 CX_TEST_ASSERT(cxMapGet(dst, "k4") == NULL);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
975 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
976 cxMapFree(dst);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
977 cxMapFree(src);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
978 cxListFree(keys);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
979 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
980
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
981 CX_TEST(test_hash_map_intersection_non_empty_target) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
982 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
983 cxSetAdvancedDestructor(dst, cxFree, (void*) cxDefaultAllocator);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
984
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
985 CxMap *s1 = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
986 CxMap *s2 = cxHashMapCreate(NULL, sizeof(int), 0);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
987 const char *s1_keys[] = {"k1", "k2", "k3", "k4"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
988 int s1_values[] = {1, 3, 4, 6};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
989 const char *s2_keys[] = {"k4", "k5", "k2", "k6"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
990 int s2_values[] = {5, 9, 15, 23};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
991 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
992 cxMapPut(s1, s1_keys[i], &s1_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
993 cxMapPut(s2, s2_keys[i], &s2_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
994 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
995
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
996 // add k7 to dst which is not in src, and also not in the difference
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
997 int *k7 = cxMallocDefault(sizeof(int));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
998 *k7 = 1337;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
999 cxMapPut(dst, "k7", k7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1000
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1001 CX_TEST_DO {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1002 int c = 4;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1003 CX_TEST_ASSERT(0 == cxMapIntersection(dst, s1, s2, test_hash_map_clone_func, NULL, &c));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1004 CX_TEST_ASSERT(cxMapSize(dst) == 3);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1005 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1006 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 10);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1007 CX_TEST_ASSERT(*(int*)cxMapGet(dst, "k7") == 1337);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1008 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1009 cxMapFree(dst);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1010 cxMapFree(s1);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1011 cxMapFree(s2);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1012 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1013
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1014 CX_TEST(test_hash_map_list_intersection_non_empty_target) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1015 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1016 cxSetAdvancedDestructor(dst, cxFree, (void*) cxDefaultAllocator);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1017 CxMap *src = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1018 CxList *keys = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1019 cxSetCompareFunc(keys, cx_hash_key_cmp);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1020
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1021 const char *src_keys[] = {"k1", "k2", "k3", "k4"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1022 int src_values[] = {1, 3, 4, 6};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1023 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1024 cxMapPut(src, src_keys[i], &src_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1025 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1026 const char *k[] = {"k4", "k5", "k2", "k6"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1027 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1028 CxHashKey key = CX_HASH_KEY(k[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1029 cxListAdd(keys, &key);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1030 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1031
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1032 // add k7 to dst which is not in src, and also not in the difference
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1033 int *k7 = cxMallocDefault(sizeof(int));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1034 *k7 = 1337;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1035 cxMapPut(dst, "k7", k7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1036
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1037 CX_TEST_DO {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1038 int c = 4;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1039 CX_TEST_ASSERT(0 == cxMapListIntersection(dst, src, keys, test_hash_map_clone_func, NULL, &c));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1040 CX_TEST_ASSERT(cxMapSize(dst) == 3);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1041 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1042 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 10);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1043 CX_TEST_ASSERT(*(int*)cxMapGet(dst, "k7") == 1337);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1044 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1045
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1046 cxMapFree(dst);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1047 cxMapFree(src);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1048 cxListFree(keys);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1049 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1050
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1051 CX_TEST(test_hash_map_intersection_ptr) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1052 CxTestingAllocator talloc;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1053 cx_testing_allocator_init(&talloc);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1054 CxAllocator *allocator = &talloc.base;
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1055 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1056 cxSetAdvancedDestructor(dst, cxFree, allocator);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1057
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1058 CxMap *s1 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1059 CxMap *s2 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1060 const char *s1_keys[] = {"k1", "k2", "k3", "k4"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1061 int s1_values[] = {1, 3, 4, 6};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1062 const char *s2_keys[] = {"k4", "k5", "k2", "k6"};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1063 int s2_values[] = {5, 9, 15, 23};
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1064 for (unsigned int i = 0 ; i < 4 ; i++) {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1065 cxMapPut(s1, s1_keys[i], &s1_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1066 cxMapPut(s2, s2_keys[i], &s2_values[i]);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1067 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1068 CX_TEST_DO {
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1069 int c = 4;
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1070 CX_TEST_ASSERT(0 == cxMapIntersection(dst, s1, s2, test_hash_map_clone_func, allocator, &c));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1071 CX_TEST_ASSERT(cxMapSize(dst) == 2);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1072 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1073 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 10);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1074 CX_TEST_ASSERT(cx_testing_allocator_used(&talloc));
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1075 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1076 cxMapFree(dst);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1077 cxMapFree(s1);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1078 cxMapFree(s2);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1079 cx_testing_allocator_destroy(&talloc);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1080 }
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1081
1474
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1082 CX_TEST(test_hash_map_union) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1083 CxMap *s1 = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1084 CxMap *s2 = cxHashMapCreate(NULL, sizeof(int), 0);
1474
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1085 const char *s1_keys[] = {"k1", "k2", "k3", "k4"};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1086 int s1_values[] = {1, 3, 4, 6};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1087 const char *s2_keys[] = {"k4", "k5", "k2", "k6"};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1088 int s2_values[] = {5, 9, 15, 23};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1089 for (unsigned int i = 0 ; i < 4 ; i++) {
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1090 cxMapPut(s1, s1_keys[i], &s1_values[i]);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1091 cxMapPut(s2, s2_keys[i], &s2_values[i]);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1092 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1093 CX_TEST_DO {
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1094 int c = 4;
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1095 CX_TEST_ASSERT(0 == cxMapUnion(s1, s2, test_hash_map_clone_func, NULL, &c));
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1096 CX_TEST_ASSERT(cxMapSize(s1) == 6);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1097 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k1")) == 1);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1098 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k2")) == 3);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1099 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k3")) == 4);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1100 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k4")) == 6);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1101 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k5")) == 13);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1102 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k6")) == 27);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1103 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1104 cxMapFree(s1);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1105 cxMapFree(s2);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1106 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1107
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1108 CX_TEST(test_hash_map_union_ptr) {
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1109 CxTestingAllocator talloc;
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1110 cx_testing_allocator_init(&talloc);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1111 CxAllocator *allocator = &talloc.base;
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1112 CxMap *dst = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1113 cxSetAdvancedDestructor(dst, cxFree, allocator);
1474
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1114
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1115 CxMap *s1 = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1116 CxMap *s2 = cxHashMapCreate(NULL, sizeof(int), 0);
1474
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1117 const char *s1_keys[] = {"k1", "k2", "k3", "k4"};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1118 int s1_values[] = {1, 3, 4, 6};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1119 const char *s2_keys[] = {"k4", "k5", "k2", "k6"};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1120 int s2_values[] = {5, 9, 15, 23};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1121 for (unsigned int i = 0 ; i < 4 ; i++) {
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1122 cxMapPut(s1, s1_keys[i], &s1_values[i]);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1123 cxMapPut(s2, s2_keys[i], &s2_values[i]);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1124 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1125 CX_TEST_DO {
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1126 int c = 4;
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1127 CX_TEST_ASSERT(0 == cxMapClone(dst, s1, test_hash_map_clone_func, allocator, &c));
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1128 CX_TEST_ASSERT(0 == cxMapUnion(dst, s2, test_hash_map_clone_func, allocator, &c));
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1129 CX_TEST_ASSERT(cxMapSize(dst) == 6);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1130 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k1")) == 5);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1131 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k2")) == 7);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1132 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k3")) == 8);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1133 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k4")) == 10);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1134 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k5")) == 13);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1135 CX_TEST_ASSERT(*((int*)cxMapGet(dst, "k6")) == 27);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1136 CX_TEST_ASSERT(cx_testing_allocator_used(&talloc));
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1137 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1138 cxMapFree(dst);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1139 cxMapFree(s1);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1140 cxMapFree(s2);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1141 cx_testing_allocator_destroy(&talloc);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1142 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1143
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1144 CX_TEST(test_hash_map_union_alloc_fail) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1145 CxMap *s1 = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1146 CxMap *s2 = cxHashMapCreate(NULL, sizeof(int), 0);
1474
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1147 const char *s1_keys[] = {"k1", "k2", "k3", "k4"};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1148 int s1_values[] = {1, 3, 4, 6};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1149 const char *s2_keys[] = {"k4", "k5", "k2", "k6"};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1150 int s2_values[] = {5, 9, 15, 23};
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1151 for (unsigned int i = 0 ; i < 4 ; i++) {
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1152 cxMapPut(s1, s1_keys[i], &s1_values[i]);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1153 cxMapPut(s2, s2_keys[i], &s2_values[i]);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1154 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1155 CX_TEST_DO {
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1156 int c = 4;
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1157 test_hash_map_clone_func_max_enabled = true;
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1158 test_hash_map_clone_func_max_clones = 1;
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1159 CX_TEST_ASSERT(0 != cxMapUnion(s1, s2, test_hash_map_clone_func, NULL, &c));
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1160 test_hash_map_clone_func_max_enabled = false;
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1161 CX_TEST_ASSERT(cxMapSize(s1) == 5);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1162 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k1")) == 1);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1163 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k2")) == 3);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1164 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k3")) == 4);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1165 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k4")) == 6);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1166 // the concrete element which is affected might change when the hash function changes
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1167 CX_TEST_ASSERT(cxMapGet(s1, "k5") == NULL);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1168 CX_TEST_ASSERT(*((int*)cxMapGet(s1, "k6")) == 27);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1169 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1170 cxMapFree(s1);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1171 cxMapFree(s2);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1172 }
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1173
1616
bdc04a8e0dd3 update names of internal simple_clone funcs to shallow_clone funcs - relates to #780
Mike Becker <universe@uap-core.de>
parents: 1605
diff changeset
1174 CX_TEST(test_hash_map_shallow_clones) {
1483
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1175 int v = 47; // the value does not matter in this test
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1176 CxMap *a = cxHashMapCreate(NULL, sizeof(int), 0);
1483
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1177 cxMapPut(a, "k1", &v);
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1178 cxMapPut(a, "k2", &v);
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1179 cxMapPut(a, "k3", &v);
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1180 cxMapPut(a, "k4", &v);
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1181
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1182 CxMap *b = cxHashMapCreate(NULL, sizeof(int), 0);
1483
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1183 cxMapPut(b, "k0", &v);
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1184 cxMapPut(b, "k2", &v);
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1185 cxMapPut(b, "k5", &v);
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1186
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1187 CxMap *c = cxHashMapCreate(NULL, sizeof(int), 0);
1483
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1188 cxMapPut(c, "k3", &v);
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1189 cxMapPut(c, "k4", &v);
97a6cf1520ba fix some memory management bugs in the map and list tests
Mike Becker <universe@uap-core.de>
parents: 1480
diff changeset
1190 cxMapPut(c, "k5", &v);
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1191
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1192
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1193 CxHashKey k;
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1194 CxList *kl1 = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1195 cxSetCompareFunc(kl1, cx_hash_key_cmp);
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1196 k = CX_HASH_KEY("k0");
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1197 cxListAdd(kl1, &k);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1198 k = CX_HASH_KEY("k2");
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1199 cxListAdd(kl1, &k);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1200 k = CX_HASH_KEY("k5");
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1201 cxListAdd(kl1, &k);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1202
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1203 CxList *kl2 = cxArrayListCreate(NULL, sizeof(CxHashKey), 4);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1204 cxSetCompareFunc(kl2, cx_hash_key_cmp);
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1205 k = CX_HASH_KEY("k3");
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1206 cxListAdd(kl2, &k);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1207 k = CX_HASH_KEY("k4");
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1208 cxListAdd(kl2, &k);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1209 k = CX_HASH_KEY("k5");
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1210 cxListAdd(kl2, &k);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1211
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1212 CxMap *d1 = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1213 CxMap *d2 = cxHashMapCreate(NULL, sizeof(int), 0);
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1214
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1215 CX_TEST_DO {
1604
68b75c091028 rename the "simple" cloning functions from Simple to Shallow
Mike Becker <universe@uap-core.de>
parents: 1582
diff changeset
1216 CX_TEST_ASSERT(0 == cxMapCloneShallow(d1, a));
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1217 CX_TEST_ASSERT(!cxMapContains(d1, "k0"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1218 CX_TEST_ASSERT(cxMapContains(d1, "k1"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1219 CX_TEST_ASSERT(cxMapContains(d1, "k2"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1220 CX_TEST_ASSERT(cxMapContains(d1, "k3"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1221 CX_TEST_ASSERT(cxMapContains(d1, "k4"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1222 CX_TEST_ASSERT(!cxMapContains(d1, "k5"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1223
1604
68b75c091028 rename the "simple" cloning functions from Simple to Shallow
Mike Becker <universe@uap-core.de>
parents: 1582
diff changeset
1224 CX_TEST_ASSERT(0 == cxMapListDifferenceShallow(d2, d1, kl1));
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1225 CX_TEST_ASSERT(!cxMapContains(d2, "k0"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1226 CX_TEST_ASSERT(cxMapContains(d2, "k1"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1227 CX_TEST_ASSERT(!cxMapContains(d2, "k2"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1228 CX_TEST_ASSERT(cxMapContains(d2, "k3"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1229 CX_TEST_ASSERT(cxMapContains(d2, "k4"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1230 CX_TEST_ASSERT(!cxMapContains(d2, "k5"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1231
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1232 cxMapClear(d1);
1604
68b75c091028 rename the "simple" cloning functions from Simple to Shallow
Mike Becker <universe@uap-core.de>
parents: 1582
diff changeset
1233 CX_TEST_ASSERT(0 == cxMapListIntersectionShallow(d1, d2, kl2));
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1234 CX_TEST_ASSERT(!cxMapContains(d1, "k0"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1235 CX_TEST_ASSERT(!cxMapContains(d1, "k1"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1236 CX_TEST_ASSERT(!cxMapContains(d1, "k2"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1237 CX_TEST_ASSERT(cxMapContains(d1, "k3"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1238 CX_TEST_ASSERT(cxMapContains(d1, "k4"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1239
1604
68b75c091028 rename the "simple" cloning functions from Simple to Shallow
Mike Becker <universe@uap-core.de>
parents: 1582
diff changeset
1240 CX_TEST_ASSERT(0 == cxMapUnionShallow(d1, b));
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1241 CX_TEST_ASSERT(cxMapContains(d1, "k0"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1242 CX_TEST_ASSERT(!cxMapContains(d1, "k1"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1243 CX_TEST_ASSERT(cxMapContains(d1, "k2"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1244 CX_TEST_ASSERT(cxMapContains(d1, "k3"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1245 CX_TEST_ASSERT(cxMapContains(d1, "k4"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1246 CX_TEST_ASSERT(cxMapContains(d1, "k5"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1247
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1248 cxMapClear(d2);
1604
68b75c091028 rename the "simple" cloning functions from Simple to Shallow
Mike Becker <universe@uap-core.de>
parents: 1582
diff changeset
1249 CX_TEST_ASSERT(0 == cxMapDifferenceShallow(d2, d1, a));
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1250 CX_TEST_ASSERT(cxMapContains(d2, "k0"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1251 CX_TEST_ASSERT(!cxMapContains(d2, "k1"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1252 CX_TEST_ASSERT(!cxMapContains(d2, "k2"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1253 CX_TEST_ASSERT(!cxMapContains(d2, "k3"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1254 CX_TEST_ASSERT(!cxMapContains(d2, "k4"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1255 CX_TEST_ASSERT(cxMapContains(d2, "k5"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1256
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1257 cxMapClear(d1);
1604
68b75c091028 rename the "simple" cloning functions from Simple to Shallow
Mike Becker <universe@uap-core.de>
parents: 1582
diff changeset
1258 CX_TEST_ASSERT(0 == cxMapIntersectionShallow(d1, d2, c));
1480
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1259 CX_TEST_ASSERT(!cxMapContains(d1, "k0"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1260 CX_TEST_ASSERT(!cxMapContains(d1, "k1"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1261 CX_TEST_ASSERT(!cxMapContains(d1, "k2"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1262 CX_TEST_ASSERT(!cxMapContains(d1, "k3"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1263 CX_TEST_ASSERT(!cxMapContains(d1, "k4"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1264 CX_TEST_ASSERT(cxMapContains(d1, "k5"));
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1265 }
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1266
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1267 cxMapFree(a);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1268 cxMapFree(b);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1269 cxMapFree(c);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1270 cxListFree(kl1);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1271 cxListFree(kl2);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1272 cxMapFree(d1);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1273 cxMapFree(d2);
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1274 }
83146195a1db add tests for simple clone functions
Mike Becker <universe@uap-core.de>
parents: 1474
diff changeset
1275
1579
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1276 CX_TEST(test_hash_map_compare) {
1605
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1277 CxMap *map1 = cxHashMapCreate(NULL, sizeof(int), 0);
55b13f583356 refactor the list and map construction functions and remove the simple macros
Mike Becker <universe@uap-core.de>
parents: 1604
diff changeset
1278 CxMap *map2 = cxHashMapCreate(NULL, CX_STORE_POINTERS, 0);
1618
ef7cab6eb131 huge refactoring of collections to add support for 3-arg compare functions
Mike Becker <universe@uap-core.de>
parents: 1616
diff changeset
1279 cxSetCompareFunc(map1, cx_cmp_int);
ef7cab6eb131 huge refactoring of collections to add support for 3-arg compare functions
Mike Becker <universe@uap-core.de>
parents: 1616
diff changeset
1280 cxSetCompareFunc(map2, cx_cmp_int);
1579
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1281
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1282 // some ints we can point to in the pointer map
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1283 int z13 = 13;
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1284 int z15 = 15;
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1285 int z42 = 42;
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1286 int z1337 = 1337;
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1287 int z4711 = 4711;
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1288
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1289 CX_TEST_DO {
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1290 // empty maps are equal
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1291 CX_TEST_ASSERT(cxMapCompare(map1, map2) == 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1292 CX_TEST_ASSERT(cxMapCompare(map2, map1) == 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1293
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1294 // left has fewer keys than right
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1295 cxMapPut(map1, "first key", &z13);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1296 cxMapPut(map1, "second key", &z15);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1297 cxMapPut(map2, "first key", &z13);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1298 cxMapPut(map2, "second key", &z15);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1299 cxMapPut(map2, "third key", &z42);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1300 CX_TEST_ASSERT(cxMapCompare(map1, map2) < 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1301 CX_TEST_ASSERT(cxMapCompare(map2, map1) > 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1302
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1303 // both are equal
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1304 cxMapPut(map1, "third key", &z42);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1305 CX_TEST_ASSERT(cxMapCompare(map1, map2) == 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1306 CX_TEST_ASSERT(cxMapCompare(map2, map1) == 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1307
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1308 // left has more keys than right
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1309 cxMapPut(map1, "fourth key", &z1337);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1310 CX_TEST_ASSERT(cxMapCompare(map1, map2) > 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1311 CX_TEST_ASSERT(cxMapCompare(map2, map1) < 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1312
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1313 // key sets differ
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1314 cxMapPut(map2, "wrong key", &z1337);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1315 CX_TEST_ASSERT(cxMapCompare(map1, map2) != 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1316 CX_TEST_ASSERT(cxMapCompare(map2, map1) != 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1317
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1318 // values differ
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1319 cxMapRemove(map2, "wrong key");
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1320 cxMapPut(map2, "fourth key", &z4711);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1321 CX_TEST_ASSERT(cxMapCompare(map1, map2) != 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1322 CX_TEST_ASSERT(cxMapCompare(map2, map1) != 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1323
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1324 // equal again (by overwriting value in map 1)
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1325 cxMapPut(map1, "fourth key", &z4711);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1326 CX_TEST_ASSERT(cxMapCompare(map1, map2) == 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1327 CX_TEST_ASSERT(cxMapCompare(map2, map1) == 0);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1328 }
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1329 cxMapFree(map1);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1330 cxMapFree(map2);
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1331 }
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1332
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1333 CX_TEST(test_empty_map_size) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1334 CX_TEST_DO {
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1335 CX_TEST_ASSERT(cxEmptyMap->collection.size == 0);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1336 CX_TEST_ASSERT(cxMapSize(cxEmptyMap) == 0);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1337 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1338 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1339
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1340 CX_TEST(test_empty_map_iterator) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1341 CxMap *map = cxEmptyMap;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1342
1115
6db21dee4929 create specialized map iterators - fixes #550
Mike Becker <universe@uap-core.de>
parents: 1114
diff changeset
1343 CxMapIterator it1 = cxMapIterator(map);
6db21dee4929 create specialized map iterators - fixes #550
Mike Becker <universe@uap-core.de>
parents: 1114
diff changeset
1344 CxMapIterator it2 = cxMapIteratorValues(map);
6db21dee4929 create specialized map iterators - fixes #550
Mike Becker <universe@uap-core.de>
parents: 1114
diff changeset
1345 CxMapIterator it3 = cxMapIteratorKeys(map);
1429
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
1346 CxMapIterator it4 = cxMapIterator(map);
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
1347 CxMapIterator it5 = cxMapIteratorValues(map);
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
1348 CxMapIterator it6 = cxMapIteratorKeys(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1349
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1350 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1351 CX_TEST_ASSERT(!cxIteratorValid(it1));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1352 CX_TEST_ASSERT(!cxIteratorValid(it2));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1353 CX_TEST_ASSERT(!cxIteratorValid(it3));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1354 CX_TEST_ASSERT(!cxIteratorValid(it4));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1355 CX_TEST_ASSERT(!cxIteratorValid(it5));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1356 CX_TEST_ASSERT(!cxIteratorValid(it6));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1357
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1358 int c = 0;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1359 cx_foreach(void*, data, it1) c++;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1360 cx_foreach(void*, data, it2) c++;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1361 cx_foreach(void*, data, it3) c++;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1362 cx_foreach(void*, data, it4) c++;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1363 cx_foreach(void*, data, it5) c++;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1364 cx_foreach(void*, data, it6) c++;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1365 CX_TEST_ASSERT(c == 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1366 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1367 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1368
1388
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1369 CX_TEST(test_null_map_iterator) {
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1370 CxMap *map = NULL;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1371
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1372 CxMapIterator it1 = cxMapIterator(map);
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1373 CxMapIterator it2 = cxMapIteratorValues(map);
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1374 CxMapIterator it3 = cxMapIteratorKeys(map);
1429
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
1375 CxMapIterator it4 = cxMapIterator(map);
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
1376 CxMapIterator it5 = cxMapIteratorValues(map);
6e0c3a8a914a remove the concept of "mutating iterators" - resolves #579
Mike Becker <universe@uap-core.de>
parents: 1388
diff changeset
1377 CxMapIterator it6 = cxMapIteratorKeys(map);
1388
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1378
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1379 CX_TEST_DO {
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1380 CX_TEST_ASSERT(!cxIteratorValid(it1));
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1381 CX_TEST_ASSERT(!cxIteratorValid(it2));
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1382 CX_TEST_ASSERT(!cxIteratorValid(it3));
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1383 CX_TEST_ASSERT(!cxIteratorValid(it4));
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1384 CX_TEST_ASSERT(!cxIteratorValid(it5));
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1385 CX_TEST_ASSERT(!cxIteratorValid(it6));
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1386
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1387 int c = 0;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1388 cx_foreach(void*, data, it1) c++;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1389 cx_foreach(void*, data, it2) c++;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1390 cx_foreach(void*, data, it3) c++;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1391 cx_foreach(void*, data, it4) c++;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1392 cx_foreach(void*, data, it5) c++;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1393 cx_foreach(void*, data, it6) c++;
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1394 CX_TEST_ASSERT(c == 0);
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1395 }
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1396 }
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1397
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1398 CX_TEST(test_empty_map_no_ops) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1399 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1400 // assertion not possible
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1401 // test that no segfault happens and valgrind is happy
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1402 cxMapClear(cxEmptyMap);
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
1403 cxMapFree(cxEmptyMap);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1404 CX_TEST_ASSERT(true);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1405 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1406 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1407
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1408 CX_TEST(test_empty_map_get) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1409 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1410 CxHashKey key = cx_hash_key_str("test");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1411 CX_TEST_ASSERT(cxMapGet(cxEmptyMap, key) == NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1412 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1413 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1414
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1415 CX_TEST(test_hash_map_generics) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1416 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1417 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1418 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1419 CX_TEST_DO {
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1420 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 0);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1421 cxMapPut(map, "test", "test");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1422 cxMapPut(map, cx_mutstr("foo"), "bar");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1423 cxMapPut(map, cx_str("hallo"), "welt");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1424
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1425 CX_TEST_ASSERT(map->collection.size == 3);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1426 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "test"), "test"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1427 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "foo"), "bar"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1428 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "hallo"), "welt"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1429
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1430 CX_TEST_ASSERT(0 == cxMapRemove(map, cx_str("test")));
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1431 const char *hallo = "hallo";
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1432 CX_TEST_ASSERT(0 == cxMapRemove(map, hallo));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1433 cxMapPut(map, cx_hash_key_str("key"), "value");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1434
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1435 CX_TEST_ASSERT(map->collection.size == 2);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1436 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "key"), "value"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1437 CX_TEST_ASSERT(0 == strcmp(cxMapGet(map, "foo"), "bar"));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1438
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1439 const char *r1, *r2;
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1440 CX_TEST_ASSERT(0 == cxMapRemoveAndGet(map, "key", &r1));
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1441 CX_TEST_ASSERT(0 == strcmp(r1, "value"));
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1442 CX_TEST_ASSERT(0 == cxMapRemoveAndGet(map, cx_str("foo"), &r2));
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1443 CX_TEST_ASSERT(0 == strcmp(r2, "bar"));
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1444 r2 = "nope";
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1445 CX_TEST_ASSERT(0 != cxMapRemoveAndGet(map, cx_hash_key("notfound",9), &r2));
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1446 CX_TEST_ASSERT(0 == strcmp(r2, "nope"));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1447
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1448 CX_TEST_ASSERT(map->collection.size == 0);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1449
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
1450 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1451 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1452 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1453 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1454 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1455
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1456 struct test_map_kv {
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1457 const char *key;
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1458 const char *value;
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1459 };
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1460
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1461 static struct test_map_kv const test_map_operations[] = {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1462 {"key 1", "test"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1463 {"key 2", "blub"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1464 {"key 3", "hallo"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1465 {"key 2", "foobar"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1466 {"key 4", "value 4"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1467 {"key 5", "value 5"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1468 {"key 6", "value 6"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1469 {"key 4", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1470 {"key 7", "value 7"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1471 {"key 8", "value 8"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1472 {"does not exist", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1473 {"key 9", "value 9"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1474 {"key 6", "other value"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1475 {"key 7", "something else"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1476 {"key 8", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1477 {"key 2", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1478 {"key 8", "new value"},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1479 };
926
8fdd8d78c14b fix several survivors of east-const and some missing consts
Mike Becker <universe@uap-core.de>
parents: 890
diff changeset
1480 static const size_t test_map_operations_len =
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1481 sizeof(test_map_operations) / sizeof(struct test_map_kv);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1482 static struct test_map_kv test_map_reference[] = {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1483 {"key 1", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1484 {"key 2", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1485 {"key 3", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1486 {"key 4", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1487 {"key 5", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1488 {"key 6", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1489 {"key 7", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1490 {"key 8", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1491 {"key 9", NULL},
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1492 };
926
8fdd8d78c14b fix several survivors of east-const and some missing consts
Mike Becker <universe@uap-core.de>
parents: 890
diff changeset
1493 static const size_t test_map_reference_len =
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1494 sizeof(test_map_reference) / sizeof(struct test_map_kv);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1495
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1496 static void test_map_reference_put(const char *key, const char *value) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1497 for (size_t i = 0 ; i < test_map_reference_len ; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1498 if (0 == strcmp(key, test_map_reference[i].key)) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1499 test_map_reference[i].value = value;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1500 return;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1501 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1502 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1503 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1504
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1505 static const char *test_map_reference_get(const char *key) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1506 for (size_t i = 0 ; i < test_map_reference_len ; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1507 if (0 == strcmp(key, test_map_reference[i].key)) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1508 return test_map_reference[i].value;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1509 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1510 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1511 return NULL;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1512 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1513
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1514 static const char *test_map_reference_remove(const char *key) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1515 for (size_t i = 0 ; i < test_map_reference_len ; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1516 if (0 == strcmp(key, test_map_reference[i].key)) {
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1517 const char *ret = test_map_reference[i].value;
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1518 test_map_reference[i].value = NULL;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1519 return ret;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1520 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1521 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1522 return NULL;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1523 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1524
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1525 static size_t test_map_reference_size(void) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1526 size_t size = 0;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1527 for (size_t i = 0; i < test_map_reference_len; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1528 if (test_map_reference[i].value != NULL) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1529 size++;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1530 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1531 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1532 return size;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1533 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1534
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1535 static CX_TEST_SUBROUTINE(verify_map_contents, CxMap *map) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1536 // verify that the reference map has same size (i.e. no other keys are mapped)
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1537 CX_TEST_ASSERT(map->collection.size == test_map_reference_size());
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1538
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1539 // verify key iterator
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1540 {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1541 // collect the keys from the map iterator
1115
6db21dee4929 create specialized map iterators - fixes #550
Mike Becker <universe@uap-core.de>
parents: 1114
diff changeset
1542 CxMapIterator keyiter = cxMapIteratorKeys(map);
850
b2bc48c2b251 add iterator over raw C arrays - closes #389
Mike Becker <universe@uap-core.de>
parents: 785
diff changeset
1543 CX_TEST_ASSERT(keyiter.elem_size == sizeof(CxHashKey));
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1544 CX_TEST_ASSERT(keyiter.elem_count == map->collection.size);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1545 CxHashKey *keys = calloc(map->collection.size, sizeof(CxHashKey));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1546 cx_foreach(CxHashKey*, elem, keyiter) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1547 keys[keyiter.index] = *elem;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1548 }
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1549 CX_TEST_ASSERT(keyiter.index == map->collection.size);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1550 // verify that all keys are mapped to values in reference map
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1551 for (size_t i = 0 ; i < map->collection.size ; i++) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1552 cxmutstr ksz = cx_strdup(cx_strn(keys[i].data, keys[i].len));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1553 CX_TEST_ASSERT(test_map_reference_get(ksz.ptr) != NULL);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1554 cx_strfree(&ksz);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1555 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1556 free(keys);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1557 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1558
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1559 // verify value iterator
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1560 {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1561 // by using that the values in our test data are unique strings
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1562 // we can re-use a similar approach as above
1115
6db21dee4929 create specialized map iterators - fixes #550
Mike Becker <universe@uap-core.de>
parents: 1114
diff changeset
1563 CxMapIterator valiter = cxMapIteratorValues(map);
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1564 CX_TEST_ASSERT(valiter.elem_size == map->collection.elem_size);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1565 CX_TEST_ASSERT(valiter.elem_count == map->collection.size);
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1566 const char ** values = calloc(map->collection.size, sizeof(const char *));
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1567 cx_foreach(const char *, elem, valiter) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1568 values[valiter.index] = elem;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1569 }
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1570 CX_TEST_ASSERT(valiter.index == map->collection.size);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1571 // verify that all values are present in the reference map
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1572 for (size_t i = 0 ; i < map->collection.size ; i++) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1573 bool found = false;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1574 for (size_t j = 0; j < test_map_reference_len ; j++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1575 if (test_map_reference[j].value == values[i]) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1576 found = true;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1577 break;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1578 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1579 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1580 CX_TEST_ASSERTM(found, "A value was not found in the reference map");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1581 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1582 free(values);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1583 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1584
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1585 // verify pair iterator
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1586 {
1115
6db21dee4929 create specialized map iterators - fixes #550
Mike Becker <universe@uap-core.de>
parents: 1114
diff changeset
1587 CxMapIterator pairiter = cxMapIterator(map);
850
b2bc48c2b251 add iterator over raw C arrays - closes #389
Mike Becker <universe@uap-core.de>
parents: 785
diff changeset
1588 CX_TEST_ASSERT(pairiter.elem_size == sizeof(CxMapEntry));
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1589 CX_TEST_ASSERT(pairiter.elem_count == map->collection.size);
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1590 struct test_map_kv *pairs = calloc(map->collection.size, sizeof(struct test_map_kv));
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1591 cx_foreach(CxMapEntry*, entry, pairiter) {
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1592 const CxHashKey *key = entry->key;
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1593 pairs[pairiter.index].key = cx_strdup(cx_strn(key->data, key->len)).ptr;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1594 pairs[pairiter.index].value = entry->value;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1595 }
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1596 CX_TEST_ASSERT(pairiter.index == map->collection.size);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1597 // verify that all pairs are present in the reference map
856
6bbbf219251d fix name of collection base member (to avoid base.base)
Mike Becker <universe@uap-core.de>
parents: 855
diff changeset
1598 for (size_t i = 0 ; i < map->collection.size ; i++) {
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1599 CX_TEST_ASSERT(test_map_reference_get(pairs[i].key) == pairs[i].value);
1318
12fa1d37fe48 allow changing the cxDefaultAllocator - resolves #669
Mike Becker <universe@uap-core.de>
parents: 1115
diff changeset
1600 // this was cx_strdup'ed
1319
aa1f580f8f59 add convenience macros for using the default allocator - relates to #669
Mike Becker <universe@uap-core.de>
parents: 1318
diff changeset
1601 cxFreeDefault((void*)pairs[i].key);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1602 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1603 free(pairs);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1604 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1605 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1606
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1607 CX_TEST(test_hash_map_basic_operations) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1608 CxTestingAllocator talloc;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1609 cx_testing_allocator_init(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1610 CxAllocator *allocator = &talloc.base;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1611 CX_TEST_DO {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1612 // create the map
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1613 CxMap *map = cxHashMapCreate(allocator, CX_STORE_POINTERS, 8);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1614
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1615 // clear the reference map
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1616 for (size_t i = 0 ; i < test_map_reference_len ; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1617 test_map_reference[i].value = NULL;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1618 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1619
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1620 // verify iterators for empty map
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1621 CX_TEST_CALL_SUBROUTINE(verify_map_contents, map);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1622
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1623 // execute operations and verify results
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1624 for (size_t i = 0 ; i < test_map_operations_len ; i++) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1625 struct test_map_kv kv = test_map_operations[i];
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1626 CxHashKey key = cx_hash_key_str(kv.key);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1627 key.hash = 0; // force the hash map to compute the hash
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1628 if (kv.value != NULL) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1629 // execute a put operation and verify that the exact value can be read back
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1630 test_map_reference_put(kv.key, kv.value);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1631 int result = cxMapPut(map, key, (void *) kv.value);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1632 CX_TEST_ASSERT(result == 0);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1633 void *added = cxMapGet(map, key);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1634 CX_TEST_ASSERT(0 == memcmp(kv.value, added, strlen(kv.value)));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1635 } else {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1636 // execute a remove and verify that the removed element was returned (or NULL)
890
54565fd74e74 move all const keywords to the west - fixes #426
Mike Becker <universe@uap-core.de>
parents: 856
diff changeset
1637 const char *found = test_map_reference_remove(kv.key);
994
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1638 void *removed = (void*) 0x1337;
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1639 int result = cxMapRemoveAndGet(map, key, &removed);
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1640 if (found == NULL) {
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1641 CX_TEST_ASSERT(0 != result);
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1642 CX_TEST_ASSERT(removed == (void*) 0x1337);
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1643 } else {
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1644 CX_TEST_ASSERT(0 == result);
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1645 CX_TEST_ASSERT(removed == found);
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1646 }
3603bdf4a78b remove map detach function - fixes #487
Mike Becker <universe@uap-core.de>
parents: 993
diff changeset
1647
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1648 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1649 // compare the current map state with the reference map
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1650 CX_TEST_CALL_SUBROUTINE(verify_map_contents, map);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1651 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1652
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1653 // destroy the map and verify the memory (de)allocations
993
b642eca4b956 make names of destroy and free functions consistent - fixes #484
Mike Becker <universe@uap-core.de>
parents: 985
diff changeset
1654 cxMapFree(map);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1655 CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1656 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1657 cx_testing_allocator_destroy(&talloc);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1658 }
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1659
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1660 CxTestSuite *cx_test_suite_hash_map(void) {
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1661 CxTestSuite *suite = cx_test_suite_new("map");
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1662
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1663 cx_test_register(suite, test_hash_map_create);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1664 cx_test_register(suite, test_hash_map_create_store_pointers);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1665 cx_test_register(suite, test_hash_map_basic_operations);
1341
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
1666 cx_test_register(suite, test_hash_map_emplace);
dc88d2ece7e4 add cxMapEmplace()
Mike Becker <universe@uap-core.de>
parents: 1319
diff changeset
1667 cx_test_register(suite, test_hash_map_emplace_pointers);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1668 cx_test_register(suite, test_hash_map_rehash);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1669 cx_test_register(suite, test_hash_map_rehash_not_required);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1670 cx_test_register(suite, test_hash_map_clear);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1671 cx_test_register(suite, test_hash_map_store_ucx_strings);
1442
244fb8bc3584 fix hash map not being able to deal with 64-bit hashes
Mike Becker <universe@uap-core.de>
parents: 1439
diff changeset
1672 cx_test_register(suite, test_hash_map_integer_keys);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1673 cx_test_register(suite, test_hash_map_remove_via_iterator);
1114
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
1674 cx_test_register(suite, test_hash_map_simple_destructor_objects);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
1675 cx_test_register(suite, test_hash_map_advanced_destructor_objects);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
1676 cx_test_register(suite, test_hash_map_simple_destructor_pointers);
ad5eeb256242 fix that overwriting a map element did not call any destructor function
Mike Becker <universe@uap-core.de>
parents: 1111
diff changeset
1677 cx_test_register(suite, test_hash_map_advanced_destructor_pointers);
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
1678 cx_test_register(suite, test_hash_map_clone);
1443
6986e9ed70f3 add test coverage for allocation failures in clone-function
Mike Becker <universe@uap-core.de>
parents: 1442
diff changeset
1679 cx_test_register(suite, test_hash_map_clone_alloc_fail);
1439
8e7fe85febc0 add tests for cxMapClone() - relates to #743
Mike Becker <universe@uap-core.de>
parents: 1429
diff changeset
1680 cx_test_register(suite, test_hash_map_clone_ptr);
1448
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
1681 cx_test_register(suite, test_hash_map_difference);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
1682 cx_test_register(suite, test_hash_map_difference_ptr);
0f0fe7311b76 add tests for cxMapDifference() and cxMapListDifference()
Mike Becker <universe@uap-core.de>
parents: 1444
diff changeset
1683 cx_test_register(suite, test_hash_map_list_difference);
1450
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
1684 cx_test_register(suite, test_hash_map_difference_alloc_fail);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
1685 cx_test_register(suite, test_hash_map_list_difference_alloc_fail);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
1686 cx_test_register(suite, test_hash_map_difference_non_empty_target);
09a73312d5ec add more test coverage for new map functions and fixes some issues
Mike Becker <universe@uap-core.de>
parents: 1448
diff changeset
1687 cx_test_register(suite, test_hash_map_list_difference_non_empty_target);
1467
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1688 cx_test_register(suite, test_hash_map_intersection);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1689 cx_test_register(suite, test_hash_map_intersection_ptr);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1690 cx_test_register(suite, test_hash_map_list_intersection);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1691 cx_test_register(suite, test_hash_map_intersection_alloc_fail);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1692 cx_test_register(suite, test_hash_map_list_intersection_alloc_fail);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1693 cx_test_register(suite, test_hash_map_intersection_non_empty_target);
bb6f04c35310 implements cxMapIntersection() and cxMapListIntersection() - resolves #555
Mike Becker <universe@uap-core.de>
parents: 1466
diff changeset
1694 cx_test_register(suite, test_hash_map_list_intersection_non_empty_target);
1474
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1695 cx_test_register(suite, test_hash_map_union);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1696 cx_test_register(suite, test_hash_map_union_ptr);
84de0ba791af implement cxMapUnion() - resolves #756
Mike Becker <universe@uap-core.de>
parents: 1467
diff changeset
1697 cx_test_register(suite, test_hash_map_union_alloc_fail);
1616
bdc04a8e0dd3 update names of internal simple_clone funcs to shallow_clone funcs - relates to #780
Mike Becker <universe@uap-core.de>
parents: 1605
diff changeset
1698 cx_test_register(suite, test_hash_map_shallow_clones);
1579
0393c67556ec add cxMapCompare() - resolves #784
Mike Becker <universe@uap-core.de>
parents: 1510
diff changeset
1699 cx_test_register(suite, test_hash_map_compare);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1700 cx_test_register(suite, test_empty_map_no_ops);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1701 cx_test_register(suite, test_empty_map_size);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1702 cx_test_register(suite, test_empty_map_get);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1703 cx_test_register(suite, test_empty_map_iterator);
1388
edc34e904fe3 add tests for creating iterators with NULL lists or maps
Mike Becker <universe@uap-core.de>
parents: 1387
diff changeset
1704 cx_test_register(suite, test_null_map_iterator);
785
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1705 cx_test_register(suite, test_hash_map_generics);
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1706
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1707 return suite;
bb18daa62d5f migrate map tests - relates to #342
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1708 }

mercurial