/* Unit tests for hash-map.h. Copyright (C) 2015-2019 Free Software Foundation, Inc. This file is part of GCC. GCC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GCC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GCC; see the file COPYING3. If not see . */ #include "config.h" #include "system.h" #include "coretypes.h" #include "tm.h" #include "opts.h" #include "hash-set.h" #include "fixed-value.h" #include "alias.h" #include "flags.h" #include "symtab.h" #include "tree-core.h" #include "stor-layout.h" #include "tree.h" #include "stringpool.h" #include "selftest.h" #if CHECKING_P namespace selftest { /* Construct a hash_map and verify that various operations work correctly. */ static void test_map_of_strings_to_int () { hash_map m; const char *ostrich = "ostrich"; const char *elephant = "elephant"; const char *ant = "ant"; const char *spider = "spider"; const char *millipede = "Illacme plenipes"; const char *eric = "half a bee"; /* A fresh hash_map should be empty. */ ASSERT_TRUE (m.is_empty ()); ASSERT_EQ (NULL, m.get (ostrich)); /* Populate the hash_map. */ ASSERT_EQ (false, m.put (ostrich, 2)); ASSERT_EQ (false, m.put (elephant, 4)); ASSERT_EQ (false, m.put (ant, 6)); ASSERT_EQ (false, m.put (spider, 8)); ASSERT_EQ (false, m.put (millipede, 750)); ASSERT_EQ (false, m.put (eric, 3)); /* Verify that we can recover the stored values. */ ASSERT_EQ (6, m.elements ()); ASSERT_EQ (2, *m.get (ostrich)); ASSERT_EQ (4, *m.get (elephant)); ASSERT_EQ (6, *m.get (ant)); ASSERT_EQ (8, *m.get (spider)); ASSERT_EQ (750, *m.get (millipede)); ASSERT_EQ (3, *m.get (eric)); /* Verify removing an item. */ m.remove (eric); ASSERT_EQ (5, m.elements ()); ASSERT_EQ (NULL, m.get (eric)); m.remove (eric); ASSERT_EQ (5, m.elements ()); ASSERT_EQ (NULL, m.get (eric)); /* A plain char * key is hashed based on its value (address), rather than the string it points to. */ char *another_ant = static_cast (xcalloc (4, 1)); another_ant[0] = 'a'; another_ant[1] = 'n'; another_ant[2] = 't'; another_ant[3] = 0; ASSERT_NE (ant, another_ant); unsigned prev_size = m.elements (); ASSERT_EQ (false, m.put (another_ant, 7)); ASSERT_EQ (prev_size + 1, m.elements ()); /* Need to use string_hash or nofree_string_hash key types to hash based on the string contents. */ hash_map string_map; ASSERT_EQ (false, string_map.put (ant, 1)); ASSERT_EQ (1, string_map.elements ()); ASSERT_EQ (true, string_map.put (another_ant, 5)); ASSERT_EQ (1, string_map.elements ()); } /* Run all of the selftests within this file. */ void hash_map_tests_c_tests () { test_map_of_strings_to_int (); } } // namespace selftest #endif /* CHECKING_P */