1bf215546Sopenharmony_ci/* 2bf215546Sopenharmony_ci * Copyright © 2018 Intel Corporation 3bf215546Sopenharmony_ci * 4bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a 5bf215546Sopenharmony_ci * copy of this software and associated documentation files (the "Software"), 6bf215546Sopenharmony_ci * to deal in the Software without restriction, including without limitation 7bf215546Sopenharmony_ci * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8bf215546Sopenharmony_ci * and/or sell copies of the Software, and to permit persons to whom the 9bf215546Sopenharmony_ci * Software is furnished to do so, subject to the following conditions: 10bf215546Sopenharmony_ci * 11bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the next 12bf215546Sopenharmony_ci * paragraph) shall be included in all copies or substantial portions of the 13bf215546Sopenharmony_ci * Software. 14bf215546Sopenharmony_ci * 15bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16bf215546Sopenharmony_ci * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17bf215546Sopenharmony_ci * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18bf215546Sopenharmony_ci * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19bf215546Sopenharmony_ci * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20bf215546Sopenharmony_ci * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 21bf215546Sopenharmony_ci * IN THE SOFTWARE. 22bf215546Sopenharmony_ci */ 23bf215546Sopenharmony_ci 24bf215546Sopenharmony_ci#include <gtest/gtest.h> 25bf215546Sopenharmony_ci#include "util/hash_table.h" 26bf215546Sopenharmony_ci#include "util/set.h" 27bf215546Sopenharmony_ci 28bf215546Sopenharmony_ciTEST(set, basic) 29bf215546Sopenharmony_ci{ 30bf215546Sopenharmony_ci struct set *s = _mesa_set_create(NULL, _mesa_hash_pointer, 31bf215546Sopenharmony_ci _mesa_key_pointer_equal); 32bf215546Sopenharmony_ci struct set_entry *entry; 33bf215546Sopenharmony_ci 34bf215546Sopenharmony_ci const void *a = (const void *)10; 35bf215546Sopenharmony_ci const void *b = (const void *)20; 36bf215546Sopenharmony_ci 37bf215546Sopenharmony_ci _mesa_set_add(s, a); 38bf215546Sopenharmony_ci _mesa_set_add(s, b); 39bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 2); 40bf215546Sopenharmony_ci 41bf215546Sopenharmony_ci _mesa_set_add(s, a); 42bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 2); 43bf215546Sopenharmony_ci 44bf215546Sopenharmony_ci entry = _mesa_set_search(s, a); 45bf215546Sopenharmony_ci EXPECT_TRUE(entry); 46bf215546Sopenharmony_ci EXPECT_EQ(entry->key, a); 47bf215546Sopenharmony_ci 48bf215546Sopenharmony_ci _mesa_set_remove(s, entry); 49bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 1); 50bf215546Sopenharmony_ci 51bf215546Sopenharmony_ci entry = _mesa_set_search(s, a); 52bf215546Sopenharmony_ci EXPECT_FALSE(entry); 53bf215546Sopenharmony_ci 54bf215546Sopenharmony_ci _mesa_set_clear(s, NULL); 55bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 0); 56bf215546Sopenharmony_ci EXPECT_EQ(s->deleted_entries, 0); 57bf215546Sopenharmony_ci set_foreach(s, he) { 58bf215546Sopenharmony_ci GTEST_FAIL(); 59bf215546Sopenharmony_ci } 60bf215546Sopenharmony_ci 61bf215546Sopenharmony_ci _mesa_set_add(s, a); 62bf215546Sopenharmony_ci _mesa_set_add(s, b); 63bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 2); 64bf215546Sopenharmony_ci unsigned count = s->entries; 65bf215546Sopenharmony_ci set_foreach_remove(s, he) { 66bf215546Sopenharmony_ci EXPECT_TRUE(he->key == a || he->key == b); 67bf215546Sopenharmony_ci EXPECT_EQ(s->entries, count--); 68bf215546Sopenharmony_ci EXPECT_EQ(s->deleted_entries, 0); 69bf215546Sopenharmony_ci } 70bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 0); 71bf215546Sopenharmony_ci set_foreach(s, he) { 72bf215546Sopenharmony_ci GTEST_FAIL(); 73bf215546Sopenharmony_ci } 74bf215546Sopenharmony_ci 75bf215546Sopenharmony_ci _mesa_set_destroy(s, NULL); 76bf215546Sopenharmony_ci} 77bf215546Sopenharmony_ci 78bf215546Sopenharmony_ciTEST(set, clone) 79bf215546Sopenharmony_ci{ 80bf215546Sopenharmony_ci struct set *s = _mesa_set_create(NULL, _mesa_hash_pointer, 81bf215546Sopenharmony_ci _mesa_key_pointer_equal); 82bf215546Sopenharmony_ci struct set_entry *entry; 83bf215546Sopenharmony_ci 84bf215546Sopenharmony_ci const void *a = (const void *)10; 85bf215546Sopenharmony_ci const void *b = (const void *)20; 86bf215546Sopenharmony_ci const void *c = (const void *)30; 87bf215546Sopenharmony_ci 88bf215546Sopenharmony_ci _mesa_set_add(s, a); 89bf215546Sopenharmony_ci _mesa_set_add(s, b); 90bf215546Sopenharmony_ci _mesa_set_add(s, c); 91bf215546Sopenharmony_ci 92bf215546Sopenharmony_ci entry = _mesa_set_search(s, c); 93bf215546Sopenharmony_ci EXPECT_TRUE(entry); 94bf215546Sopenharmony_ci EXPECT_EQ(entry->key, c); 95bf215546Sopenharmony_ci 96bf215546Sopenharmony_ci _mesa_set_remove(s, entry); 97bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 2); 98bf215546Sopenharmony_ci 99bf215546Sopenharmony_ci struct set *clone = _mesa_set_clone(s, NULL); 100bf215546Sopenharmony_ci EXPECT_EQ(clone->entries, 2); 101bf215546Sopenharmony_ci 102bf215546Sopenharmony_ci EXPECT_TRUE(_mesa_set_search(clone, a)); 103bf215546Sopenharmony_ci EXPECT_TRUE(_mesa_set_search(clone, b)); 104bf215546Sopenharmony_ci EXPECT_FALSE(_mesa_set_search(clone, c)); 105bf215546Sopenharmony_ci 106bf215546Sopenharmony_ci _mesa_set_destroy(s, NULL); 107bf215546Sopenharmony_ci _mesa_set_destroy(clone, NULL); 108bf215546Sopenharmony_ci} 109bf215546Sopenharmony_ci 110bf215546Sopenharmony_ciTEST(set, remove_key) 111bf215546Sopenharmony_ci{ 112bf215546Sopenharmony_ci struct set *s = _mesa_set_create(NULL, _mesa_hash_pointer, 113bf215546Sopenharmony_ci _mesa_key_pointer_equal); 114bf215546Sopenharmony_ci 115bf215546Sopenharmony_ci const void *a = (const void *)10; 116bf215546Sopenharmony_ci const void *b = (const void *)20; 117bf215546Sopenharmony_ci const void *c = (const void *)30; 118bf215546Sopenharmony_ci 119bf215546Sopenharmony_ci _mesa_set_add(s, a); 120bf215546Sopenharmony_ci _mesa_set_add(s, b); 121bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 2); 122bf215546Sopenharmony_ci 123bf215546Sopenharmony_ci /* Remove existing key. */ 124bf215546Sopenharmony_ci _mesa_set_remove_key(s, a); 125bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 1); 126bf215546Sopenharmony_ci EXPECT_FALSE(_mesa_set_search(s, a)); 127bf215546Sopenharmony_ci EXPECT_TRUE(_mesa_set_search(s, b)); 128bf215546Sopenharmony_ci 129bf215546Sopenharmony_ci /* Remove non-existing key. */ 130bf215546Sopenharmony_ci _mesa_set_remove_key(s, c); 131bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 1); 132bf215546Sopenharmony_ci EXPECT_FALSE(_mesa_set_search(s, a)); 133bf215546Sopenharmony_ci EXPECT_TRUE(_mesa_set_search(s, b)); 134bf215546Sopenharmony_ci 135bf215546Sopenharmony_ci _mesa_set_destroy(s, NULL); 136bf215546Sopenharmony_ci} 137bf215546Sopenharmony_ci 138bf215546Sopenharmony_cistatic uint32_t hash_int(const void *p) 139bf215546Sopenharmony_ci{ 140bf215546Sopenharmony_ci int i = *(const int *)p; 141bf215546Sopenharmony_ci return i; 142bf215546Sopenharmony_ci} 143bf215546Sopenharmony_ci 144bf215546Sopenharmony_cistatic bool cmp_int(const void *p1, const void *p2) 145bf215546Sopenharmony_ci{ 146bf215546Sopenharmony_ci int i1 = *(const int *)p1, i2 = *(const int *)p2; 147bf215546Sopenharmony_ci return i1 == i2; 148bf215546Sopenharmony_ci} 149bf215546Sopenharmony_ci 150bf215546Sopenharmony_ciTEST(set, search_or_add) 151bf215546Sopenharmony_ci{ 152bf215546Sopenharmony_ci struct set *s = _mesa_set_create(NULL, hash_int, cmp_int); 153bf215546Sopenharmony_ci 154bf215546Sopenharmony_ci int a = 10, b = 20, c = 20, d = 30; 155bf215546Sopenharmony_ci 156bf215546Sopenharmony_ci _mesa_set_add(s, &a); 157bf215546Sopenharmony_ci _mesa_set_add(s, &b); 158bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 2); 159bf215546Sopenharmony_ci 160bf215546Sopenharmony_ci bool found = false; 161bf215546Sopenharmony_ci struct set_entry *entry = _mesa_set_search_or_add(s, &c, &found); 162bf215546Sopenharmony_ci EXPECT_EQ(entry->key, (void *)&b); 163bf215546Sopenharmony_ci EXPECT_EQ(found, true); 164bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 2); 165bf215546Sopenharmony_ci 166bf215546Sopenharmony_ci found = false; 167bf215546Sopenharmony_ci struct set_entry *entry3 = _mesa_set_search_or_add(s, &d, &found); 168bf215546Sopenharmony_ci EXPECT_EQ(entry3->key, &d); 169bf215546Sopenharmony_ci EXPECT_EQ(found, false); 170bf215546Sopenharmony_ci EXPECT_EQ(s->entries, 3); 171bf215546Sopenharmony_ci 172bf215546Sopenharmony_ci _mesa_set_destroy(s, NULL); 173bf215546Sopenharmony_ci} 174